Skip to content
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

sql: fix some error codes and messages for udfs #108224

Merged
merged 1 commit into from
Aug 7, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions pkg/sql/logictest/testdata/logic_test/udf
Original file line number Diff line number Diff line change
Expand Up @@ -406,8 +406,7 @@ CREATE FUNCTION sc1.f_test_drop(IN INT8)
SELECT 1;
$$

# TODO(107369): Postgres errors with code 42725 here.
statement error pgcode XXUUU pq: function name \"f_test_drop\" is not unique
statement error pgcode 42725 pq: function name \"f_test_drop\" is not unique
DROP FUNCTION f_test_drop;

statement ok
Expand Down
5 changes: 2 additions & 3 deletions pkg/sql/logictest/testdata/logic_test/udf_insert
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,8 @@ SELECT f_void();
----
NULL

# TODO(107369): This doesn't error in postgres, and this is the error code for
# invalid foreign key, which may not make sense.
statement error pgcode 42830 missing "a" primary key column
# Note: This does not error in postgres until the function is executed.
statement error pgcode 23502 missing "a" primary key column
CREATE FUNCTION f_err(b INT) RETURNS RECORD AS
$$
INSERT INTO t (b) VALUES (b);
Expand Down
6 changes: 3 additions & 3 deletions pkg/sql/logictest/testdata/logic_test/udf_options
Original file line number Diff line number Diff line change
Expand Up @@ -109,13 +109,13 @@ l1 l2 i1 i2 s1 s2 v1 v2
statement ok
CREATE SEQUENCE sq2;

# TODO(107369): This does not error in postgres.
# Note: postgres allows non-volatile functions to call other volatile functions.
statement error pgcode 22023 volatile statement not allowed in immutable function: SELECT nextval\('sq2'\)
CREATE FUNCTION rand_i() RETURNS INT IMMUTABLE LANGUAGE SQL AS $$SELECT nextval('sq2')$$;

# TODO(107369): This does not error in postgres.
# Note: postgres allows non-volatile functions to call other volatile functions.
statement error pgcode 22023 volatile statement not allowed in stable function: SELECT nextval\('sq2'\)
CREATE FUNCTION rand_s() RETURNS INT STABLE LANGUAGE SQL AS $$SELECT nextval('sq2')$$;
CREATE FUNCTION rand_s() RETURNS INT STABLE LANGUAGE SQL AS $$SELECT nextval('sq2')$$;

statement ok
CREATE FUNCTION rand_v() RETURNS INT VOLATILE LANGUAGE SQL AS $$SELECT nextval('sq2')$$;
Expand Down
2 changes: 1 addition & 1 deletion pkg/sql/logictest/testdata/logic_test/udf_privileges
Original file line number Diff line number Diff line change
Expand Up @@ -533,7 +533,7 @@ CREATE FUNCTION f_test_show_grants(INT, string, OID) RETURNS INT LANGUAGE SQL AS
CREATE USER u_test_show_grants;
GRANT EXECUTE ON FUNCTION f_test_show_grants(INT), f_test_show_grants(INT, string, OID) TO u_test_show_grants;

statement error pgcode XXUUU pq: function name "f_test_show_grants" is not unique
statement error pgcode 42725 pq: function name "f_test_show_grants" is not unique
SHOW GRANTS ON FUNCTION f_test_show_grants;

query TTTTTTB colnames
Expand Down
11 changes: 6 additions & 5 deletions pkg/sql/logictest/testdata/logic_test/udf_record
Original file line number Diff line number Diff line change
Expand Up @@ -535,20 +535,21 @@ SELECT imp_cast(), (1,2,'3') = imp_cast(), pg_typeof(imp_cast())
----
(1,2,3) true imp

# TODO(107369): This is code 42846 in postgres.
# Note: postgres returns error code 42846 (cannot cast type) here instead due to
# implementation differences.
statement error pgcode 42P13 return type mismatch in function declared to return imp
CREATE FUNCTION err() RETURNS imp LANGUAGE SQL AS $$
SELECT (1, 2)
$$

# TODO(mgartner): The error message should say "imp" instead of "record".
statement error pgcode 42P13 return type mismatch in function declared to return record
statement error pgcode 42P13 return type mismatch in function declared to return imp
CREATE FUNCTION err() RETURNS imp LANGUAGE SQL AS $$
SELECT k, a FROM imp
$$

# TODO(mgartner): The error message should say "imp" instead of "record".
statement error pgcode 42P13 return type mismatch in function declared to return record
# Note: This function can be successfully created in postgres, but will fail
# when called.
statement error pgcode 42P13 return type mismatch in function declared to return imp
CREATE FUNCTION err() RETURNS imp LANGUAGE SQL AS $$
SELECT k, a, b::INT FROM imp
$$
Expand Down
2 changes: 1 addition & 1 deletion pkg/sql/logictest/testdata/logic_test/udf_schema_change
Original file line number Diff line number Diff line change
Expand Up @@ -633,7 +633,7 @@ ALTER TABLE t_alter ALTER b TYPE TEXT
statement ok
ALTER TABLE t_alter ADD COLUMN d INT;

statement error pgcode 42P13 pq: return type mismatch in function declared to return record
statement error pgcode 42P13 pq: return type mismatch in function declared to return t_alter
CREATE OR REPLACE FUNCTION f_rtbl() RETURNS t_alter LANGUAGE SQL AS $$
SELECT 1, 'foobar', 2
$$
Expand Down
1 change: 0 additions & 1 deletion pkg/sql/logictest/testdata/logic_test/udf_update
Original file line number Diff line number Diff line change
Expand Up @@ -167,7 +167,6 @@ CREATE TABLE generated_as_id_t (
statement ok
INSERT INTO generated_as_id_t (a) VALUES (7), (8), (9);

# TODO(107369): This error code does not have a name associated with it.
statement error pgcode 428C9 column "b" can only be updated to DEFAULT
CREATE FUNCTION f_err(i INT, j INT) RETURNS RECORD AS
$$
Expand Down
3 changes: 2 additions & 1 deletion pkg/sql/logictest/testdata/logic_test/udf_volatility_check
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,8 @@ statement ok
CREATE TABLE t1(a INT PRIMARY KEY, b INT);
CREATE TABLE t2(a INT PRIMARY KEY, b INT);

# TODO(107369): These do not appear to error in postgres.
# Note: postgres does not error in the following cases. CRDB provides stronger
# protections against adding volatility to non-volatile functions.
statement error pgcode 22023 pq: referencing relations is not allowed in immutable function
CREATE FUNCTION f() RETURNS FLOAT LANGUAGE SQL IMMUTABLE AS $$ SELECT a FROM t1 $$;

Expand Down
4 changes: 2 additions & 2 deletions pkg/sql/opt/optbuilder/create_function.go
Original file line number Diff line number Diff line change
Expand Up @@ -358,7 +358,7 @@ func validateReturnType(expected *types.T, cols []scopeColumn) error {
if !typ.Equivalent(cols[i].typ) {
return pgerror.WithCandidateCode(
errors.WithDetailf(
errors.Newf("return type mismatch in function declared to return record"),
errors.Newf("return type mismatch in function declared to return %s", expected.Name()),
"Final statement returns %s instead of %s at column %d",
cols[i].typ.Name(), typ.Name(), i+1,
),
Expand All @@ -372,7 +372,7 @@ func validateReturnType(expected *types.T, cols []scopeColumn) error {
// Ran out of columns from last statement.
return pgerror.WithCandidateCode(
errors.WithDetailf(
errors.New("return type mismatch in function declared to return record"),
errors.Newf("return type mismatch in function declared to return %s", expected.Name()),
"Final statement returns too few columns",
),
pgcode.InvalidFunctionDefinition,
Expand Down
2 changes: 1 addition & 1 deletion pkg/sql/opt/optbuilder/insert.go
Original file line number Diff line number Diff line change
Expand Up @@ -454,7 +454,7 @@ func (mb *mutationBuilder) checkPrimaryKeyForInsert() {
continue
}

panic(pgerror.Newf(pgcode.InvalidForeignKey,
panic(pgerror.Newf(pgcode.NotNullViolation,
"missing %q primary key column", col.ColName()))
}
}
Expand Down
2 changes: 1 addition & 1 deletion pkg/sql/sem/tree/function_definition.go
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ func (fd *ResolvedFunctionDefinition) MatchOverload(
)
}
if len(ret) > 1 {
return QualifiedOverload{}, errors.Errorf("function name %q is not unique", fd.Name)
return QualifiedOverload{}, pgerror.Newf(pgcode.AmbiguousFunction, "function name %q is not unique", fd.Name)
}
return ret[0], nil
}
Expand Down