github.com/cloudposse/helm@v2.2.3+incompatible/pkg/chartutil/load_test.go (about) 1 /* 2 Copyright 2016 The Kubernetes Authors All rights reserved. 3 4 Licensed under the Apache License, Version 2.0 (the "License"); 5 you may not use this file except in compliance with the License. 6 You may obtain a copy of the License at 7 8 http://www.apache.org/licenses/LICENSE-2.0 9 10 Unless required by applicable law or agreed to in writing, software 11 distributed under the License is distributed on an "AS IS" BASIS, 12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 See the License for the specific language governing permissions and 14 limitations under the License. 15 */ 16 17 package chartutil 18 19 import ( 20 "testing" 21 22 "k8s.io/helm/pkg/proto/hapi/chart" 23 ) 24 25 func TestLoadDir(t *testing.T) { 26 c, err := Load("testdata/frobnitz") 27 if err != nil { 28 t.Fatalf("Failed to load testdata: %s", err) 29 } 30 verifyFrobnitz(t, c) 31 verifyChart(t, c) 32 verifyRequirements(t, c) 33 } 34 35 func TestLoadFile(t *testing.T) { 36 c, err := Load("testdata/frobnitz-1.2.3.tgz") 37 if err != nil { 38 t.Fatalf("Failed to load testdata: %s", err) 39 } 40 verifyFrobnitz(t, c) 41 verifyChart(t, c) 42 verifyRequirements(t, c) 43 } 44 45 // Packaging the chart on a Windows machine will produce an 46 // archive that has \\ as delimiters. Test that we support these archives 47 func TestLoadFileBackslash(t *testing.T) { 48 c, err := Load("testdata/frobnitz_backslash-1.2.3.tgz") 49 if err != nil { 50 t.Fatalf("Failed to load testdata: %s", err) 51 } 52 verifyChartFileAndTemplate(t, c, "frobnitz_backslash") 53 verifyChart(t, c) 54 verifyRequirements(t, c) 55 } 56 57 func verifyChart(t *testing.T, c *chart.Chart) { 58 if c.Metadata.Name == "" { 59 t.Fatalf("No chart metadata found on %v", c) 60 } 61 t.Logf("Verifying chart %s", c.Metadata.Name) 62 if len(c.Templates) != 1 { 63 t.Errorf("Expected 1 template, got %d", len(c.Templates)) 64 } 65 66 numfiles := 8 67 if len(c.Files) != numfiles { 68 t.Errorf("Expected %d extra files, got %d", numfiles, len(c.Files)) 69 for _, n := range c.Files { 70 t.Logf("\t%s", n.TypeUrl) 71 } 72 } 73 74 if len(c.Dependencies) != 2 { 75 t.Errorf("Expected 2 dependencies, got %d (%v)", len(c.Dependencies), c.Dependencies) 76 for _, d := range c.Dependencies { 77 t.Logf("\tSubchart: %s\n", d.Metadata.Name) 78 } 79 } 80 81 expect := map[string]map[string]string{ 82 "alpine": { 83 "version": "0.1.0", 84 }, 85 "mariner": { 86 "version": "4.3.2", 87 }, 88 } 89 90 for _, dep := range c.Dependencies { 91 if dep.Metadata == nil { 92 t.Fatalf("expected metadata on dependency: %v", dep) 93 } 94 exp, ok := expect[dep.Metadata.Name] 95 if !ok { 96 t.Fatalf("Unknown dependency %s", dep.Metadata.Name) 97 } 98 if exp["version"] != dep.Metadata.Version { 99 t.Errorf("Expected %s version %s, got %s", dep.Metadata.Name, exp["version"], dep.Metadata.Version) 100 } 101 } 102 103 } 104 105 func verifyRequirements(t *testing.T, c *chart.Chart) { 106 r, err := LoadRequirements(c) 107 if err != nil { 108 t.Fatal(err) 109 } 110 if len(r.Dependencies) != 2 { 111 t.Errorf("Expected 2 requirements, got %d", len(r.Dependencies)) 112 } 113 tests := []*Dependency{ 114 {Name: "alpine", Version: "0.1.0", Repository: "https://example.com/charts"}, 115 {Name: "mariner", Version: "4.3.2", Repository: "https://example.com/charts"}, 116 } 117 for i, tt := range tests { 118 d := r.Dependencies[i] 119 if d.Name != tt.Name { 120 t.Errorf("Expected dependency named %q, got %q", tt.Name, d.Name) 121 } 122 if d.Version != tt.Version { 123 t.Errorf("Expected dependency named %q to have version %q, got %q", tt.Name, tt.Version, d.Version) 124 } 125 if d.Repository != tt.Repository { 126 t.Errorf("Expected dependency named %q to have repository %q, got %q", tt.Name, tt.Repository, d.Repository) 127 } 128 } 129 } 130 func verifyRequirementsLock(t *testing.T, c *chart.Chart) { 131 r, err := LoadRequirementsLock(c) 132 if err != nil { 133 t.Fatal(err) 134 } 135 if len(r.Dependencies) != 2 { 136 t.Errorf("Expected 2 requirements, got %d", len(r.Dependencies)) 137 } 138 tests := []*Dependency{ 139 {Name: "alpine", Version: "0.1.0", Repository: "https://example.com/charts"}, 140 {Name: "mariner", Version: "4.3.2", Repository: "https://example.com/charts"}, 141 } 142 for i, tt := range tests { 143 d := r.Dependencies[i] 144 if d.Name != tt.Name { 145 t.Errorf("Expected dependency named %q, got %q", tt.Name, d.Name) 146 } 147 if d.Version != tt.Version { 148 t.Errorf("Expected dependency named %q to have version %q, got %q", tt.Name, tt.Version, d.Version) 149 } 150 if d.Repository != tt.Repository { 151 t.Errorf("Expected dependency named %q to have repository %q, got %q", tt.Name, tt.Repository, d.Repository) 152 } 153 } 154 } 155 156 func verifyFrobnitz(t *testing.T, c *chart.Chart) { 157 verifyChartFileAndTemplate(t, c, "frobnitz") 158 } 159 160 func verifyChartFileAndTemplate(t *testing.T, c *chart.Chart, name string) { 161 162 verifyChartfile(t, c.Metadata, name) 163 164 if len(c.Templates) != 1 { 165 t.Fatalf("Expected 1 template, got %d", len(c.Templates)) 166 } 167 168 if c.Templates[0].Name != "templates/template.tpl" { 169 t.Errorf("Unexpected template: %s", c.Templates[0].Name) 170 } 171 172 if len(c.Templates[0].Data) == 0 { 173 t.Error("No template data.") 174 } 175 }