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

feat(error): report the error's source chain through psql #13264

Merged
merged 15 commits into from
Nov 9, 2023
Merged
9 changes: 5 additions & 4 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ arrow-buffer = "48"
arrow-flight = "48"
arrow-select = "48"
arrow-ord = "48"
thiserror-ext = "0.0.1"
thiserror-ext = "0.0.5"
tikv-jemalloc-ctl = { git = "https://github.com/risingwavelabs/jemallocator.git", rev = "64a2d9" }
tikv-jemallocator = { git = "https://github.com/risingwavelabs/jemallocator.git", features = [
"profiling",
Expand Down
2 changes: 1 addition & 1 deletion Makefile.toml
Original file line number Diff line number Diff line change
Expand Up @@ -1333,7 +1333,7 @@ echo "All processes has exited."

[tasks.slt]
category = "RiseDev - SQLLogicTest"
install_crate = { version = "0.17.2", crate_name = "sqllogictest-bin", binary = "sqllogictest", test_arg = [
install_crate = { version = "0.18.0", crate_name = "sqllogictest-bin", binary = "sqllogictest", test_arg = [
"--help",
], install_command = "binstall" }
dependencies = ["check-risedev-env-file"]
Expand Down
8 changes: 8 additions & 0 deletions ci/scripts/run-e2e-test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,14 @@ sqllogictest -p 4566 -d dev './e2e_test/generated/**/*.slt' --junit "generated-$
echo "--- Kill cluster"
cluster_stop

echo "--- e2e, $mode, error ui"
RUST_LOG="info,risingwave_stream=info,risingwave_batch=info,risingwave_storage=info" \
cluster_start
sqllogictest -p 4566 -d dev './e2e_test/error_ui/**/*.slt'

echo "--- Kill cluster"
cluster_stop

echo "--- e2e, $mode, extended query"
RUST_LOG="info,risingwave_stream=info,risingwave_batch=info,risingwave_storage=info" \
cluster_start
Expand Down
4 changes: 2 additions & 2 deletions e2e_test/batch/aggregate/sum.slt.part
Original file line number Diff line number Diff line change
Expand Up @@ -77,8 +77,8 @@ select sum(d) from t;
statement ok
insert into t values (9000000000000000000000000000);

statement error Expr error: Numeric out of range
statement error Numeric out of range
select sum(d) from t;

statement ok
drop table t;
drop table t;
2 changes: 1 addition & 1 deletion e2e_test/batch/basic/dml.slt.part
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ select * from t order by v1;
1 1 aa
3 2 bb

statement error QueryError: Bind error: update modifying the PK column is unsupported
statement error update modifying the PK column is unsupported
update t set (v3, v2) = (v3||v3, v1+v2);

statement ok
Expand Down
12 changes: 6 additions & 6 deletions e2e_test/batch/functions/pow.slt.part
Original file line number Diff line number Diff line change
Expand Up @@ -46,11 +46,11 @@ select pow(100000, 0);
statement error underflow
select pow(100000, -200000000000000);

statement error QueryError: Expr error: Numeric out of range
statement error Numeric out of range
select pow(100000, 200000000000000);


statement error QueryError: Expr error: Numeric out of range
statement error Numeric out of range
select pow(-100000, 200000000000001);

query R
Expand Down Expand Up @@ -101,11 +101,11 @@ select 100000 ^ 0;
statement error underflow
select 100000 ^ -200000000000000;

statement error QueryError: Expr error: Numeric out of range
statement error Numeric out of range
select 100000 ^ 200000000000000;


statement error QueryError: Expr error: Numeric out of range
statement error Numeric out of range
select -100000 ^ 200000000000001;

query RRRR
Expand Down Expand Up @@ -231,10 +231,10 @@ select exp(2::smallint)
----
7.38905609893065

statement error QueryError: Expr error: Numeric out of range: overflow
statement error Numeric out of range: overflow
select exp(10000000);

statement error QueryError: Expr error: Numeric out of range: underflow
statement error Numeric out of range: underflow
select exp(-10000000);

query TRR
Expand Down
2 changes: 1 addition & 1 deletion e2e_test/ddl/invalid_operation.slt
Original file line number Diff line number Diff line change
Expand Up @@ -264,7 +264,7 @@ SELECT * from v limit 0;
statement ok
insert into t values (1);

statement error QueryError: Bind error: update modifying the PK column is unsupported
statement error update modifying the PK column is unsupported
update t set v = 2;

statement ok
Expand Down
8 changes: 4 additions & 4 deletions e2e_test/ddl/table/generated_columns.slt.part
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ select * from t1;
0 1 2 2.02
1 2 3 3.02

statement error QueryError: Bind error: update modifying the generated column is unsupported
statement error update modifying the generated column is unsupported
update t1 set v1 = 1;

statement ok
Expand Down Expand Up @@ -140,7 +140,7 @@ statement ok
drop source t4;

# create a table with generated column now
statement error QueryError: Bind error: failed to bind expression: now()
statement error failed to bind expression: now()
CREATE TABLE t (v INT, t timestamptz as now()) WITH (
connector = 'datagen',
fields.v.kind = 'sequence',
Expand All @@ -151,9 +151,9 @@ CREATE TABLE t (v INT, t timestamptz as now()) WITH (
) FORMAT PLAIN ENCODE JSON;

# create a table with impure generated column as pk.
statement error QueryError: Bind error: Generated columns with impure expressions should not be part of the primary key. Here column "v2" is defined as part of the primary key.
statement error Generated columns with impure expressions should not be part of the primary key. Here column "v2" is defined as part of the primary key.
CREATE TABLE t (
v1 INT,
v2 timestamptz AS proctime(),
PRIMARY KEY (v1, v2)
);
);
12 changes: 12 additions & 0 deletions e2e_test/error_ui/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# User Interface Test for Error Reporting

The test cases in this directory act as snapshot tests for the error reporting, to ensure that the UI does not change unexpectedly.

When you find the tests in this directory failing...

- First, ensure that the changes to the error messages are expected and make them look better.
- Then, update the test cases by running:
```bash
./risedev slt './e2e_test/error_ui/**/*.slt' --override
```
Please note that the minimum required version of `sqllogictest` is 0.18 or higher.
41 changes: 41 additions & 0 deletions e2e_test/error_ui/main.slt
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

😄🤣

Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
statement error
create function int_42() returns int as int_42 using link 'localhost:8815';
----
db error: ERROR: QueryError

Caused by these errors (recent errors listed first):
1: failed to connect to UDF service
2: transport error
3: error trying to connect
4: invalid URL, scheme is missing


statement error
alter system set not_exist_key to value;
----
db error: ERROR: QueryError

Caused by this error:
1: internal error: SystemParams error: unrecognized system param "not_exist_key"


query error
select v1 + v2 = v3;
----
db error: ERROR: QueryError

Caused by this error:
1: Bind error: failed to bind expression: v1 + v2 = v3

Caused by:
Item not found: Invalid column: v1


query error
select 1/0;
----
db error: ERROR: QueryError

Caused by these errors (recent errors listed first):
1: Expr error
2: Division by zero
2 changes: 1 addition & 1 deletion e2e_test/sink/append_only_sink.slt
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ create sink invalid_sink_type from t with (connector = 'blackhole', type = 'inva
statement error `force_append_only` must be true or false
create sink invalid_force_append_only from t with (connector = 'blackhole', force_append_only = 'invalid');

statement error db error: ERROR: QueryError: Sink error: config error: unsupported sink type invalid
statement error unsupported sink type invalid
create sink invalid_connector from t with (connector = 'invalid');

statement ok
Expand Down
2 changes: 1 addition & 1 deletion e2e_test/sink/kafka/avro.slt
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ create sink sink_err from into_kafka with (
format upsert encode avro (
schema.registry = 'http://message_queue:8081');

statement error encode extra_column error: field not in avro
statement error field not in avro
create sink sink_err as select 1 as extra_column, * from into_kafka with (
connector = 'kafka',
topic = 'test-rw-sink-upsert-avro',
Expand Down
2 changes: 1 addition & 1 deletion e2e_test/sink/kafka/protobuf.slt
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ format plain encode protobuf (
schema.location = 'file:///risingwave/proto-recursiv',
message = 'recursive.AllTypes');

statement error encode extra_column error: field not in proto
statement error field not in proto
create sink sink_err as select 1 as extra_column with (
connector = 'kafka',
topic = 'test-rw-sink-append-only-protobuf',
Expand Down
4 changes: 2 additions & 2 deletions e2e_test/source/basic/datagen.slt
Original file line number Diff line number Diff line change
Expand Up @@ -182,9 +182,9 @@ statement ok
drop table s1;

# Do NOT allow With clause to contain a comma only.
statement error QueryError: sql parser error: Expected identifier.*
statement error Expected identifier.*
create table s1 (v1 int) with (,) FORMAT PLAIN ENCODE JSON;

# Do NOT allow an empty With clause.
statement error QueryError: sql parser error: Expected identifier.*
statement error Expected identifier.*
create table s1 (v1 int) with () FORMAT PLAIN ENCODE JSON;
4 changes: 2 additions & 2 deletions e2e_test/source/basic/ddl.slt
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ create source invalid_startup_mode (
) FORMAT PLAIN ENCODE JSON;

# TODO: Better to refine the error message.
statement error internal error: invalid digit found in string
statement error invalid digit found in string
create source invalid_startup_timestamp (
column1 varchar
) with (
Expand All @@ -28,7 +28,7 @@ create source invalid_startup_timestamp (
properties.bootstrap.server = 'message_queue:29092'
) FORMAT PLAIN ENCODE JSON;

statement error db error: ERROR: QueryError: Protocol error: Schema definition is required, either from SQL or schema registry.
statement error Schema definition is required, either from SQL or schema registry.
create source invalid_schema_definition
with (
connector = 'kafka',
Expand Down
4 changes: 2 additions & 2 deletions e2e_test/source/basic/old_row_format_syntax/datagen.slt
Original file line number Diff line number Diff line change
Expand Up @@ -182,9 +182,9 @@ statement ok
drop table s1;

# Do NOT allow With clause to contain a comma only.
statement error QueryError: sql parser error: Expected identifier.*
statement error Expected identifier.*
create table s1 (v1 int) with (,) ROW FORMAT JSON;

# Do NOT allow an empty With clause.
statement error QueryError: sql parser error: Expected identifier.*
statement error Expected identifier.*
create table s1 (v1 int) with () ROW FORMAT JSON;
4 changes: 2 additions & 2 deletions e2e_test/source/basic/old_row_format_syntax/ddl.slt
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ create source invalid_startup_mode (
) ROW FORMAT JSON;

# TODO: Better to refine the error message.
statement error internal error: invalid digit found in string
statement error invalid digit found in string
create source invalid_startup_timestamp (
column1 varchar
) with (
Expand All @@ -28,7 +28,7 @@ create source invalid_startup_timestamp (
properties.bootstrap.server = 'message_queue:29092'
) ROW FORMAT JSON;

statement error db error: ERROR: QueryError: Protocol error: Schema definition is required, either from SQL or schema registry.
statement error Schema definition is required, either from SQL or schema registry.
create source invalid_schema_definition
with (
connector = 'kafka',
Expand Down
2 changes: 1 addition & 1 deletion e2e_test/streaming/watermark.slt
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ statement ok
drop table t;

# create a watermark with different return type from column
statement error QueryError: Bind error: The return value type of the watermark expression must be identical to the watermark column data type. Current data type of watermark return value: `timestamp with time zone`, column `integer`
statement error The return value type of the watermark expression must be identical to the watermark column data type. Current data type of watermark return value: `timestamp with time zone`, column `integer`
CREATE TABLE t (
v INT,
WATERMARK FOR v AS to_timestamp(v) - INTERVAL '5' SECOND
Expand Down
1 change: 1 addition & 0 deletions src/utils/pgwire/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ panic-message = "0.3"
risingwave_common = { workspace = true }
risingwave_sqlparser = { workspace = true }
thiserror = "1"
thiserror-ext = { workspace = true }
tokio = { version = "0.2", package = "madsim-tokio", features = ["rt", "macros"] }
tokio-openssl = "0.6.3"
tracing = "0.1"
Expand Down
5 changes: 3 additions & 2 deletions src/utils/pgwire/src/error.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,9 @@ pub enum PsqlError {
#[error(transparent)]
Internal(BoxedError),

#[error("Panicked when processing: {0}.\n
This is a bug. We would appreciate a bug report at https://github.com/risingwavelabs/risingwave/issues/new?labels=type%2Fbug&template=bug_report.yml.")]
#[error("Panicked when processing: {0}
Copy link
Member Author

@BugenZhao BugenZhao Nov 7, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I just realized that mutli-line string already contains a \n at the line break. 🤡

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a bug. We would appreciate a bug report at:
https://github.com/risingwavelabs/risingwave/issues/new?labels=type%2Fbug&template=bug_report.yml")]
Panic(String),

#[error("Unable to set up an ssl connection")]
Expand Down
4 changes: 3 additions & 1 deletion src/utils/pgwire/src/pg_message.rs
Original file line number Diff line number Diff line change
Expand Up @@ -628,12 +628,14 @@ impl<'a> BeMessage<'a> {
}

BeMessage::ErrorResponse(error) => {
use thiserror_ext::AsReport;
// For all the errors set Severity to Error and error code to
// 'internal error'.

// 'E' signalizes ErrorResponse messages
buf.put_u8(b'E');
let msg = error.to_string();
// Format the error as a pretty report.
let msg = format!("{:#}", error.as_ref().as_report());
write_err_or_notice(buf, &ErrorOrNoticeMessage::internal_error(&msg))?;
}

Expand Down
Loading