On Tue, 25 Jun 2024 at 13:56, Karthik Nayak <karthik.188@xxxxxxxxx> wrote: > > Chandra Pratap <chandrapratap3519@xxxxxxxxx> writes: > > > reftable/record_test.c exercises the functions defined in > > reftable/record.{c, h}. Migrate reftable/record_test.c to the > > unit testing framework. Migration involves refactoring the tests > > to use the unit testing framework instead of reftable's test > > framework. > > While at it, change the type of index variable 'i' to 'size_t' > > from 'int'. This is because 'i' is used in comparison against > > 'ARRAY_SIZE(x)' which is of type 'size_t'. > > > > Also, use set_hash() which is defined locally in the test file > > instead of set_test_hash() which is defined by > > reftable/test_framework.{c, h}. This is fine to do as both these > > functions are similarly implemented, and > > reftable/test_framework.{c, h} is not #included in the ported test. > > > > Mentored-by: Patrick Steinhardt <ps@xxxxxx> > > Mentored-by: Christian Couder <chriscool@xxxxxxxxxxxxx> > > Signed-off-by: Chandra Pratap <chandrapratap3519@xxxxxxxxx> > > --- > > Makefile | 2 +- > > t/helper/test-reftable.c | 1 - > > .../unit-tests/t-reftable-record.c | 106 ++++++++---------- > > 3 files changed, 50 insertions(+), 59 deletions(-) > > rename reftable/record_test.c => t/unit-tests/t-reftable-record.c (77%) > > > > diff --git a/Makefile b/Makefile > > index f25b2e80a1..def3700b4d 100644 > > --- a/Makefile > > +++ b/Makefile > > @@ -1338,6 +1338,7 @@ UNIT_TEST_PROGRAMS += t-hash > > UNIT_TEST_PROGRAMS += t-mem-pool > > UNIT_TEST_PROGRAMS += t-prio-queue > > UNIT_TEST_PROGRAMS += t-reftable-basics > > +UNIT_TEST_PROGRAMS += t-reftable-record > > UNIT_TEST_PROGRAMS += t-strbuf > > UNIT_TEST_PROGRAMS += t-strcmp-offset > > UNIT_TEST_PROGRAMS += t-strvec > > @@ -2678,7 +2679,6 @@ REFTABLE_TEST_OBJS += reftable/block_test.o > > REFTABLE_TEST_OBJS += reftable/dump.o > > REFTABLE_TEST_OBJS += reftable/merged_test.o > > REFTABLE_TEST_OBJS += reftable/pq_test.o > > -REFTABLE_TEST_OBJS += reftable/record_test.o > > REFTABLE_TEST_OBJS += reftable/readwrite_test.o > > REFTABLE_TEST_OBJS += reftable/stack_test.o > > REFTABLE_TEST_OBJS += reftable/test_framework.o > > diff --git a/t/helper/test-reftable.c b/t/helper/test-reftable.c > > index 9160bc5da6..aa6538a8da 100644 > > --- a/t/helper/test-reftable.c > > +++ b/t/helper/test-reftable.c > > @@ -5,7 +5,6 @@ > > int cmd__reftable(int argc, const char **argv) > > { > > /* test from simple to complex. */ > > - record_test_main(argc, argv); > > block_test_main(argc, argv); > > tree_test_main(argc, argv); > > pq_test_main(argc, argv); > > diff --git a/reftable/record_test.c b/t/unit-tests/t-reftable-record.c > > similarity index 77% > > rename from reftable/record_test.c > > rename to t/unit-tests/t-reftable-record.c > > index 58290bdba3..1b357e6c7f 100644 > > --- a/reftable/record_test.c > > +++ b/t/unit-tests/t-reftable-record.c > > @@ -6,13 +6,9 @@ > > https://developers.google.com/open-source/licenses/bsd > > */ > > > > -#include "record.h" > > - > > -#include "system.h" > > -#include "basics.h" > > -#include "constants.h" > > -#include "test_framework.h" > > -#include "reftable-tests.h" > > +#include "test-lib.h" > > +#include "reftable/constants.h" > > +#include "reftable/record.h" > > > > static void test_copy(struct reftable_record *rec) > > { > > @@ -24,9 +20,9 @@ static void test_copy(struct reftable_record *rec) > > reftable_record_copy_from(©, rec, GIT_SHA1_RAWSZ); > > /* do it twice to catch memory leaks */ > > I'm curious why we do this, and if it is still needed. The original > commit (e303bf22f reftable: (de)serialization for the polymorphic record > type) doesn't mention any particular reasoning. Yeah, I was confused about this as well. I asked Patrick about it some time ago and it seems like he had no clue about it either: https://gitlab.slack.com/archives/C071PDKNCHM/p1717479205788209 Should we get rid of this after all? > > reftable_record_copy_from(©, rec, GIT_SHA1_RAWSZ); > > - EXPECT(reftable_record_equal(rec, ©, GIT_SHA1_RAWSZ)); > > + check(reftable_record_equal(rec, ©, GIT_SHA1_RAWSZ)); > > > > - puts("testing print coverage:\n"); > > + test_msg("testing print coverage:"); > > reftable_record_print(©, GIT_SHA1_RAWSZ); > > > > This prints for any test that uses this function. As I see from the > current usage of the testing library, we only print debug information > when we encounter something unexpected. > > This also clogs up the unit-test's output. So I would remove this from > here. That's true, but that would also mean the print functions are no longer exercised. Is that a fine tradeoff? > > reftable_record_release(©); > > @@ -43,8 +39,8 @@ static void test_varint_roundtrip(void) > > 4096, > > ((uint64_t)1 << 63), > > ((uint64_t)1 << 63) + ((uint64_t)1 << 63) - 1 }; > > - int i = 0; > > - for (i = 0; i < ARRAY_SIZE(inputs); i++) { > > + > > + for (size_t i = 0; i < ARRAY_SIZE(inputs); i++) { > > uint8_t dest[10]; > > > > struct string_view out = { > > @@ -55,29 +51,26 @@ static void test_varint_roundtrip(void) > > int n = put_var_int(&out, in); > > uint64_t got = 0; > > > > - EXPECT(n > 0); > > + check_int(n, >, 0); > > out.len = n; > > n = get_var_int(&got, &out); > > - EXPECT(n > 0); > > + check_int(n, >, 0); > > > > - EXPECT(got == in); > > + check_int(got, ==, in); > > } > > } > > > > static void set_hash(uint8_t *h, int j) > > { > > - int i = 0; > > - for (i = 0; i < hash_size(GIT_SHA1_FORMAT_ID); i++) { > > + for (int i = 0; i < hash_size(GIT_SHA1_FORMAT_ID); i++) > > h[i] = (j >> i) & 0xff; > > - } > > } > > > > static void test_reftable_ref_record_roundtrip(void) > > { > > struct strbuf scratch = STRBUF_INIT; > > - int i = 0; > > > > - for (i = REFTABLE_REF_DELETION; i < REFTABLE_NR_REF_VALUETYPES; i++) { > > + for (int i = REFTABLE_REF_DELETION; i < REFTABLE_NR_REF_VALUETYPES; i++) { > > struct reftable_record in = { > > .type = BLOCK_TYPE_REF, > > }; > > @@ -109,17 +102,17 @@ static void test_reftable_ref_record_roundtrip(void) > > > > test_copy(&in); > > > > - EXPECT(reftable_record_val_type(&in) == i); > > + check_int(reftable_record_val_type(&in), ==, i); > > > > reftable_record_key(&in, &key); > > n = reftable_record_encode(&in, dest, GIT_SHA1_RAWSZ); > > - EXPECT(n > 0); > > + check_int(n, >, 0); > > > > /* decode into a non-zero reftable_record to test for leaks. */ > > m = reftable_record_decode(&out, key, i, dest, GIT_SHA1_RAWSZ, &scratch); > > - EXPECT(n == m); > > + check_int(n, ==, m); > > > > - EXPECT(reftable_ref_record_equal(&in.u.ref, &out.u.ref, > > + check(reftable_ref_record_equal(&in.u.ref, &out.u.ref, > > GIT_SHA1_RAWSZ)); > > reftable_record_release(&in); > > > > @@ -143,16 +136,15 @@ static void test_reftable_log_record_equal(void) > > } > > }; > > > > - EXPECT(!reftable_log_record_equal(&in[0], &in[1], GIT_SHA1_RAWSZ)); > > + check(!reftable_log_record_equal(&in[0], &in[1], GIT_SHA1_RAWSZ)); > > in[1].update_index = in[0].update_index; > > - EXPECT(reftable_log_record_equal(&in[0], &in[1], GIT_SHA1_RAWSZ)); > > + check(reftable_log_record_equal(&in[0], &in[1], GIT_SHA1_RAWSZ)); > > reftable_log_record_release(&in[0]); > > reftable_log_record_release(&in[1]); > > } > > > > static void test_reftable_log_record_roundtrip(void) > > { > > - int i; > > struct reftable_log_record in[] = { > > { > > .refname = xstrdup("refs/heads/master"), > > @@ -180,12 +172,12 @@ static void test_reftable_log_record_roundtrip(void) > > } > > }; > > struct strbuf scratch = STRBUF_INIT; > > + set_hash(in[0].value.update.new_hash, 1); > > + set_hash(in[0].value.update.old_hash, 2); > > + set_hash(in[2].value.update.new_hash, 3); > > + set_hash(in[2].value.update.old_hash, 4); > > > > - set_test_hash(in[0].value.update.new_hash, 1); > > - set_test_hash(in[0].value.update.old_hash, 2); > > - set_test_hash(in[2].value.update.new_hash, 3); > > - set_test_hash(in[2].value.update.old_hash, 4); > > - for (i = 0; i < ARRAY_SIZE(in); i++) { > > + for (size_t i = 0; i < ARRAY_SIZE(in); i++) { > > struct reftable_record rec = { .type = BLOCK_TYPE_LOG }; > > struct strbuf key = STRBUF_INIT; > > uint8_t buffer[1024] = { 0 }; > > @@ -217,13 +209,13 @@ static void test_reftable_log_record_roundtrip(void) > > reftable_record_key(&rec, &key); > > > > n = reftable_record_encode(&rec, dest, GIT_SHA1_RAWSZ); > > - EXPECT(n >= 0); > > + check_int(n, >=, 0); > > valtype = reftable_record_val_type(&rec); > > m = reftable_record_decode(&out, key, valtype, dest, > > GIT_SHA1_RAWSZ, &scratch); > > - EXPECT(n == m); > > + check_int(n, ==, m); > > > > - EXPECT(reftable_log_record_equal(&in[i], &out.u.log, > > + check(reftable_log_record_equal(&in[i], &out.u.log, > > GIT_SHA1_RAWSZ)); > > reftable_log_record_release(&in[i]); > > strbuf_release(&key); > > @@ -252,14 +244,14 @@ static void test_key_roundtrip(void) > > strbuf_addstr(&key, "refs/tags/bla"); > > extra = 6; > > n = reftable_encode_key(&restart, dest, last_key, key, extra); > > - EXPECT(!restart); > > - EXPECT(n > 0); > > + check(!restart); > > + check_int(n, >, 0); > > > > strbuf_addstr(&roundtrip, "refs/heads/master"); > > m = reftable_decode_key(&roundtrip, &rt_extra, dest); > > - EXPECT(n == m); > > - EXPECT(0 == strbuf_cmp(&key, &roundtrip)); > > - EXPECT(rt_extra == extra); > > + check_int(n, ==, m); > > + check(!strbuf_cmp(&key, &roundtrip)); > > + check_int(rt_extra, ==, extra); > > > > strbuf_release(&last_key); > > strbuf_release(&key); > > @@ -289,9 +281,8 @@ static void test_reftable_obj_record_roundtrip(void) > > }, > > }; > > struct strbuf scratch = STRBUF_INIT; > > - int i = 0; > > > > - for (i = 0; i < ARRAY_SIZE(recs); i++) { > > + for (size_t i = 0; i < ARRAY_SIZE(recs); i++) { > > uint8_t buffer[1024] = { 0 }; > > struct string_view dest = { > > .buf = buffer, > > @@ -311,13 +302,13 @@ static void test_reftable_obj_record_roundtrip(void) > > test_copy(&in); > > reftable_record_key(&in, &key); > > n = reftable_record_encode(&in, dest, GIT_SHA1_RAWSZ); > > - EXPECT(n > 0); > > + check_int(n, >, 0); > > extra = reftable_record_val_type(&in); > > m = reftable_record_decode(&out, key, extra, dest, > > GIT_SHA1_RAWSZ, &scratch); > > - EXPECT(n == m); > > + check_int(n, ==, m); > > > > - EXPECT(reftable_record_equal(&in, &out, GIT_SHA1_RAWSZ)); > > + check(reftable_record_equal(&in, &out, GIT_SHA1_RAWSZ)); > > strbuf_release(&key); > > reftable_record_release(&out); > > } > > @@ -352,16 +343,16 @@ static void test_reftable_index_record_roundtrip(void) > > reftable_record_key(&in, &key); > > test_copy(&in); > > > > - EXPECT(0 == strbuf_cmp(&key, &in.u.idx.last_key)); > > + check(!strbuf_cmp(&key, &in.u.idx.last_key)); > > n = reftable_record_encode(&in, dest, GIT_SHA1_RAWSZ); > > - EXPECT(n > 0); > > + check_int(n, >, 0); > > > > extra = reftable_record_val_type(&in); > > m = reftable_record_decode(&out, key, extra, dest, GIT_SHA1_RAWSZ, > > &scratch); > > - EXPECT(m == n); > > + check_int(m, ==, n); > > > > - EXPECT(reftable_record_equal(&in, &out, GIT_SHA1_RAWSZ)); > > + check(reftable_record_equal(&in, &out, GIT_SHA1_RAWSZ)); > > > > reftable_record_release(&out); > > strbuf_release(&key); > > @@ -369,14 +360,15 @@ static void test_reftable_index_record_roundtrip(void) > > strbuf_release(&in.u.idx.last_key); > > } > > > > -int record_test_main(int argc, const char *argv[]) > > +int cmd_main(int argc, const char *argv[]) > > { > > - RUN_TEST(test_reftable_log_record_equal); > > - RUN_TEST(test_reftable_log_record_roundtrip); > > - RUN_TEST(test_reftable_ref_record_roundtrip); > > - RUN_TEST(test_varint_roundtrip); > > - RUN_TEST(test_key_roundtrip); > > - RUN_TEST(test_reftable_obj_record_roundtrip); > > - RUN_TEST(test_reftable_index_record_roundtrip); > > - return 0; > > + TEST(test_reftable_log_record_equal(), "reftable_log_record_equal works"); > > + TEST(test_reftable_log_record_roundtrip(), "record operations work on log record"); > > + TEST(test_reftable_ref_record_roundtrip(), "record operations work on ref record"); > > + TEST(test_varint_roundtrip(), "put_var_int and get_var_int work"); > > + TEST(test_key_roundtrip(), "reftable_encode_key and reftable_decode_key work"); > > + TEST(test_reftable_obj_record_roundtrip(), "record operations work on obj record"); > > + TEST(test_reftable_index_record_roundtrip(), "record operations work on index record"); > > + > > All other tests in the 'unit-tests/' folder use a `t_<name>` format for > the tests. Here we seem to diverge and use a `test_<name>` format. I > think the best outcome would be some documentation around this, but it > would still be nice if we follow this pattern nevertheless. > > > + return test_done(); > > } > > -- > > 2.45.2.404.g9eaef5822c