-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
evalengine bugfix: handle nil evals correctly when coercing values #14906
Conversation
Review ChecklistHello reviewers! 👋 Please follow this checklist when reviewing this Pull Request. General
Tests
Documentation
New flags
If a workflow is added or modified:
Backward compatibility
|
Signed-off-by: Andres Taylor <andres@planetscale.com>
Signed-off-by: Andres Taylor <andres@planetscale.com>
@@ -129,7 +129,7 @@ func evalToSQLValueWithType(e eval, resultType sqltypes.Type) sqltypes.Value { | |||
case *evalDecimal: | |||
return sqltypes.MakeTrusted(resultType, e.dec.FormatMySQL(e.length)) | |||
} | |||
default: | |||
case e != nil: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice! Can you also add a unit test here?
vitess/go/vt/vtgate/evalengine/api_arithmetic_test.go
Lines 738 to 749 in ab76091
}, { | |
// For float, we should not use scientific notation. | |
typ: sqltypes.Decimal, | |
v: newEvalFloat(1.2e-16), | |
out: TestValue(sqltypes.Decimal, "0.00000000000000012"), | |
}} | |
for _, tcase := range tcases { | |
got := evalToSQLValueWithType(tcase.v, tcase.typ) | |
if !reflect.DeepEqual(got, tcase.out) { | |
t.Errorf("toSQLValue(%v, %v): %v, want %v", tcase.v, tcase.typ, printValue(got), printValue(tcase.out)) | |
} | |
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good to go once the unit test is added.
Signed-off-by: Andres Taylor <andres@planetscale.com>
Signed-off-by: Andres Taylor <andres@planetscale.com>
…itessio#14906) Signed-off-by: Andres Taylor <andres@planetscale.com>
…14906) Signed-off-by: Andres Taylor <andres@planetscale.com>
Description
When coercing values to a common type in UNION, we hit a
panic
forBLOB
values.Related Issue(s)
Fixes #14907
Checklist