|
4 | 4 | "bytes"
|
5 | 5 | "fmt"
|
6 | 6 | "math/rand"
|
7 |
| - "sort" |
| 7 | + "strings" |
8 | 8 | "testing"
|
9 | 9 |
|
10 | 10 | dstore "github.com/ipfs/go-datastore"
|
@@ -123,79 +123,111 @@ func SubtestNotFounds(t *testing.T, ds dstore.Datastore) {
|
123 | 123 | }
|
124 | 124 | }
|
125 | 125 |
|
| 126 | +func SubtestOrder(t *testing.T, ds dstore.Datastore) { |
| 127 | + test := func(orders ...dsq.Order) { |
| 128 | + var types []string |
| 129 | + for _, o := range orders { |
| 130 | + types = append(types, fmt.Sprintf("%T", o)) |
| 131 | + } |
| 132 | + name := strings.Join(types, ">") |
| 133 | + t.Run(name, func(t *testing.T) { |
| 134 | + subtestQuery(t, ds, dsq.Query{ |
| 135 | + Orders: orders, |
| 136 | + }, func(t *testing.T, input, output []dsq.Entry) { |
| 137 | + if len(input) != len(output) { |
| 138 | + t.Fatal("got wrong number of keys back") |
| 139 | + } |
| 140 | + |
| 141 | + dsq.Sort(orders, input) |
| 142 | + |
| 143 | + for i, e := range output { |
| 144 | + if input[i].Key != e.Key { |
| 145 | + t.Fatalf("in key output, got %s but expected %s", e.Key, input[i].Key) |
| 146 | + } |
| 147 | + } |
| 148 | + }) |
| 149 | + }) |
| 150 | + } |
| 151 | + test(dsq.OrderByKey{}) |
| 152 | + test(new(dsq.OrderByKey)) |
| 153 | + test(dsq.OrderByKeyDescending{}) |
| 154 | + test(new(dsq.OrderByKeyDescending)) |
| 155 | + test(dsq.OrderByValue{}) |
| 156 | + test(dsq.OrderByValue{}, dsq.OrderByKey{}) |
| 157 | + test(dsq.OrderByFunction(func(a, b dsq.Entry) int { |
| 158 | + return bytes.Compare(a.Value, b.Value) |
| 159 | + })) |
| 160 | +} |
| 161 | + |
126 | 162 | func SubtestManyKeysAndQuery(t *testing.T, ds dstore.Datastore) {
|
127 |
| - var keys []dstore.Key |
128 |
| - var keystrs []string |
129 |
| - var values [][]byte |
| 163 | + subtestQuery(t, ds, dsq.Query{KeysOnly: true}, func(t *testing.T, input, output []dsq.Entry) { |
| 164 | + if len(input) != len(output) { |
| 165 | + t.Fatal("got wrong number of keys back") |
| 166 | + } |
| 167 | + |
| 168 | + dsq.Sort([]dsq.Order{dsq.OrderByKey{}}, input) |
| 169 | + dsq.Sort([]dsq.Order{dsq.OrderByKey{}}, output) |
| 170 | + |
| 171 | + for i, e := range output { |
| 172 | + if input[i].Key != e.Key { |
| 173 | + t.Fatalf("in key output, got %s but expected %s", e.Key, input[i].Key) |
| 174 | + } |
| 175 | + } |
| 176 | + }) |
| 177 | +} |
| 178 | + |
| 179 | +func subtestQuery(t *testing.T, ds dstore.Datastore, q dsq.Query, check func(t *testing.T, input, output []dsq.Entry)) { |
| 180 | + var input []dsq.Entry |
130 | 181 | count := 100
|
131 | 182 | for i := 0; i < count; i++ {
|
132 | 183 | s := fmt.Sprintf("%dkey%d", i, i)
|
133 |
| - dsk := dstore.NewKey(s) |
134 |
| - keystrs = append(keystrs, dsk.String()) |
135 |
| - keys = append(keys, dsk) |
136 |
| - buf := make([]byte, 64) |
137 |
| - rand.Read(buf) |
138 |
| - values = append(values, buf) |
| 184 | + key := dstore.NewKey(s).String() |
| 185 | + value := make([]byte, 64) |
| 186 | + rand.Read(value) |
| 187 | + input = append(input, dsq.Entry{ |
| 188 | + Key: key, |
| 189 | + Value: value, |
| 190 | + }) |
139 | 191 | }
|
140 | 192 |
|
141 | 193 | t.Logf("putting %d values", count)
|
142 |
| - for i, k := range keys { |
143 |
| - err := ds.Put(k, values[i]) |
| 194 | + for i, e := range input { |
| 195 | + err := ds.Put(dstore.RawKey(e.Key), e.Value) |
144 | 196 | if err != nil {
|
145 | 197 | t.Fatalf("error on put[%d]: %s", i, err)
|
146 | 198 | }
|
147 | 199 | }
|
148 | 200 |
|
149 | 201 | t.Log("getting values back")
|
150 |
| - for i, k := range keys { |
151 |
| - val, err := ds.Get(k) |
| 202 | + for i, e := range input { |
| 203 | + val, err := ds.Get(dstore.RawKey(e.Key)) |
152 | 204 | if err != nil {
|
153 | 205 | t.Fatalf("error on get[%d]: %s", i, err)
|
154 | 206 | }
|
155 | 207 |
|
156 |
| - if !bytes.Equal(val, values[i]) { |
| 208 | + if !bytes.Equal(val, e.Value) { |
157 | 209 | t.Fatal("input value didnt match the one returned from Get")
|
158 | 210 | }
|
159 | 211 | }
|
160 | 212 |
|
161 | 213 | t.Log("querying values")
|
162 |
| - q := dsq.Query{KeysOnly: true} |
163 | 214 | resp, err := ds.Query(q)
|
164 | 215 | if err != nil {
|
165 | 216 | t.Fatal("calling query: ", err)
|
166 | 217 | }
|
167 | 218 |
|
168 | 219 | t.Log("aggregating query results")
|
169 |
| - var outkeys []string |
170 |
| - for { |
171 |
| - res, ok := resp.NextSync() |
172 |
| - if res.Error != nil { |
173 |
| - t.Fatal("query result error: ", res.Error) |
174 |
| - } |
175 |
| - if !ok { |
176 |
| - break |
177 |
| - } |
178 |
| - |
179 |
| - outkeys = append(outkeys, res.Key) |
| 220 | + output, err := resp.Rest() |
| 221 | + if err != nil { |
| 222 | + t.Fatal("query result error: ", err) |
180 | 223 | }
|
181 | 224 |
|
182 | 225 | t.Log("verifying query output")
|
183 |
| - sort.Strings(keystrs) |
184 |
| - sort.Strings(outkeys) |
185 |
| - |
186 |
| - if len(keystrs) != len(outkeys) { |
187 |
| - t.Fatal("got wrong number of keys back") |
188 |
| - } |
189 |
| - |
190 |
| - for i, s := range keystrs { |
191 |
| - if outkeys[i] != s { |
192 |
| - t.Fatalf("in key output, got %s but expected %s", outkeys[i], s) |
193 |
| - } |
194 |
| - } |
| 226 | + check(t, input, output) |
195 | 227 |
|
196 | 228 | t.Log("deleting all keys")
|
197 |
| - for _, k := range keys { |
198 |
| - if err := ds.Delete(k); err != nil { |
| 229 | + for _, e := range input { |
| 230 | + if err := ds.Delete(dstore.RawKey(e.Key)); err != nil { |
199 | 231 | t.Fatal(err)
|
200 | 232 | }
|
201 | 233 | }
|
|
0 commit comments