2013-08-15 22:11:27 -04:00
|
|
|
package packer
|
|
|
|
|
|
|
|
import (
|
2014-05-06 09:00:56 -04:00
|
|
|
"fmt"
|
2013-08-15 22:11:27 -04:00
|
|
|
"math"
|
2013-12-27 22:44:26 -05:00
|
|
|
"os"
|
2013-08-15 22:11:27 -04:00
|
|
|
"strconv"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2013-12-28 11:34:17 -05:00
|
|
|
func TestConfigTemplateProcess_env(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err = tpl.Process(`{{env "foo"}}`, nil)
|
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should error")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-05 14:09:37 -04:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-06 09:00:56 -04:00
|
|
|
// Note must format with the magic Date: Mon Jan 2 15:04:05 -0700 MST 2006
|
|
|
|
func TestConfigTemplateProcess_isotime_withFormat(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Checking for a too-many arguments error
|
|
|
|
// Because of the variadic function, compile time checking won't work
|
|
|
|
_, err = tpl.Process(`{{isotime "20060102" "huh"}}`, nil)
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("err: cannot have more than 1 input")
|
|
|
|
}
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{isotime "20060102"}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
ti := time.Now().UTC()
|
|
|
|
val := fmt.Sprintf("%04d%02d%02d", ti.Year(), ti.Month(), ti.Day())
|
|
|
|
|
|
|
|
if result != val {
|
|
|
|
t.Fatalf("val: %s (formated: %s)", val, result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-12-27 22:44:26 -05:00
|
|
|
func TestConfigTemplateProcess_pwd(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
pwd, err := os.Getwd()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{pwd}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result != pwd {
|
|
|
|
t.Fatalf("err: %s", result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-15 22:11:27 -04:00
|
|
|
func TestConfigTemplateProcess_timestamp(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{timestamp}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
val, err := strconv.ParseInt(result, 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
currentTime := time.Now().UTC().Unix()
|
|
|
|
if math.Abs(float64(currentTime-val)) > 10 {
|
|
|
|
t.Fatalf("val: %d (current: %d)", val, currentTime)
|
|
|
|
}
|
2013-12-26 19:29:21 -05:00
|
|
|
|
|
|
|
time.Sleep(2 * time.Second)
|
|
|
|
|
|
|
|
result2, err := tpl.Process(`{{timestamp}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result != result2 {
|
|
|
|
t.Fatalf("bad: %#v %#v", result, result2)
|
|
|
|
}
|
2013-08-15 22:11:27 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestConfigTemplateProcess_user(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tpl.UserVars["foo"] = "bar"
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{user "foo"}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result != "bar" {
|
|
|
|
t.Fatalf("bad: %s", result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-05 15:19:56 -04:00
|
|
|
func TestConfigTemplateProcess_uuid(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{uuid}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
2013-10-17 03:09:27 -04:00
|
|
|
if len(result) != 36 {
|
2013-09-05 15:19:56 -04:00
|
|
|
t.Fatalf("err: %s", result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-06 07:08:08 -04:00
|
|
|
func TestConfigTemplateProcess_upper(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tpl.UserVars["foo"] = "bar"
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{user "foo" | upper}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result != "BAR" {
|
|
|
|
t.Fatalf("bad: %s", result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestConfigTemplateProcess_lower(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
tpl.UserVars["foo"] = "BAR"
|
|
|
|
|
|
|
|
result, err := tpl.Process(`{{user "foo" | lower}}`, nil)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if result != "bar" {
|
|
|
|
t.Fatalf("bad: %s", result)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-15 22:11:27 -04:00
|
|
|
func TestConfigTemplateValidate(t *testing.T) {
|
|
|
|
tpl, err := NewConfigTemplate()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Valid
|
|
|
|
err = tpl.Validate(`{{user "foo"}}`)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Invalid
|
|
|
|
err = tpl.Validate(`{{idontexist}}`)
|
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
}
|