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