Files
dolt/integration-tests/bats/sql-checkout.bats
2025-11-21 10:15:01 -08:00

315 lines
8.7 KiB
Bash

#!/usr/bin/env bats
load $BATS_TEST_DIRNAME/helper/common.bash
setup() {
setup_common
dolt sql <<SQL
CREATE TABLE test (
pk int primary key
);
INSERT INTO test VALUES (0),(1),(2);
SQL
}
teardown() {
assert_feature_version
teardown_common
}
@test "sql-checkout: DOLT_CHECKOUT just works" {
run dolt sql -q "call dolt_checkout('-b', 'feature-branch')"
[ $status -eq 0 ]
# dolt sql -q "call dolt_checkout() should not change the branch
# It changes the branch for that session which ends after the SQL
# statements are executed.
run dolt status
[ $status -eq 0 ]
[[ "$output" =~ "main" ]] || false
run dolt branch
[ $status -eq 0 ]
[[ "$output" =~ "feature-branch" ]] || false
run dolt sql -q "call dolt_checkout('main');"
[ $status -eq 0 ]
run dolt status
[ $status -eq 0 ]
[[ "$output" =~ "main" ]] || false
}
@test "sql-checkout: DOLT_CHECKOUT -b throws error on branches that already exist" {
run dolt sql -q "call dolt_checkout('-b', 'main')"
[ $status -eq 1 ]
}
@test "sql-checkout: DOLT_CHECKOUT throws error on branches that don't exist" {
run dolt sql -q "call dolt_checkout('feature-branch')"
[ $status -eq 1 ]
}
@test "sql-checkout: DOLT_CHECKOUT -b throws error on empty branch" {
run dolt sql -q "call dolt_checkout('-b', '')"
[ $status -eq 1 ]
}
@test "sql-checkout: DOLT_CHECKOUT updates the head ref session var" {
export DOLT_DBNAME_REPLACE="true"
run dolt sql <<SQL
call dolt_checkout('-b', 'feature-branch');
select @@dolt_repo_$$_head_ref;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "refs/heads/feature-branch" ]] || false
}
@test "sql-checkout: DOLT_CHECKOUT changes branches, leaves behind working set unmodified." {
dolt add . && dolt commit -m "0, 1, and 2 in test table"
dolt sql -q "insert into test values (4);"
run dolt status
[ $status -eq 0 ]
[[ "$output" =~ "On branch main" ]] || false
[[ "$output" =~ ([[:space:]]*modified:[[:space:]]*test) ]] || false
# After switching to a new branch, we don't see working set changes
run dolt sql << SQL
call dolt_checkout('-b', 'feature-branch');
select * from test where pk > 3;
SQL
[ $status -eq 0 ]
[[ ! "$output" =~ "4" ]] || false
# the branch was created by dolt_checkout
run dolt branch
[ $status -eq 0 ]
[[ "$output" =~ "feature-branch" ]] || false
# but the shell is still on branch main, with the same changes as before
run dolt status
[ $status -eq 0 ]
[[ "$output" =~ "On branch main" ]] || false
[[ "$output" =~ ([[:space:]]*modified:[[:space:]]*test) ]] || false
run dolt sql << SQL
select * from test where pk > 3;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "4" ]] || false
run dolt sql << SQL
call dolt_checkout('-b', 'feature-branch2');
insert into test values (5);
select * from test where pk > 3;
SQL
[ $status -eq 0 ]
[[ ! "$output" =~ "4" ]] || false
[[ "$output" =~ "5" ]] || false
# working set from main has 4, but not 5
run dolt sql -q "select * from test where pk > 3"
[ $status -eq 0 ]
[[ "$output" =~ "4" ]] || false
[[ ! "$output" =~ "5" ]] || false
run dolt status
[ $status -eq 0 ]
[[ "$output" =~ "On branch main" ]] || false
[[ "$output" =~ ([[:space:]]*modified:[[:space:]]*test) ]] || false
# In a new session, the value inserted should still be there
run dolt sql << SQL
call dolt_checkout('feature-branch2');
select * from test where pk > 3;
SQL
[ $status -eq 0 ]
[[ ! "$output" =~ "4" ]] || false
[[ "$output" =~ "5" ]] || false
# This is an error on the command line, but not in SQL
run dolt sql -q "call dolt_checkout('main')"
[ $status -eq 0 ]
}
@test "sql-checkout: DOLT_CHECKOUT works with dolt_diff tables" {
dolt add . && dolt commit -m "1, 2, and 3 in test table"
run dolt sql -q "SELECT * FROM dolt_diff_test";
[ $status -eq 0 ]
emptydiff=$output
run dolt sql << SQL
call dolt_checkout('-b', 'feature-branch');
SELECT * FROM dolt_diff_test;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "$emptydiff" ]] || false
run dolt sql << SQL
call dolt_checkout('feature-branch');
SELECT * FROM dolt_diff_test;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "$emptydiff" ]] || false
# add some changes to the working set
dolt sql -q "insert into test values (4)"
run dolt sql -q "SELECT * FROM dolt_diff_test";
[ $status -eq 0 ]
[[ ! "$output" =~ "$emptydiff" ]] || false
run dolt sql << SQL
call dolt_checkout('-b', 'feature-branch2');
SELECT * FROM dolt_diff_test;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "$emptydiff" ]] || false
run dolt sql << SQL
call dolt_checkout('feature-branch2');
SELECT * FROM dolt_diff_test;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "$emptydiff" ]] || false
}
@test "sql-checkout: DOLT_CHECKOUT followed by DOLT_COMMIT" {
dolt add . && dolt commit -m "0, 1, and 2 in test table"
run dolt sql << SQL
call dolt_checkout('-b', 'feature-branch');
INSERT INTO test VALUES (4);
call dolt_add('.');
call dolt_commit('-m', 'Added 4', '--author', 'John Doe <john@doe.com>');
SQL
[ $status -eq 0 ]
dolt status
# on branch main, no changes visible
run dolt log -n 1
[[ ! "$output" =~ "Added 4" ]] || false
[[ "$output" =~ "0, 1, and 2" ]] || false
dolt checkout feature-branch
run dolt log -n 1
[ $status -eq 0 ]
[[ "$output" =~ "Added 4" ]] || false
[[ "$output" =~ "John Doe" ]] || false
dolt checkout main
run dolt merge feature-branch --no-commit
[ $status -eq 0 ]
run dolt log -n 1
[[ "$output" =~ "Added 4" ]] || false
[[ "$output" =~ "John Doe" ]] || false
}
@test "sql-checkout: DOLT_CHECKOUT with table name clears working set changes" {
dolt add . && dolt commit -m "0, 1, and 2 in test table"
run dolt sql << SQL
call dolt_checkout('-b', 'feature-branch');
INSERT INTO test VALUES (4);
select * from test where pk > 3;
SQL
[ $status -eq 0 ]
[[ "$output" =~ "4" ]] || false
run dolt sql << SQL
call dolt_checkout('feature-branch');
call dolt_checkout('test');
select * from test where pk > 3;
SQL
[ $status -eq 0 ]
[[ ! "$output" =~ "4" ]] || false
}
@test "sql-checkout: DOLT_CHECKOUT between branches operating on the same table works." {
run dolt sql << SQL
CREATE TABLE one_pk (
pk1 BIGINT NOT NULL,
c1 BIGINT,
c2 BIGINT,
PRIMARY KEY (pk1)
);
call dolt_add('.');
call dolt_commit('-a', '-m', 'add tables');
call dolt_checkout('-b', 'feature-branch');
call dolt_checkout('main');
INSERT INTO one_pk (pk1,c1,c2) VALUES (0,0,0);
call dolt_commit('-a', '-m', 'changed main');
call dolt_checkout('feature-branch');
INSERT INTO one_pk (pk1,c1,c2) VALUES (0,1,1);
call dolt_commit('-a', '-m', "changed feature-branch");
SQL
[ $status -eq 0 ]
run dolt sql -q "SELECT * FROM one_pk" -r csv
[ $status -eq 0 ]
[[ "$output" =~ "pk1,c1,c2" ]] || false
[[ ! "$output" =~ "0,1,1" ]] || false
[[ "$output" =~ "0,0,0" ]] || false
dolt checkout feature-branch
run dolt sql -q "SELECT * FROM one_pk" -r csv
[ $status -eq 0 ]
[[ "$output" =~ "pk1,c1,c2" ]] || false
[[ "$output" =~ "0,1,1" ]] || false
[[ ! "$output" =~ "0,0,0" ]] || false
}
@test "sql-checkout: DOLT_CHECKOUT does not throw an error when checking out to the same branch" {
run dolt sql -q "call dolt_checkout('main')"
[ $status -eq 0 ]
[[ "$output" =~ "0" ]] || false
}
@test "sql-checkout: CALL DOLT_CHECKOUT can successfully checkout a branch that does not have a workingset" {
# Some code paths in dolt, especially in older versions of dolt, would create
# branches without working sets. CLI `dolt checkout` will check these out
# fine. CALL DOLT_CHECKOUT needs to be able to too.
h=`get_head_commit`
# First we test the case where there is no remote tracking branch associate with this branch.
dolt admin set-ref --branch no_working_set --to "$h"
run dolt sql -q 'CALL DOLT_CHECKOUT("no_working_set")'
[ $status -eq 0 ]
[[ "$output" =~ "0" ]] || false
# Then we test the same behavior but with a remote tracking branch around as well.
dolt remote add origin https://localhost:50051/doesnot/work
dolt admin set-ref --remote-name origin --remote-branch no_working_set --to "$h"
run dolt sql -q 'CALL DOLT_CHECKOUT("no_working_set")'
[ $status -eq 0 ]
[[ "$output" =~ "0" ]] || false
}
@test "sql-checkout: 'CALL DOLT_CHECKOUT --move' moves the working set" {
dolt branch other
run dolt sql -r csv << SQL
call dolt_checkout('other', '--move');
select active_branch();
select * from dolt_status;
SQL
[ $status -eq 0 ]
[[ "${lines[3]}" =~ "other" ]] || false
[[ "${lines[5]}" =~ "test,0,new table" ]] || false
}
get_head_commit() {
dolt log -n 1 | grep -m 1 commit | awk '{print $2}'
}