From 71f78e0eda7d42fe8b74b68e4ac8fe24c8f405a8 Mon Sep 17 00:00:00 2001 From: Haytham Abuelfutuh Date: Thu, 17 Jun 2021 07:49:38 -0700 Subject: [PATCH] MakeLiteralForType shouldn't print for nil values (#188) * Add max concurrency to launch plan & execution spec (#186) Signed-off-by: Haytham Abuelfutuh * MakeLiteralForType shouldn't print for nil values Signed-off-by: Haytham Abuelfutuh * bump Signed-off-by: Haytham Abuelfutuh Co-authored-by: Katrina Rogan --- flyteidl/clients/go/coreutils/literals.go | 4 ++++ flyteidl/clients/go/coreutils/literals_test.go | 10 ++++++++++ 2 files changed, 14 insertions(+) diff --git a/flyteidl/clients/go/coreutils/literals.go b/flyteidl/clients/go/coreutils/literals.go index c05061854d..2a6b10bb0a 100644 --- a/flyteidl/clients/go/coreutils/literals.go +++ b/flyteidl/clients/go/coreutils/literals.go @@ -489,6 +489,10 @@ func MakeLiteralForType(t *core.LiteralType, v interface{}) (*core.Literal, erro case *core.LiteralType_Simple: newT := t.Type.(*core.LiteralType_Simple) strValue := fmt.Sprintf("%v", v) + if v == nil { + strValue = "" + } + if newT.Simple == core.SimpleType_STRUCT { if _, isValueStringType := v.(string); !isValueStringType { byteValue, err := json.Marshal(v) diff --git a/flyteidl/clients/go/coreutils/literals_test.go b/flyteidl/clients/go/coreutils/literals_test.go index e1a557a863..38e03f1de2 100644 --- a/flyteidl/clients/go/coreutils/literals_test.go +++ b/flyteidl/clients/go/coreutils/literals_test.go @@ -617,4 +617,14 @@ func TestMakeLiteralForType(t *testing.T) { _, err := MakeLiteralForType(literalType, "m") assert.Error(t, err) }) + + t.Run("Nil string", func(t *testing.T) { + var literalType = &core.LiteralType{Type: &core.LiteralType_Simple{Simple: core.SimpleType_STRING}} + l, err := MakeLiteralForType(literalType, nil) + assert.NoError(t, err) + assert.Equal(t, "", l.GetScalar().GetPrimitive().GetStringValue()) + l, err = MakeLiteralForType(literalType, "") + assert.NoError(t, err) + assert.Equal(t, "", l.GetScalar().GetPrimitive().GetStringValue()) + }) }