Merge branch 'master' of https://github.com/armon/packer into armon-master
Conflicts: packer/config_template.go
This commit is contained in:
commit
a59bbd892d
|
@ -28,6 +28,7 @@ func NewConfigTemplate() (*ConfigTemplate, error) {
|
||||||
|
|
||||||
result.root = template.New("configTemplateRoot")
|
result.root = template.New("configTemplateRoot")
|
||||||
result.root.Funcs(template.FuncMap{
|
result.root.Funcs(template.FuncMap{
|
||||||
|
"isotime": templateISOTime,
|
||||||
"timestamp": templateTimestamp,
|
"timestamp": templateTimestamp,
|
||||||
"user": result.templateUser,
|
"user": result.templateUser,
|
||||||
"uuid": templateUuid,
|
"uuid": templateUuid,
|
||||||
|
@ -79,6 +80,10 @@ func (t *ConfigTemplate) templateUser(n string) (string, error) {
|
||||||
return result, nil
|
return result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func templateISOTime() string {
|
||||||
|
return time.Now().UTC().Format(time.RFC3339)
|
||||||
|
}
|
||||||
|
|
||||||
func templateTimestamp() string {
|
func templateTimestamp() string {
|
||||||
return strconv.FormatInt(time.Now().UTC().Unix(), 10)
|
return strconv.FormatInt(time.Now().UTC().Unix(), 10)
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,28 @@ import (
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func TestConfigTemplateProcess_isotime(t *testing.T) {
|
||||||
|
tpl, err := NewConfigTemplate()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
result, err := tpl.Process(`{{isotime}}`, nil)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
val, err := time.Parse(time.RFC3339, result)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
currentTime := time.Now().UTC()
|
||||||
|
if currentTime.Sub(val) > 2*time.Second {
|
||||||
|
t.Fatalf("val: %d (current: %d)", val, currentTime)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestConfigTemplateProcess_timestamp(t *testing.T) {
|
func TestConfigTemplateProcess_timestamp(t *testing.T) {
|
||||||
tpl, err := NewConfigTemplate()
|
tpl, err := NewConfigTemplate()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in New Issue