mirror of https://github.com/helm/helm
Merge pull request #994 from technosophos/feat/950-files-in-templates
feat(tiller): add Files map to templatespull/1009/head
commit
be053f3c05
@ -0,0 +1,53 @@
|
||||
/*
|
||||
Copyright 2016 The Kubernetes Authors All rights reserved.
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
*/
|
||||
|
||||
package chartutil
|
||||
|
||||
import (
|
||||
"github.com/golang/protobuf/ptypes/any"
|
||||
)
|
||||
|
||||
// Files is a map of files in a chart that can be accessed from a template.
|
||||
type Files map[string][]byte
|
||||
|
||||
// NewFiles creates a new Files from chart files.
|
||||
// Given an []*any.Any (the format for files in a chart.Chart), extract a map of files.
|
||||
func NewFiles(from []*any.Any) Files {
|
||||
files := map[string][]byte{}
|
||||
for _, f := range from {
|
||||
files[f.TypeUrl] = f.Value
|
||||
}
|
||||
return files
|
||||
}
|
||||
|
||||
// Get a file by path.
|
||||
//
|
||||
// This is intended to be accessed from within a template, so a missed key returns
|
||||
// an empty []byte.
|
||||
func (f Files) Get(name string) []byte {
|
||||
v, ok := f[name]
|
||||
if !ok {
|
||||
return []byte{}
|
||||
}
|
||||
return v
|
||||
}
|
||||
|
||||
// GetString returns a string representation of the given file.
|
||||
//
|
||||
// This is a convenience for the otherwise cumbersome template logic
|
||||
// for '{{.Files.Get "foo" | printf "%s"}}'.
|
||||
func (f Files) GetString(name string) string {
|
||||
return string(f.Get(name))
|
||||
}
|
@ -0,0 +1,53 @@
|
||||
/*
|
||||
Copyright 2016 The Kubernetes Authors All rights reserved.
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
*/
|
||||
|
||||
package chartutil
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/golang/protobuf/ptypes/any"
|
||||
)
|
||||
|
||||
func TestNewFiles(t *testing.T) {
|
||||
|
||||
cases := []struct {
|
||||
path, data string
|
||||
}{
|
||||
{"ship/captain.txt", "The Captain"},
|
||||
{"ship/stowaway.txt", "Legatt"},
|
||||
{"story/name.txt", "The Secret Sharer"},
|
||||
{"story/author.txt", "Joseph Conrad"},
|
||||
}
|
||||
|
||||
a := []*any.Any{}
|
||||
for _, c := range cases {
|
||||
a = append(a, &any.Any{TypeUrl: c.path, Value: []byte(c.data)})
|
||||
}
|
||||
|
||||
files := NewFiles(a)
|
||||
if len(files) != len(cases) {
|
||||
t.Errorf("Expected len() = %d, got %d", len(cases), len(files))
|
||||
}
|
||||
|
||||
for i, f := range cases {
|
||||
if got := string(files.Get(f.path)); got != f.data {
|
||||
t.Errorf("%d: expected %q, got %q", i, f.data, got)
|
||||
}
|
||||
if got := files.GetString(f.path); got != f.data {
|
||||
t.Errorf("%d: expected %q, got %q", i, f.data, got)
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in new issue