Skip to content

Commit

Permalink
Support non-any type as any input in workflow
Browse files Browse the repository at this point in the history
Signed-off-by: Future-Outlier <[email protected]>
  • Loading branch information
Future-Outlier committed May 24, 2024
1 parent 0583f77 commit 6f85700
Showing 1 changed file with 19 additions and 1 deletion.
20 changes: 19 additions & 1 deletion flytepropeller/pkg/compiler/validators/typing.go
Original file line number Diff line number Diff line change
Expand Up @@ -356,9 +356,27 @@ func getTypeChecker(t *flyte.LiteralType) typeChecker {
}
}

func AreTypesCastable(upstreamType, downstreamType *flyte.LiteralType) bool {
func isTypeAny(t *flyte.LiteralType) bool {
if t.GetMetadata() != nil {
if t.GetMetadata().GetFields() != nil {
pythonClassName := t.GetMetadata().GetFields()["python_class_name"]
if pythonClassName != nil {
if strVal, ok := pythonClassName.GetKind().(*structpb.Value_StringValue); ok && strVal.StringValue == "typing.Any" {
return true
}
}
}
}
return false
}

func AreTypesCastable(upstreamType *flyte.LiteralType, downstreamType *flyte.LiteralType) bool {
typeChecker := getTypeChecker(downstreamType)

if isTypeAny(upstreamType) || isTypeAny(downstreamType) {
return true
}

// if upstream is a singular union we check if the downstream type is castable from the union variant
if upstreamType.GetUnionType() != nil && len(upstreamType.GetUnionType().GetVariants()) == 1 {
variants := upstreamType.GetUnionType().GetVariants()
Expand Down

0 comments on commit 6f85700

Please sign in to comment.