2 Copyright 2020 Google LLC
4 Use of this source code is governed by a BSD-style
5 license that can be found in the LICENSE file or at
6 https://developers.google.com/open-source/licenses/bsd
12 #include "constants.h"
15 #include "reftable-tests.h"
16 #include "test_framework.h"
18 void merged_iter_pqueue_check(struct merged_iter_pqueue pq
)
21 for (i
= 1; i
< pq
.len
; i
++) {
22 int parent
= (i
- 1) / 2;
24 EXPECT(pq_less(&pq
.heap
[parent
], &pq
.heap
[i
]));
28 static void test_pq(void)
30 char *names
[54] = { NULL
};
31 int N
= ARRAY_SIZE(names
) - 1;
33 struct merged_iter_pqueue pq
= { NULL
};
34 const char *last
= NULL
;
37 for (i
= 0; i
< N
; i
++) {
39 snprintf(name
, sizeof(name
), "%02d", i
);
40 names
[i
] = xstrdup(name
);
45 struct reftable_record rec
=
46 reftable_new_record(BLOCK_TYPE_REF
);
47 struct pq_entry e
= { 0 };
49 reftable_record_as_ref(&rec
)->refname
= names
[i
];
51 merged_iter_pqueue_add(&pq
, e
);
52 merged_iter_pqueue_check(pq
);
56 while (!merged_iter_pqueue_is_empty(pq
)) {
57 struct pq_entry e
= merged_iter_pqueue_remove(&pq
);
58 struct reftable_ref_record
*ref
=
59 reftable_record_as_ref(&e
.rec
);
61 merged_iter_pqueue_check(pq
);
64 EXPECT(strcmp(last
, ref
->refname
) < 0);
71 for (i
= 0; i
< N
; i
++) {
72 reftable_free(names
[i
]);
75 merged_iter_pqueue_release(&pq
);
78 int pq_test_main(int argc
, const char *argv
[])