Commit fab369bf authored by Armon Dadgar's avatar Armon Dadgar

Adding support for isotime template variable

parent 1df07357
...@@ -26,6 +26,7 @@ func NewConfigTemplate() (*ConfigTemplate, error) { ...@@ -26,6 +26,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,
}) })
...@@ -79,3 +80,7 @@ func (t *ConfigTemplate) templateUser(n string) (string, error) { ...@@ -79,3 +80,7 @@ func (t *ConfigTemplate) templateUser(n string) (string, error) {
func templateTimestamp() string { func templateTimestamp() string {
return strconv.FormatInt(time.Now().UTC().Unix(), 10) return strconv.FormatInt(time.Now().UTC().Unix(), 10)
} }
func templateISOTime() string {
return time.Now().UTC().Format(time.RFC3339)
}
...@@ -7,6 +7,28 @@ import ( ...@@ -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 {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment