blob: 45685af2fd5095a9901fdb150de1c6fd8703728f [file] [log] [blame]
René Scharfe38d905b2014-10-01 17:00:33 +02001#!/bin/sh
2
3test_description='basic tests for the SHA1 array implementation'
4. ./test-lib.sh
5
brian m. carlson13740032018-09-13 05:17:36 +00006echoid () {
René Scharfe38d905b2014-10-01 17:00:33 +02007 prefix="${1:+$1 }"
8 shift
9 while test $# -gt 0
10 do
brian m. carlson13740032018-09-13 05:17:36 +000011 echo "$prefix$ZERO_OID" | sed -e "s/00/$1/g"
René Scharfe38d905b2014-10-01 17:00:33 +020012 shift
13 done
14}
15
16test_expect_success 'ordered enumeration' '
brian m. carlson13740032018-09-13 05:17:36 +000017 echoid "" 44 55 88 aa >expect &&
René Scharfe38d905b2014-10-01 17:00:33 +020018 {
brian m. carlson13740032018-09-13 05:17:36 +000019 echoid append 88 44 aa 55 &&
René Scharfe38d905b2014-10-01 17:00:33 +020020 echo for_each_unique
Jeff Kinged4b8042020-03-30 10:04:03 -040021 } | test-tool oid-array >actual &&
René Scharfe38d905b2014-10-01 17:00:33 +020022 test_cmp expect actual
23'
24
25test_expect_success 'ordered enumeration with duplicate suppression' '
brian m. carlson13740032018-09-13 05:17:36 +000026 echoid "" 44 55 88 aa >expect &&
René Scharfe38d905b2014-10-01 17:00:33 +020027 {
brian m. carlson13740032018-09-13 05:17:36 +000028 echoid append 88 44 aa 55 &&
29 echoid append 88 44 aa 55 &&
René Scharfe38d905b2014-10-01 17:00:33 +020030 echo for_each_unique
Jeff Kinged4b8042020-03-30 10:04:03 -040031 } | test-tool oid-array >actual &&
René Scharfe38d905b2014-10-01 17:00:33 +020032 test_cmp expect actual
33'
34
35test_expect_success 'lookup' '
36 {
brian m. carlson13740032018-09-13 05:17:36 +000037 echoid append 88 44 aa 55 &&
38 echoid lookup 55
Jeff Kinged4b8042020-03-30 10:04:03 -040039 } | test-tool oid-array >actual &&
René Scharfe38d905b2014-10-01 17:00:33 +020040 n=$(cat actual) &&
41 test "$n" -eq 1
42'
43
44test_expect_success 'lookup non-existing entry' '
45 {
brian m. carlson13740032018-09-13 05:17:36 +000046 echoid append 88 44 aa 55 &&
47 echoid lookup 33
Jeff Kinged4b8042020-03-30 10:04:03 -040048 } | test-tool oid-array >actual &&
René Scharfe38d905b2014-10-01 17:00:33 +020049 n=$(cat actual) &&
50 test "$n" -lt 0
51'
52
53test_expect_success 'lookup with duplicates' '
54 {
brian m. carlson13740032018-09-13 05:17:36 +000055 echoid append 88 44 aa 55 &&
56 echoid append 88 44 aa 55 &&
57 echoid lookup 55
Jeff Kinged4b8042020-03-30 10:04:03 -040058 } | test-tool oid-array >actual &&
René Scharfe38d905b2014-10-01 17:00:33 +020059 n=$(cat actual) &&
60 test "$n" -ge 2 &&
61 test "$n" -le 3
62'
63
64test_expect_success 'lookup non-existing entry with duplicates' '
65 {
brian m. carlson13740032018-09-13 05:17:36 +000066 echoid append 88 44 aa 55 &&
67 echoid append 88 44 aa 55 &&
68 echoid lookup 66
Jeff Kinged4b8042020-03-30 10:04:03 -040069 } | test-tool oid-array >actual &&
René Scharfe38d905b2014-10-01 17:00:33 +020070 n=$(cat actual) &&
71 test "$n" -lt 0
72'
73
René Scharfe0eb0fb82014-10-01 17:02:37 +020074test_expect_success 'lookup with almost duplicate values' '
brian m. carlson13740032018-09-13 05:17:36 +000075 # n-1 5s
76 root=$(echoid "" 55) &&
77 root=${root%5} &&
René Scharfe0eb0fb82014-10-01 17:02:37 +020078 {
brian m. carlson13740032018-09-13 05:17:36 +000079 id1="${root}5" &&
80 id2="${root}f" &&
81 echo "append $id1" &&
82 echo "append $id2" &&
83 echoid lookup 55
Jeff Kinged4b8042020-03-30 10:04:03 -040084 } | test-tool oid-array >actual &&
René Scharfe0eb0fb82014-10-01 17:02:37 +020085 n=$(cat actual) &&
86 test "$n" -eq 0
87'
88
89test_expect_success 'lookup with single duplicate value' '
90 {
brian m. carlson13740032018-09-13 05:17:36 +000091 echoid append 55 55 &&
92 echoid lookup 55
Jeff Kinged4b8042020-03-30 10:04:03 -040093 } | test-tool oid-array >actual &&
René Scharfe0eb0fb82014-10-01 17:02:37 +020094 n=$(cat actual) &&
95 test "$n" -ge 0 &&
96 test "$n" -le 1
97'
98
René Scharfe38d905b2014-10-01 17:00:33 +020099test_done