mirror of https://github.com/helm/helm
parent
34362c13bf
commit
d50e22c707
@ -0,0 +1,79 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"github.com/kubernetes/helm/pkg/repo"
|
||||
|
||||
"testing"
|
||||
)
|
||||
|
||||
const testDir = "testdata/"
|
||||
const testFile = "testdata/local-cache.yaml"
|
||||
|
||||
type searchTestCase struct {
|
||||
in string
|
||||
expectedOut []string
|
||||
}
|
||||
|
||||
var searchTestCases = []searchTestCase{
|
||||
{"foo", []string{}},
|
||||
{"alpine", []string{"alpine-1.0.0"}},
|
||||
{"sumtin", []string{"alpine-1.0.0"}},
|
||||
{"web", []string{"nginx-0.1.0"}},
|
||||
}
|
||||
|
||||
var searchCacheTestCases = []searchTestCase{
|
||||
{"notthere", []string{}},
|
||||
{"odd", []string{"foobar/oddness-1.2.3"}},
|
||||
{"sumtin", []string{"local/alpine-1.0.0", "foobar/oddness-1.2.3"}},
|
||||
{"foobar", []string{"foobar/foobar-0.1.0"}},
|
||||
{"web", []string{"local/nginx-0.1.0"}},
|
||||
}
|
||||
|
||||
func validateEntries(t *testing.T, in string, found []string, expected []string) {
|
||||
if len(found) != len(expected) {
|
||||
t.Errorf("Failed to search %s: Expected: %#v got: %#v", in, expected, found)
|
||||
}
|
||||
foundCount := 0
|
||||
for _, exp := range expected {
|
||||
for _, f := range found {
|
||||
if exp == f {
|
||||
foundCount = foundCount + 1
|
||||
continue
|
||||
}
|
||||
}
|
||||
}
|
||||
if foundCount != len(expected) {
|
||||
t.Errorf("Failed to find expected items for %s: Expected: %#v got: %#v", in, expected, found)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
func searchTestRunner(t *testing.T, tc searchTestCase) {
|
||||
cf, err := repo.LoadCacheFile(testFile)
|
||||
if err != nil {
|
||||
t.Errorf("Failed to load cache file : %s : %s", testFile, err)
|
||||
}
|
||||
|
||||
u := searchChartRefsForPattern(tc.in, cf.Entries)
|
||||
validateEntries(t, tc.in, u, tc.expectedOut)
|
||||
}
|
||||
|
||||
func searchCacheTestRunner(t *testing.T, tc searchTestCase) {
|
||||
u, err := searchCacheForPattern(testDir, tc.in)
|
||||
if err != nil {
|
||||
t.Errorf("searchCacheForPattern failed: %#v", err)
|
||||
}
|
||||
validateEntries(t, tc.in, u, tc.expectedOut)
|
||||
}
|
||||
|
||||
func TestSearches(t *testing.T) {
|
||||
for _, tc := range searchTestCases {
|
||||
searchTestRunner(t, tc)
|
||||
}
|
||||
}
|
||||
|
||||
func TestCacheSearches(t *testing.T) {
|
||||
for _, tc := range searchCacheTestCases {
|
||||
searchCacheTestRunner(t, tc)
|
||||
}
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
foobar-0.1.0:
|
||||
url: http://storage.googleapis.com/kubernetes-charts/nginx-0.1.0.tgz
|
||||
name: foobar
|
||||
description: string
|
||||
version: 0.1.0
|
||||
home: https://github.com/foo
|
||||
keywords:
|
||||
- dummy
|
||||
- hokey
|
||||
oddness-1.2.3:
|
||||
url: http://storage.googleapis.com/kubernetes-charts/alpine-1.0.0.tgz
|
||||
name: oddness
|
||||
description: string
|
||||
version: 1.2.3
|
||||
home: https://github.com/something
|
||||
keywords:
|
||||
- duck
|
||||
- sumtin
|
@ -0,0 +1,22 @@
|
||||
nginx-0.1.0:
|
||||
url: http://storage.googleapis.com/kubernetes-charts/nginx-0.1.0.tgz
|
||||
name: nginx
|
||||
description: string
|
||||
version: 0.1.0
|
||||
home: https://github.com/something
|
||||
keywords:
|
||||
- popular
|
||||
- web server
|
||||
- proxy
|
||||
alpine-1.0.0:
|
||||
url: http://storage.googleapis.com/kubernetes-charts/alpine-1.0.0.tgz
|
||||
name: alpine
|
||||
description: string
|
||||
version: 1.0.0
|
||||
home: https://github.com/something
|
||||
keywords:
|
||||
- linux
|
||||
- alpine
|
||||
- small
|
||||
- sumtin
|
||||
|
@ -0,0 +1,41 @@
|
||||
package repo
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
const testfile = "testdata/local-cache.yaml"
|
||||
|
||||
func TestLoadCacheFile(t *testing.T) {
|
||||
cf, err := LoadCacheFile(testfile)
|
||||
if err != nil {
|
||||
t.Errorf("Failed to load cachefile: %s", err)
|
||||
}
|
||||
if len(cf.Entries) != 2 {
|
||||
t.Errorf("Expected 2 entries in the cache file, but got %d", len(cf.Entries))
|
||||
}
|
||||
nginx := false
|
||||
alpine := false
|
||||
for k, e := range cf.Entries {
|
||||
if k == "nginx-0.1.0" {
|
||||
if e.Name == "nginx" {
|
||||
if len(e.Keywords) == 3 {
|
||||
nginx = true
|
||||
}
|
||||
}
|
||||
}
|
||||
if k == "alpine-1.0.0" {
|
||||
if e.Name == "alpine" {
|
||||
if len(e.Keywords) == 4 {
|
||||
alpine = true
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if !nginx {
|
||||
t.Errorf("nginx entry was not decoded properly")
|
||||
}
|
||||
if !alpine {
|
||||
t.Errorf("alpine entry was not decoded properly")
|
||||
}
|
||||
}
|
@ -0,0 +1,22 @@
|
||||
nginx-0.1.0:
|
||||
url: http://storage.googleapis.com/kubernetes-charts/nginx-0.1.0.tgz
|
||||
name: nginx
|
||||
description: string
|
||||
version: 0.1.0
|
||||
home: https://github.com/something
|
||||
keywords:
|
||||
- popular
|
||||
- web server
|
||||
- proxy
|
||||
alpine-1.0.0:
|
||||
url: http://storage.googleapis.com/kubernetes-charts/alpine-1.0.0.tgz
|
||||
name: alpine
|
||||
description: string
|
||||
version: 1.0.0
|
||||
home: https://github.com/something
|
||||
keywords:
|
||||
- linux
|
||||
- alpine
|
||||
- small
|
||||
- sumtin
|
||||
|
Loading…
Reference in new issue