Skip to content

Commit

Permalink
Merge branch 'main' into yiming/create-sub-via-add-mutation
Browse files Browse the repository at this point in the history
  • Loading branch information
wenym1 authored Aug 2, 2024
2 parents 40cbe95 + 03e4bc3 commit 53aeb7d
Show file tree
Hide file tree
Showing 64 changed files with 1,311 additions and 945 deletions.
1 change: 1 addition & 0 deletions .github/labeler.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
version: 1
appendOnly: true

# Match title
labels:
Expand Down
52 changes: 1 addition & 51 deletions Cargo.lock

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

1 change: 1 addition & 0 deletions ci/scripts/run-e2e-test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ if [[ $mode == "standalone" ]]; then
fi

if [[ $mode == "single-node" ]]; then
export RUST_MIN_STACK=4194304
source ci/scripts/single-node-utils.sh
fi

Expand Down
1 change: 1 addition & 0 deletions ci/scripts/single-node-utils.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ set -euo pipefail
export RW_PREFIX=$PWD/.risingwave
export PREFIX_BIN=./target/debug
export PREFIX_LOG=$RW_PREFIX/log
export PREFIX_CONFIG=$RW_PREFIX/config
export RISEDEV=1 # as if we are running in RiseDev

# You can fill up this section by consulting
Expand Down
201 changes: 201 additions & 0 deletions e2e_test/sink/sink_into_table/alter_column.slt
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
statement ok
SET RW_IMPLICIT_FLUSH TO true;

statement ok
create table t_simple_1 (v1 int);

statement ok
create table m_simple (v1 int primary key);

statement ok
create sink s_simple_1 into m_simple as select v1 from t_simple_1;

statement ok
insert into t_simple_1 values (1), (2), (3);

statement ok
flush;

query I rowsort
select * from m_simple;
----
1
2
3

statement ok
alter table m_simple add column v2 int;

statement ok
insert into t_simple_1 values (4);

statement ok
flush;

query II rowsort
select * from m_simple;
----
1 NULL
2 NULL
3 NULL
4 NULL

statement ok
create table t_simple_2 (v1 int, v2 int);

statement ok
create sink s_simple_2 into m_simple as select v1, v2 from t_simple_2;

statement ok
insert into t_simple_2 values (100, 101), (200, 201), (300, 301);

statement ok
flush;

query II rowsort
select * from m_simple;
----
1 NULL
100 101
2 NULL
200 201
3 NULL
300 301
4 NULL

statement error dropping columns in target table of sinks is not supported
alter table m_simple drop column v2;

statement ok
drop sink s_simple_1;

statement ok
drop sink s_simple_2;

statement ok
drop table t_simple_1;

statement ok
drop table t_simple_2;

statement ok
drop table m_simple;

# target table with row_id as primary key
statement ok
create table t_s1 (v1 int);

statement ok
insert into t_s1 values (1), (2), (3);

statement ok
create table t_row_id_as_primary_key (v1 int, v2 int default 1000);

statement ok
create sink s1 into t_row_id_as_primary_key as select v1 from t_s1 with (type = 'append-only', force_append_only = 'true');

statement ok
flush;

query II rowsort
select * from t_row_id_as_primary_key;
----
1 1000
2 1000
3 1000

statement ok
alter table t_row_id_as_primary_key add column v3 int;

query III rowsort
select * from t_row_id_as_primary_key;
----
1 1000 NULL
2 1000 NULL
3 1000 NULL

statement ok
create sink s11 into t_row_id_as_primary_key as select v1+1000 as v1, v1+2000 as v2, v1+3000 as v3 from t_s1 with (type = 'append-only', force_append_only = 'true');

statement ok
flush;

query III rowsort
select * from t_row_id_as_primary_key;
----
1 1000 NULL
1001 2001 3001
1002 2002 3002
1003 2003 3003
2 1000 NULL
3 1000 NULL

statement ok
drop sink s1;

statement ok
drop sink s11;

statement ok
drop table t_row_id_as_primary_key;

statement ok
drop table t_s1;

# target table with append only
statement ok
create table t_s2 (v1 int);

statement ok
insert into t_s2 values (1), (2), (3);

statement ok
create table t_append_only (v1 int, v2 int default 1000) append only;

statement ok
create sink s2 into t_append_only as select v1 from t_s2 with (type = 'append-only', force_append_only = 'true');

statement ok
flush;

query II rowsort
select * from t_append_only;
----
1 1000
2 1000
3 1000

statement ok
alter table t_append_only add column v3 int;

query III rowsort
select * from t_append_only;
----
1 1000 NULL
2 1000 NULL
3 1000 NULL

statement ok
create sink s21 into t_append_only as select v1+1000 as v1, v1+2000 as v2, v1+3000 as v3 from t_s2 with (type = 'append-only', force_append_only = 'true');

query III rowsort
select * from t_append_only;
----
1 1000 NULL
1001 2001 3001
1002 2002 3002
1003 2003 3003
2 1000 NULL
3 1000 NULL

statement ok
drop sink s21;

statement ok
drop sink s2;

statement ok
drop table t_append_only;

statement ok
drop table t_s2;
4 changes: 0 additions & 4 deletions e2e_test/sink/sink_into_table/basic.slt
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,6 @@ create table m_simple (v1 int primary key, v2 int);
statement ok
create sink s_simple_1 into m_simple as select v1, v2 from t_simple;

# we can't alter a table with incoming sinks
statement error Feature is not yet implemented: alter table with incoming sinks
alter table m_simple add column v3 int;

statement ok
drop sink s_simple_1;

Expand Down
3 changes: 3 additions & 0 deletions proto/catalog.proto
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,9 @@ message Sink {
// Handle the sink relies on any sceret. The key is the propertity name and the value is the secret id and type.
// Used for connect options.
map<string, secret.SecretRef> secret_refs = 25;

// only for the sink whose target is a table. Columns of the target table when the sink is created. At this point all the default columns of the target table are all handled by the project operator in the sink plan.
repeated plan_common.ColumnCatalog original_target_columns = 26;
}

message Subscription {
Expand Down
2 changes: 1 addition & 1 deletion proto/stream_plan.proto
Original file line number Diff line number Diff line change
Expand Up @@ -478,7 +478,7 @@ message DynamicFilterNode {
// When the condition changes, we will tell downstream to insert the LHS records which now match the condition.
// If this is false, we need to store RHS records which match the condition in the internal table.
// When the condition changes, we will tell downstream to delete the LHS records which now no longer match the condition.
bool condition_always_relax = 5;
bool condition_always_relax = 5 [deprecated = true];
}

// Delta join with two indexes. This is a pseudo plan node generated on frontend. On meta
Expand Down
6 changes: 5 additions & 1 deletion src/bench/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,11 @@ itertools = { workspace = true }
libc = "0.2"
opentelemetry = { workspace = true, optional = true }
parking_lot = { workspace = true }
plotlib = "0.5.1"
plotters = { version = "0.3.5", default-features = false, features = [
"svg_backend",
"line_series",
"point_series"
] }
prometheus = { version = "0.13", features = ["process"] }
rand = { workspace = true }
risingwave_common = { workspace = true }
Expand Down
Loading

0 comments on commit 53aeb7d

Please sign in to comment.