2014-10-01 19:00:33 +04:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
test_description='basic tests for the SHA1 array implementation'
|
|
|
|
. ./test-lib.sh
|
|
|
|
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid () {
|
2014-10-01 19:00:33 +04:00
|
|
|
prefix="${1:+$1 }"
|
|
|
|
shift
|
|
|
|
while test $# -gt 0
|
|
|
|
do
|
2018-09-13 08:17:36 +03:00
|
|
|
echo "$prefix$ZERO_OID" | sed -e "s/00/$1/g"
|
2014-10-01 19:00:33 +04:00
|
|
|
shift
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
test_expect_success 'ordered enumeration' '
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid "" 44 55 88 aa >expect &&
|
2014-10-01 19:00:33 +04:00
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 88 44 aa 55 &&
|
2014-10-01 19:00:33 +04:00
|
|
|
echo for_each_unique
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:00:33 +04:00
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'ordered enumeration with duplicate suppression' '
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid "" 44 55 88 aa >expect &&
|
2014-10-01 19:00:33 +04:00
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid append 88 44 aa 55 &&
|
2014-10-01 19:00:33 +04:00
|
|
|
echo for_each_unique
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:00:33 +04:00
|
|
|
test_cmp expect actual
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'lookup' '
|
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid lookup 55
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:00:33 +04:00
|
|
|
n=$(cat actual) &&
|
|
|
|
test "$n" -eq 1
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'lookup non-existing entry' '
|
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid lookup 33
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:00:33 +04:00
|
|
|
n=$(cat actual) &&
|
|
|
|
test "$n" -lt 0
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'lookup with duplicates' '
|
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid lookup 55
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:00:33 +04:00
|
|
|
n=$(cat actual) &&
|
|
|
|
test "$n" -ge 2 &&
|
|
|
|
test "$n" -le 3
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'lookup non-existing entry with duplicates' '
|
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid append 88 44 aa 55 &&
|
|
|
|
echoid lookup 66
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:00:33 +04:00
|
|
|
n=$(cat actual) &&
|
|
|
|
test "$n" -lt 0
|
|
|
|
'
|
|
|
|
|
2014-10-01 19:02:37 +04:00
|
|
|
test_expect_success 'lookup with almost duplicate values' '
|
2018-09-13 08:17:36 +03:00
|
|
|
# n-1 5s
|
|
|
|
root=$(echoid "" 55) &&
|
|
|
|
root=${root%5} &&
|
2014-10-01 19:02:37 +04:00
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
id1="${root}5" &&
|
|
|
|
id2="${root}f" &&
|
|
|
|
echo "append $id1" &&
|
|
|
|
echo "append $id2" &&
|
|
|
|
echoid lookup 55
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:02:37 +04:00
|
|
|
n=$(cat actual) &&
|
|
|
|
test "$n" -eq 0
|
|
|
|
'
|
|
|
|
|
|
|
|
test_expect_success 'lookup with single duplicate value' '
|
|
|
|
{
|
2018-09-13 08:17:36 +03:00
|
|
|
echoid append 55 55 &&
|
|
|
|
echoid lookup 55
|
2018-03-24 10:44:57 +03:00
|
|
|
} | test-tool sha1-array >actual &&
|
2014-10-01 19:02:37 +04:00
|
|
|
n=$(cat actual) &&
|
|
|
|
test "$n" -ge 0 &&
|
|
|
|
test "$n" -le 1
|
|
|
|
'
|
|
|
|
|
2014-10-01 19:00:33 +04:00
|
|
|
test_done
|