Files
dolt/bats/sql-batch.bats
2021-03-05 13:51:52 -08:00

152 lines
3.7 KiB
Bash

#!/usr/bin/env bats
load $BATS_TEST_DIRNAME/helper/common.bash
setup() {
setup_common
dolt sql <<SQL
CREATE TABLE test (
pk bigint NOT NULL,
c1 bigint,
c2 bigint,
c3 bigint,
c4 bigint,
c5 bigint,
PRIMARY KEY (pk)
);
SQL
}
teardown() {
assert_feature_version
teardown_common
}
@test "sql-batch: dolt sql -b and -batch are a valid commands" {
run dolt sql -b -q "insert into test values (0,0,0,0,0,0)"
[ "$status" -eq 0 ]
[[ "$output" =~ "Rows inserted: 1" ]] || false
dolt sql -batch -q "insert into test values (1,0,0,0,0,0)"
run dolt sql -b -q "select * from test"
[ "$status" -eq 0 ]
[[ "$output" =~ " 0 " ]] || false
[[ "$output" =~ " 1 " ]] || false
# check for trailing newline
# https://backreference.org/2010/05/23/sanitizing-files-with-no-trailing-newline/
dolt sql -batch -q "insert into test values (2,0,0,0,0,0)" > out.txt
lastline=$(tail -n 1 out.txt; echo x)
lastline=${lastline%x}
[[ $lastline =~ $'\n'$ ]] || false
}
@test "sql-batch: Piped SQL files interpreted in batch mode" {
run dolt sql <<SQL
insert into test values (0,0,0,0,0,0);
insert into test values (1,0,0,0,0,0);
SQL
[ "$status" -eq 0 ]
[[ "$output" =~ "Rows inserted: 2" ]] || false
}
@test "sql-batch: Line number and bad query displayed on error in batch sql" {
run dolt sql <<SQL
insert into test values (0,0,0,0,0,0);
insert into test values (1,0,0,0,0,0);
insert into test values poop;
SQL
[ "$status" -ne 0 ]
[[ "$output" =~ "Error processing batch" ]] || false
[[ "$output" =~ "error on line 3 for query" ]] || false
[[ "$output" =~ "insert into test values poop" ]] || false
run dolt sql <<SQL
insert into test values (0,0,0,0,0,0);
insert into test values (1,0,
0,0,0,0);
insert into
test values (2,0,0,0,0,0)
;
insert into
test values
poop;
insert into test values (3,0,0,0,0,0);
SQL
[ "$status" -ne 0 ]
[[ "$output" =~ "Error processing batch" ]] || false
[[ "$output" =~ "error on line 10 for query" ]] || false
[[ "$output" =~ "poop" ]] || false
}
@test "sql-batch: sql reset('hard') function" {
mkdir test && cd test && dolt init
dolt sql <<SQL
CREATE TABLE test (
pk int PRIMARY KEY,
c0 int
);
SQL
dolt add -A && dolt commit -m "added table test"
run dolt status
[ "$status" -eq 0 ]
[[ "$output" =~ "working tree clean" ]] || false
dolt sql <<SQL
INSERT INTO test VALUES (1,1);
SQL
run dolt status
[ "$status" -eq 0 ]
[[ "$output" =~ "test" ]] || false
dolt sql <<SQL
SET @@test_head=reset('hard');
REPLACE INTO dolt_branches (hash,name) VALUES (@@test_head,'master');
SQL
run dolt status
[ "$status" -eq 0 ]
[[ "$output" =~ "working tree clean" ]] || false
dolt sql <<SQL
INSERT INTO test VALUES (1,1);
SET @@test_head = reset('hard');
REPLACE INTO dolt_branches (hash,name) VALUES (@@test_head,'master');
SQL
run dolt status
[ "$status" -eq 0 ]
[[ "$output" =~ "working tree clean" ]] || false
}
@test "sql-batch: batch mode detects subqueries and decides not to do batch insert." {
# create the second table.
dolt sql << SQL
CREATE TABLE test2 (
pk bigint NOT NULL,
c1 bigint NOT NULL,
PRIMARY KEY (pk)
);
SQL
run dolt status
[ "$status" -eq 0 ]
# Create the table and base subquery on recently inserted row.
run dolt sql << SQL
INSERT INTO TEST VALUES (1,1,1,1,1,1);
INSERT INTO TEST2 VALUES (2,2);
INSERT INTO TEST2 VALUES (1, (SELECT c1 FROM TEST WHERE c1=1));
SQL
[ "$status" -eq 0 ]
[[ "$output" =~ "Rows inserted: 3" ]] || false
run dolt sql -r csv -q "select * from test2 ORDER BY pk"
[[ "$output" =~ "pk,c1" ]] || false
[[ "$output" =~ "1,1" ]] || false
[[ "$output" =~ "2,2" ]] || false
}