mirror of
https://github.com/dolthub/dolt.git
synced 2026-04-24 19:49:43 -05:00
155 lines
4.0 KiB
Bash
155 lines
4.0 KiB
Bash
#!/usr/bin/env bats
|
|
load $BATS_TEST_DIRNAME/helper/common.bash
|
|
|
|
setup() {
|
|
skip_nbf_dolt_1
|
|
skip_nbf_dolt_dev
|
|
|
|
TARGET_NBF="__DOLT_DEV__"
|
|
setup_common
|
|
}
|
|
|
|
teardown() {
|
|
teardown_common
|
|
}
|
|
|
|
function checksum_table {
|
|
QUERY="SELECT GROUP_CONCAT(column_name) FROM information_schema.columns WHERE table_name = '$1'"
|
|
COLUMNS=$( dolt sql -q "$QUERY" -r csv | tail -n1 | sed 's/"//g' )
|
|
dolt sql -q "SELECT CAST(SUM(CRC32(CONCAT($COLUMNS))) AS UNSIGNED) FROM $1 AS OF '$2';" -r csv | tail -n1
|
|
}
|
|
|
|
@test "migrate: smoke test" {
|
|
dolt sql <<SQL
|
|
CREATE TABLE test (pk int primary key, c0 int, c1 int);
|
|
INSERT INTO test VALUES (0,0,0);
|
|
CALL dadd('-A');
|
|
CALL dcommit('-am', 'added table test');
|
|
SQL
|
|
CHECKSUM=$(checksum_table test head)
|
|
|
|
[[ $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "__LD_1__" ]] || false
|
|
[[ ! $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
|
|
dolt migrate
|
|
|
|
[[ $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
[[ ! $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "__LD_1__" ]] || false
|
|
|
|
run checksum_table test head
|
|
[[ "$output" =~ "$CHECKSUM" ]] || false
|
|
|
|
run dolt sql -q "SELECT count(*) FROM dolt_commits" -r csv
|
|
[ $status -eq 0 ]
|
|
[[ "$output" =~ "2" ]] || false
|
|
}
|
|
|
|
@test "migrate: functional transform" {
|
|
dolt sql <<SQL
|
|
CREATE TABLE test (pk int primary key, c0 int, c1 int);
|
|
INSERT INTO test VALUES (0,0,0);
|
|
CALL dadd('-A');
|
|
CALL dcommit('-am', 'added table test');
|
|
SQL
|
|
|
|
mkdir db_one db_two
|
|
mv .dolt db_one
|
|
cp -r db_one/ db_two/
|
|
|
|
pushd db_one
|
|
dolt migrate
|
|
[[ $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
ONE=$(dolt branch -av)
|
|
popd
|
|
|
|
pushd db_two
|
|
dolt migrate
|
|
[[ $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
TWO=$(dolt branch -av)
|
|
popd
|
|
|
|
[[ "$ONE" = "$TWO" ]] || false
|
|
}
|
|
|
|
@test "migrate: manifest backup" {
|
|
dolt sql <<SQL
|
|
CREATE TABLE test (pk int primary key, c0 int, c1 int);
|
|
INSERT INTO test VALUES (0,0,0);
|
|
CALL dadd('-A');
|
|
CALL dcommit('-am', 'added table test');
|
|
SQL
|
|
|
|
dolt migrate
|
|
[[ $(cat ./.dolt/noms/manifest.bak | cut -f 2 -d :) = "__LD_1__" ]] || false
|
|
[[ ! $(cat ./.dolt/noms/manifest.bak | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
}
|
|
|
|
@test "migrate: multiple branches" {
|
|
dolt sql <<SQL
|
|
CREATE TABLE test (pk int primary key, c0 int, c1 int);
|
|
INSERT INTO test VALUES (0,0,0);
|
|
CALL dadd('-A');
|
|
CALL dcommit('-am', 'added table test');
|
|
SQL
|
|
dolt branch one
|
|
dolt branch two
|
|
|
|
dolt sql <<SQL
|
|
CALL dcheckout('one');
|
|
INSERT INTO test VALUES (1,1,1);
|
|
CALL dcommit('-am', 'row (1,1,1)');
|
|
CALL dcheckout('two');
|
|
INSERT INTO test VALUES (2,2,2);
|
|
CALL dcommit('-am', 'row (2,2,2)');
|
|
CALL dmerge('one');
|
|
SQL
|
|
|
|
MAIN=$(checksum_table test main)
|
|
ONE=$(checksum_table test one)
|
|
TWO=$(checksum_table test two)
|
|
|
|
dolt migrate
|
|
|
|
[[ $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
|
|
run checksum_table test main
|
|
[[ "$output" =~ "$MAIN" ]] || false
|
|
run checksum_table test one
|
|
[[ "$output" =~ "$ONE" ]] || false
|
|
run checksum_table test two
|
|
[[ "$output" =~ "$TWO" ]] || false
|
|
|
|
run dolt sql -q "SELECT count(*) FROM dolt_commits" -r csv
|
|
[ $status -eq 0 ]
|
|
[[ "$output" =~ "4" ]] || false
|
|
}
|
|
|
|
@test "migrate: tag and working set" {
|
|
dolt sql <<SQL
|
|
CREATE TABLE test (pk int primary key, c0 int, c1 int);
|
|
INSERT INTO test VALUES (0,0,0);
|
|
CALL dadd('-A');
|
|
CALL dcommit('-am', 'added table test');
|
|
CALL dtag('tag1', 'head');
|
|
INSERT INTO test VALUES (1,1,1);
|
|
CALL dcommit('-am', 'added rows');
|
|
INSERT INTO test VALUES (2,2,2);
|
|
SQL
|
|
|
|
HEAD=$(checksum_table test head)
|
|
PREV=$(checksum_table test head~1)
|
|
TAG=$(checksum_table test tag1)
|
|
[ $TAG -eq $PREV ]
|
|
|
|
dolt migrate
|
|
|
|
[[ $(cat ./.dolt/noms/manifest | cut -f 2 -d :) = "$TARGET_NBF" ]] || false
|
|
|
|
run checksum_table test head
|
|
[[ "$output" =~ "$HEAD" ]] || false
|
|
run checksum_table test head~1
|
|
[[ "$output" =~ "$PREV" ]] || false
|
|
run checksum_table test tag1
|
|
[[ "$output" =~ "$TAG" ]] || false
|
|
}
|