Skip to content

Commit

Permalink
feat(sdk): ternary, urlencode, dirname, basename interpolate helper
Browse files Browse the repository at this point in the history
  • Loading branch information
louisquentinjoucla committed Jan 12, 2022
1 parent 0cbd785 commit b900865
Show file tree
Hide file tree
Showing 3 changed files with 126 additions and 3 deletions.
9 changes: 6 additions & 3 deletions sdk/interpolate/interpolate.go
Original file line number Diff line number Diff line change
Expand Up @@ -125,9 +125,12 @@ func Do(input string, vars map[string]string) (string, error) {
}
}

var defaultIsUsed bool
var isHandlingUnknownVars bool
if _, ok := usedHelpers["default"]; ok {
defaultIsUsed = true
isHandlingUnknownVars = true
}
if _, ok := usedHelpers["ternary"]; ok {
isHandlingUnknownVars = true
}

unknownVariables := make([]string, 0, 1000)
Expand All @@ -146,7 +149,7 @@ func Do(input string, vars map[string]string) (string, error) {
delete(usedHelpers, h)
}

if !defaultIsUsed && (len(unknownVariables) > 0 || len(unknownHelpers) > 0) {
if !isHandlingUnknownVars && (len(unknownVariables) > 0 || len(unknownHelpers) > 0) {
for _, s := range quotedStuff {
q := strings.Replace(sm[i][1], `"`+s+`"`, `\"`+s+`\"`, -1)
input = strings.Replace(input, sm[i][1], q, 1)
Expand Down
13 changes: 13 additions & 0 deletions sdk/interpolate/interpolate_helper.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ import (
"encoding/base64"
"encoding/json"
"fmt"
"net/url"
"path"
"reflect"
"strings"
"text/template"
Expand Down Expand Up @@ -71,6 +73,10 @@ func init() {
}
return a
},
"ternary": ternary,
"urlencode": func(s string) string { return url.QueryEscape(s) },
"dirname": func(s string) string { return path.Dir(s) },
"basename": func(s string) string { return path.Base(s) },
})
}

Expand Down Expand Up @@ -369,6 +375,13 @@ func escape(s string) string {
return s1
}

func ternary(v, v2, a interface{}) interface{} {
if cast.ToBool(a) {
return v
}
return v2
}

// toInt64 converts integer types to 64-bit integers
func toInt64(v interface{}) int64 {
return cast.ToInt64(v)
Expand Down
107 changes: 107 additions & 0 deletions sdk/interpolate/interpolate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -446,6 +446,113 @@ func TestDo(t *testing.T) {
want: "my value 4 4",
enable: true,
},
{
name: "dirname",
args: args{
input: "{{.path | dirname}}",
vars: map[string]string{
"path": "/a/b/c",
},
},
want: "/a/b",
enable: true,
},
{
name: "basename",
args: args{
input: "{{.path | basename}}",
vars: map[string]string{
"path": "/ab/c",
},
},
want: "c",
enable: true,
},
{
name: "urlencode word",
args: args{
input: "{{.query | urlencode}}",
vars: map[string]string{
"query": "Trollhättan",
},
},
want: "Trollh%C3%A4ttan",
enable: true,
},
{
name: "urlencode query",
args: args{
input: "{{.query | urlencode}}",
vars: map[string]string{
"query": "zone:eq=Somewhere over the rainbow&name:like=%mydomain.ovh.net",
},
},
want: "zone%3Aeq%3DSomewhere+over+the+rainbow%26name%3Alike%3D%25mydomain.ovh.net",
enable: true,
},
{
name: "urlencode nothing to do",
args: args{
input: "{{.query | urlencode}}",
vars: map[string]string{
"query": "patrick",
},
},
want: "patrick",
enable: true,
},
{
name: "ternary truthy",
args: args{
input: "{{.assert | ternary .foo .bar}}",
vars: map[string]string{
"assert": "true",
"bar": "bar",
"foo": "foo",
},
},
want: "foo",
enable: true,
},
{
name: "ternary truthy integer",
args: args{
input: "{{ \"1\" | ternary .foo .bar}}",
vars: map[string]string{
"assert": "false",
"bar": "bar",
"foo": "foo",
},
},
want: "foo",
enable: true,
},
{
name: "ternary falsy",
args: args{
input: "{{.assert | ternary .foo .bar}}",
vars: map[string]string{
"assert": "false",
"bar": "bar",
"foo": "foo",
},
},
want: "bar",
enable: true,
},
{
name: "ternary undef assert",
args: args{
input: "{{.assert | ternary .foo .bar}}",
vars: map[string]string{
"assert": "false",
"bar": "bar",
"foo": "foo",
},
},
want: "bar",
enable: true,
},
}
for _, tt := range tests {
if !tt.enable {
Expand Down

0 comments on commit b900865

Please sign in to comment.