Files
dolt/integration-tests/bats/show.bats
2025-01-10 14:13:08 -08:00

344 lines
16 KiB
Bash

#!/usr/bin/env bats
load $BATS_TEST_DIRNAME/helper/common.bash
setup() {
setup_common
}
teardown() {
assert_feature_version
teardown_common
}
extract_value() {
key="$1"
input="$2"
echo "$input" | awk "
BEGIN { in_value = 0 }
/$key: {/ { in_value = 1; next }
match("'$0'", /$key: /) { print substr("'$0'", RSTART+RLENGTH) }
/}/ { if (in_value) { in_value = 0 } }
in_value { gsub(/^[ \t]+/, \"\"); print }
"
}
assert_has_key() {
key="$1"
input="$2"
extracted=$(extract_value "$key" "$input")
if [[ -z $extracted ]]; then
echo "Expected to find key $key"
return 1
else
return 0
fi
}
assert_has_key_value() {
key="$1"
value="$2"
input="$3"
extracted=$(extract_value "$key" "$input")
if [[ "$extracted" != "$value" ]]; then
echo "Expected key $key to have value $value, instead found $extracted"
return 1
else
return 0
fi
}
@test "show: on initialized repo" {
run dolt show
[ "$status" -eq 0 ]
[[ "$output" =~ "Initialize data repository" ]] || false
}
@test "show: log zero refs" {
dolt commit --allow-empty -m "Commit One"
dolt tag v1
run dolt show
[ $status -eq 0 ]
[[ "$output" =~ "Commit One" ]] || false
[[ "$output" =~ "tag: v1" ]] || false
dolt commit --allow-empty -m "Commit Two"
dolt tag v2
run dolt show
[ $status -eq 0 ]
[[ "$output" =~ "Commit Two" ]] || false
[[ "$output" =~ "tag: v2" ]] || false
}
@test "show: log one ref" {
dolt commit --allow-empty -m "Commit One"
dolt tag v1
dolt commit --allow-empty -m "Commit Two"
dolt tag v2
run dolt show v1
[ $status -eq 0 ]
[[ "$output" =~ "Commit One" ]] || false
[[ "$output" =~ "tag: v1" ]] || false
}
@test "show: log two refs" {
dolt commit --allow-empty -m "Commit One"
dolt tag v1
dolt commit --allow-empty -m "Commit Two"
dolt tag v2
run dolt show v1 v2
[ $status -eq 0 ]
[[ "$output" =~ "Commit One" ]] || false
[[ "$output" =~ "tag: v1" ]] || false
[[ "$output" =~ "Commit Two" ]] || false
[[ "$output" =~ "tag: v2" ]] || false
}
@test "show: log and diff" {
dolt sql -q "create table testtable (pk int PRIMARY KEY)"
dolt add .
dolt commit -m "commit: add table"
run dolt show
[ $status -eq 0 ]
[[ "$output" =~ "commit: add table" ]] || false
[[ "$output" =~ "diff --dolt a/testtable b/testtable" ]] || false
[[ "$output" =~ "added table" ]] || false
[[ "$output" =~ "+CREATE TABLE \`testtable\` (" ]] || false
[[ "$output" =~ "+ \`pk\` int NOT NULL," ]] || false
[[ "$output" =~ "+ PRIMARY KEY (\`pk\`)" ]] || false
dolt sql -q 'insert into testtable values (4)'
dolt add .
dolt commit -m "commit: add values"
run dolt show
[ $status -eq 0 ]
[[ "$output" =~ "commit: add values" ]] || false
[[ "$output" =~ "| | pk |" ]] || false
[[ "$output" =~ "| + | 4 |" ]] || false
}
@test "show: --no-pretty" {
dolt commit --allow-empty -m "commit: initialize table1"
run dolt show --no-pretty
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
assert_has_key "Name" "$output"
assert_has_key_value "Name" "Bats Tests" "$output"
assert_has_key_value "Desc" "commit: initialize table1" "$output"
assert_has_key_value "Name" "Bats Tests" "$output"
assert_has_key_value "Email" "bats@email.fake" "$output"
assert_has_key "Timestamp" "$output"
assert_has_key "UserTimestamp" "$output"
assert_has_key_value "Height" "2" "$output"
assert_has_key "RootValue" "$output"
assert_has_key "Parents" "$output"
assert_has_key "ParentClosure" "$output"
}
@test "show: --no-pretty commit hash" {
dolt commit --allow-empty -m "commit: initialize table1"
hash=$(dolt sql -q "select dolt_hashof('head');" -r csv | tail -n 1)
run dolt show --no-pretty $hash
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
assert_has_key "Name" "$output"
assert_has_key_value "Name" "Bats Tests" "$output"
assert_has_key_value "Desc" "commit: initialize table1" "$output"
assert_has_key_value "Name" "Bats Tests" "$output"
assert_has_key_value "Email" "bats@email.fake" "$output"
assert_has_key "Timestamp" "$output"
assert_has_key "UserTimestamp" "$output"
assert_has_key_value "Height" "2" "$output"
assert_has_key "RootValue" "$output"
assert_has_key "Parents" "$output"
assert_has_key "ParentClosure" "$output"
}
@test "show: HEAD root" {
dolt sql -q "create table table1 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (1), (2), (3)"
dolt add .
dolt commit -m "commit: initialize table1"
dolt sql -q "create table table2 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (4), (5), (6)"
dolt add .
dolt sql -q "create table table3 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (7), (8), (9)"
head=$(dolt show --no-pretty)
rootValue=$(extract_value RootValue "$head")
echo rootValue=$rootValue
[[ ! -z $rootValue ]] || false
run dolt show $rootValue
[ $status -eq 0 ]
[[ "$output" =~ "table1" ]] || false
[[ ! "$output" =~ "table2" ]] || false
[[ ! "$output" =~ "table3" ]] || false
}
@test "show: WORKING" {
dolt sql -q "create table table1 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (1), (2), (3)"
dolt add .
dolt commit -m "commit: initialize table1"
dolt sql -q "create table table2 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (4), (5), (6)"
dolt add .
dolt sql -q "create table table3 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (7), (8), (9)"
run dolt show --no-pretty WORKING
[ $status -eq 0 ]
[[ "$output" =~ "table1" ]] || false
[[ "$output" =~ "table2" ]] || false
[[ "$output" =~ "table3" ]] || false
}
@test "show: STAGED" {
dolt sql -q "create table table1 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (1), (2), (3)"
dolt add .
dolt commit -m "commit: initialize table1"
dolt sql -q "create table table2 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (4), (5), (6)"
dolt add .
dolt sql -q "create table table3 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (7), (8), (9)"
run dolt show --no-pretty STAGED
[ $status -eq 0 ]
[[ "$output" =~ "table1" ]] || false
[[ "$output" =~ "table2" ]] || false
[[ ! "$output" =~ "table3" ]] || false
}
@test "show: table" {
dolt sql -q "create table table1 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (1), (2), (3)"
dolt add .
dolt commit -m "commit: initialize table1"
dolt sql -q "create table table2 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (4), (5), (6)"
dolt add .
dolt sql -q "create table table3 (pk int PRIMARY KEY)"
dolt sql -q "insert into table1 values (7), (8), (9)"
workingRoot=$(dolt show --no-pretty WORKING)
tableAddress=$(extract_value table1 "$workingRoot")
run dolt show --no-pretty $tableAddress
assert_has_key Schema "$output"
assert_has_key Violations "$output"
assert_has_key Autoinc "$output"
assert_has_key "Primary index" "$output"
assert_has_key "Secondary indexes" "$output"
}
@test "show: pretty commit from hash" {
dolt tag v0
dolt commit --allow-empty -m "commit1"
head=$(dolt show --no-pretty)
parentHash=$(extract_value Parents "$head")
run dolt show "$parentHash"
[[ "$output" =~ "tag: v0" ]] || false
}
@test "show: non-existent branch" {
run dolt show branch1
[ $status -eq 1 ]
[[ "$output" =~ "branch not found: branch1" ]] || false
}
@test "show: primary index leaf" {
dolt sql <<EOF
create table test(pk int primary key, t text, j json);
insert into test values (0, "Hello", "{}"), (1, "World", "[]");
EOF
run dolt show "#9heeqrj6idph7snnko484sqnobu2r46i"
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
[[ "$output" =~ "{ key: 00000000 value: #0isi5776c0lu0d7rvsnfl80gsdisilsa, #e6sucun84ck3bgc1p9lorkibp30mvd2f }" ]] || false
[[ "$output" =~ "{ key: 01000000 value: #8scr7d6rtnafqovoa7d06em7jkpil9gg, #8arugs9qup4pvpmqbf64lpkm9f6cdv74 }" ]] || false
}
@test "show: blob leaf" {
dolt sql <<EOF
create table test(pk int primary key, t text, j json);
insert into test values (0, "Hello", "{}"), (1, "World", "[]");
EOF
run dolt show "#0isi5776c0lu0d7rvsnfl80gsdisilsa"
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
[[ "$output" =~ "Blob - Hello" ]] || false
}
@test "show: blob non-leaf" {
dolt sql <<EOF
create table words (t text);
insert into words values ("Lorem ipsum dolor sit amet, consectetur adipiscing elit. Maecenas interdum, magna nec lacinia ultrices, nunc urna pretium neque, eu feugiat tortor elit vitae felis. Aliquam laoreet non ex vitae porttitor. Phasellus bibendum felis vel elit ultrices fermentum. Proin eleifend hendrerit auctor. Curabitur non neque lectus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras ut tincidunt magna. Fusce faucibus eget enim sit amet fringilla. Fusce vitae est quis velit efficitur rutrum iaculis quis lacus. Sed vitae diam id odio maximus interdum id at libero. Suspendisse iaculis facilisis mauris. Sed sagittis libero urna, posuere facilisis dolor porttitor sed. Nulla sed diam in risus sollicitudin blandit. Mauris purus libero, rhoncus vitae turpis ut, luctus rutrum arcu. In porta magna non enim molestie pharetra quis nec sem. Maecenas vehicula neque dolor, ut malesuada leo finibus sit amet. Proin viverra mauris sit amet urna rutrum ullamcorper. Duis hendrerit turpis a massa dapibus consectetur. Nunc posuere faucibus nibh, sed fringilla tellus mollis ac. Aliquam placerat ipsum at velit pretium, id convallis nisi euismod. Curabitur eget euismod ante, non interdum ipsum. Sed quis volutpat lorem, non luctus diam. Sed commodo enim vel nisi ultricies, nec porta magna placerat. Maecenas tristique viverra cursus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras tempus nisl et purus sodales, vitae dignissim mi condimentum. Nullam ut ullamcorper purus. Phasellus malesuada bibendum elit. Mauris justo magna, condimentum id accumsan sit amet, mollis ut nulla. Nullam et lorem sed nulla semper dapibus. Nam quis ipsum a elit sodales ultrices. Praesent convallis ipsum et semper commodo. Donec nec nunc erat. Curabitur ut hendrerit tellus, in lobortis leo. Sed at venenatis lectus. Sed faucibus in odio eu aliquet. Morbi sed enim nisl. Vestibulum gravida magna at lectus ornare, vel porta quam placerat. Fusce ornare, felis vitae sagittis volutpat, nisi ex euismod lorem, ac sollicitudin urna ipsum vitae massa. Cras lacinia mauris velit. Nam et laoreet orci, et porttitor augue. Integer viverra felis vel erat cursus, vel consequat tellus consectetur. Mauris laoreet ut tortor non finibus. Fusce mattis odio suscipit sem elementum, in vehicula nisl dignissim. Phasellus neque ligula, ullamcorper sit amet risus dapibus, tincidunt ornare mauris. Quisque non cursus ante. Nulla facilisi. Aliquam id lacus in tortor semper malesuada. Vestibulum at mattis tellus. Duis placerat tempus libero, sit amet dictum nibh pulvinar molestie. Ut aliquam tellus nec libero semper volutpat. Aenean pretium porttitor ex, non volutpat arcu aliquam non. Vestibulum eget eleifend dui. Nullam mollis, ipsum sit amet iaculis scelerisque, lorem diam eleifend leo, eget lobortis arcu orci a nulla. Morbi non ligula ex. Aliquam ac augue congue, finibus ante at, convallis leo. Vestibulum fermentum hendrerit felis ut ullamcorper. Sed porttitor turpis at justo iaculis aliquam. Praesent hendrerit sit amet justo ut aliquam. Praesent ut ligula placerat mi eleifend aliquam sit amet vel leo. Phasellus vitae arcu a turpis accumsan volutpat. Proin libero purus, dictum nec ullamcorper in, venenatis luctus felis. Sed pharetra, justo nec ornare mattis, neque erat tristique felis, ut finibus massa felis eu erat. In dictum dui nibh, a finibus velit scelerisque at. Aenean lacinia, ex a bibendum gravida, felis enim tincidunt dolor, in tristique eros nunc eu nibh. Nulla facilisi. Donec non risus porttitor, egestas nulla vitae, sollicitudin lorem. Proin sem lectus, fermentum vel dui cursus, mattis tempus nulla. Mauris quis justo urna. In vestibulum erat id lobortis malesuada. Curabitur non velit laoreet, porttitor felis vitae, aliquam magna. Quisque id tempor justo. Suspendisse potenti. Morbi vel ipsum suscipit, aliquam tellus ac, pharetra neque. Suspendisse ultrices, justo pulvinar sodales convallis, mauris risus vulputate erat, nec euismod libero quam at nulla. Curabitur ac suscipit nulla. Maecenas a augue nulla. Ut quis mauris at enim accumsan ultricies. Morbi non pellentesque elit. Proin et arcu ullamcorper, finibus nisi ut, tincidunt justo. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Nunc ultrices imperdiet nulla quis tincidunt. Donec pulvinar odio non magna imperdiet, at varius augue efficitur. Suspendisse molestie sapien lacus, in ornare est tincidunt non. Aliquam arcu sem, sagittis ac feugiat at, fermentum quis neque. Pellentesque ut nisl eget nulla lobortis pellentesque semper et felis.");
EOF
run dolt show "#se3b28duf5bpq9e05hasd4b551heqb9q"
[ $status -eq 0 ]
[[ "$output" =~ "{ ref: #0fcaf98hbdt02fb6gullguuv3frnoj7f }" ]] || false
[[ "$output" =~ "{ ref: #4mub3fdl5lm99vd0d4uoake0q4d9rsjj }" ]] || false
}
@test "show: primary index non-leaf" {
dolt sql <<EOF
create table test(pk int primary key);
insert into test values (1);
EOF
for i in {1..10}; do dolt sql -q "insert ignore into test select pk*2+$i from test;"; done
run dolt show "#r9g8a8r570drje8lbnn72jftu49gkq9t"
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
[[ "$output" =~ "{ key: d5010000 ref: #5eiul2kmip341rse0besd0bv0u07jhf1 }" ]] || false
[[ "$output" =~ "{ key: f40b0000 ref: #vpuf5ccvph0i6stls48a0bj7as5k2aka }" ]] || false
}
@test "show: schema" {
dolt sql <<EOF
create table test(pk int primary key);
insert into test values (1);
EOF
for i in {1..10}; do dolt sql -q "insert ignore into test select pk*2+$i from test;"; done
run dolt show "#svtgrd12uf2u1q492it1aod9i5cqssv9"
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
[[ "$output" =~ "Columns: [" ]] || false
[[ "$output" =~ "Primary Index: {" ]] || false
[[ "$output" =~ "Secondary Indexes: [" ]] || false
[[ "$output" =~ "Comment: " ]] || false
[[ "$output" =~ "Checks: [" ]] || false
[[ "$output" =~ "Collation: utf8mb4_0900_bin" ]] || false
}
@test "show: secondary index leaf" {
dolt sql <<EOF
create table test(pk int primary key, v2 int unique);
insert into test values (0, 35), (1, 19), (2, 3);
EOF
run dolt show "#9afhmiubuqjviu4qocn15tqlgigea26l"
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
[[ "$output" =~ "{ key: 03000000, 02000000 value: }" ]] || false
[[ "$output" =~ "{ key: 13000000, 01000000 value: }" ]] || false
[[ "$output" =~ "{ key: 23000000, 00000000 value: }" ]] || false
}
@test "show: secondary index non-leaf" {
dolt sql <<EOF
create table test(pk int primary key, v1 int, index(v1));
insert into test values (1, 0);
EOF
for i in {1..10}; do dolt sql -q "insert ignore into test select 2*(pk+$i), (pk+$i) from test;"; done
run dolt show "#3ir2otqqb8pnu28um6jc1ipv05iamdlk"
[ $status -eq 0 ]
[[ "$output" =~ "SerialMessage" ]] || false
[[ "$output" =~ "{ key: 73000000, e6000000 ref: #pdcuscnfqsusgil1642k5hup1cp5co6t }" ]] || false
[[ "$output" =~ "{ key: f4090000, e8130000 ref: #hddhk8djkj275q1so9fs3ag48v7qsfsi }" ]] || false
}