From: Phillip Wood <phillip.wood123@gmail.com>
To: Patrick Steinhardt <ps@pks.im>, git@vger.kernel.org
Cc: "René Scharfe" <l.s.r@web.de>,
"Junio C Hamano" <gitster@pobox.com>,
"Kyle Lippincott" <spectral@google.com>,
"Phillip Wood" <phillip.wood@dunelm.org.uk>,
"Josh Steadmon" <steadmon@google.com>,
rsbecker@nexbridge.com,
"Edward Thomson" <ethomson@edwardthomson.com>,
"Johannes Schindelin" <Johannes.Schindelin@gmx.de>
Subject: Re: [PATCH v7 00/14] Introduce clar testing framework
Date: Wed, 4 Sep 2024 14:35:33 +0100 [thread overview]
Message-ID: <b177ffce-f5cb-4df9-8b81-79128f9185d0@gmail.com> (raw)
In-Reply-To: <cover.1725349234.git.ps@pks.im>
Hi Patrick
On 03/09/2024 10:14, Patrick Steinhardt wrote:
> Hi,
>
> this is the seventh version fo my patch series that introduces the clar
> unit testing framework.
>
> Changes compared to v6:
>
> - Add some explanations for why we introduce clar in the first place
> to the second commit message.
>
> - Split out implementation of the test driver, that is the main
> function, into a separate commit.
>
> - Reimplement argument parsing ourselves. This allows more flexibility
> and gets rid of some options that do not make sense for us.
>
> - Add an empty line between declarations and code.
>
> - Improve the test messages in ctype tests to also mention our
> expectations.
>
> - Adapt `cl_failf()` to not use `xstrfmt()`, but `snprintf()` with a
> static buffer instead.
I've left some comments on patch 11 which is new. Apart from that
range-diff looks fine to me.
Thanks for working on this
Phillip
> Thanks!
>
> Patrick
>
> Johannes Schindelin (4):
> clar: avoid compile error with mingw-w64
> clar(win32): avoid compile error due to unused `fs_copy()`
> clar: stop including `shellapi.h` unnecessarily
> clar: add CMake support
>
> Patrick Steinhardt (10):
> t: do not pass GIT_TEST_OPTS to unit tests with prove
> t: import the clar unit testing framework
> t/clar: fix compatibility with NonStop
> Makefile: fix sparse dependency on GENERATED_H
> Makefile: make hdr-check depend on generated headers
> Makefile: do not use sparse on third-party sources
> Makefile: wire up the clar unit testing framework
> t/unit-tests: implement test driver
> t/unit-tests: convert strvec tests to use clar
> t/unit-tests: convert ctype tests to use clar
>
> .gitignore | 1 +
> Documentation/technical/unit-tests.txt | 2 +
> Makefile | 53 +-
> contrib/buildsystems/CMakeLists.txt | 53 ++
> t/Makefile | 4 +-
> t/run-test.sh | 2 +-
> t/unit-tests/.gitignore | 2 +
> t/unit-tests/clar-generate.awk | 50 ++
> t/unit-tests/clar/.github/workflows/ci.yml | 23 +
> t/unit-tests/clar/COPYING | 15 +
> t/unit-tests/clar/README.md | 329 ++++++++
> t/unit-tests/clar/clar.c | 842 +++++++++++++++++++++
> t/unit-tests/clar/clar.h | 173 +++++
> t/unit-tests/clar/clar/fixtures.h | 50 ++
> t/unit-tests/clar/clar/fs.h | 524 +++++++++++++
> t/unit-tests/clar/clar/print.h | 211 ++++++
> t/unit-tests/clar/clar/sandbox.h | 159 ++++
> t/unit-tests/clar/clar/summary.h | 143 ++++
> t/unit-tests/clar/generate.py | 266 +++++++
> t/unit-tests/clar/test/.gitignore | 4 +
> t/unit-tests/clar/test/Makefile | 39 +
> t/unit-tests/clar/test/clar_test.h | 16 +
> t/unit-tests/clar/test/main.c | 40 +
> t/unit-tests/clar/test/main.c.sample | 27 +
> t/unit-tests/clar/test/resources/test/file | 1 +
> t/unit-tests/clar/test/sample.c | 84 ++
> t/unit-tests/{t-ctype.c => ctype.c} | 71 +-
> t/unit-tests/strvec.c | 241 ++++++
> t/unit-tests/t-strvec.c | 211 ------
> t/unit-tests/unit-test.c | 45 ++
> t/unit-tests/unit-test.h | 10 +
> 31 files changed, 3457 insertions(+), 234 deletions(-)
> create mode 100644 t/unit-tests/clar-generate.awk
> create mode 100644 t/unit-tests/clar/.github/workflows/ci.yml
> create mode 100644 t/unit-tests/clar/COPYING
> create mode 100644 t/unit-tests/clar/README.md
> create mode 100644 t/unit-tests/clar/clar.c
> create mode 100644 t/unit-tests/clar/clar.h
> create mode 100644 t/unit-tests/clar/clar/fixtures.h
> create mode 100644 t/unit-tests/clar/clar/fs.h
> create mode 100644 t/unit-tests/clar/clar/print.h
> create mode 100644 t/unit-tests/clar/clar/sandbox.h
> create mode 100644 t/unit-tests/clar/clar/summary.h
> create mode 100755 t/unit-tests/clar/generate.py
> create mode 100644 t/unit-tests/clar/test/.gitignore
> create mode 100644 t/unit-tests/clar/test/Makefile
> create mode 100644 t/unit-tests/clar/test/clar_test.h
> create mode 100644 t/unit-tests/clar/test/main.c
> create mode 100644 t/unit-tests/clar/test/main.c.sample
> create mode 100644 t/unit-tests/clar/test/resources/test/file
> create mode 100644 t/unit-tests/clar/test/sample.c
> rename t/unit-tests/{t-ctype.c => ctype.c} (68%)
> create mode 100644 t/unit-tests/strvec.c
> delete mode 100644 t/unit-tests/t-strvec.c
> create mode 100644 t/unit-tests/unit-test.c
> create mode 100644 t/unit-tests/unit-test.h
>
> Range-diff against v6:
> 1: e48a6461137 = 1: b67f10ec0b0 t: do not pass GIT_TEST_OPTS to unit tests with prove
> 2: 1710e9f9ff7 ! 2: 55a9b46e65f t: import the clar unit testing framework
> @@ Metadata
> ## Commit message ##
> t: import the clar unit testing framework
>
> + Our unit testing framework is a homegrown solution. While it supports
> + most of our needs, it is likely that the volume of unit tests will grow
> + quite a bit in the future such that we can exercise low-level subsystems
> + directly. This surfaces several shortcomings that the current solution
> + has:
> +
> + - There is no way to run only one specific tests. While some of our
> + unit tests wire this up manually, others don't. In general, it
> + requires quite a bit of boilerplate to get this set up correctly.
> +
> + - Failures do not cause a test to stop execution directly. Instead,
> + the test author needs to return manually whenever an assertion
> + fails. This is rather verbose and is not done correctly in most of
> + our unit tests.
> +
> + - Wiring up a new testcase requires both implementing the test
> + function and calling it in the respective test suite's main
> + function, which is creating code duplication.
> +
> + We can of course fix all of these issues ourselves, but that feels
> + rather pointless when there are already so many unit testing frameworks
> + out there that have those features.
> +
> + We line out some requirements for any unit testing framework in
> + "Documentation/technical/unit-tests.txt". The "clar" unit testing
> + framework, which isn't listed in that table yet, ticks many of the
> + boxes:
> +
> + - It is licensed under ISC, which is compatible.
> +
> + - It is easily vendorable because it is rather tiny at around 1200
> + lines of code.
> +
> + - It is easily hackable due to the same reason.
> +
> + - It has TAP support.
> +
> + - It has skippable tests.
> +
> + - It preprocesses test files in order to extract test functions, which
> + then get wired up automatically.
> +
> + While it's not perfect, the fact that clar originates from the libgit2
> + project means that it should be rather easy for us to collaborate with
> + upstream to plug any gaps.
> +
> Import the clar unit testing framework at commit 1516124 (Merge pull
> request #97 from pks-t/pks-whitespace-fixes, 2024-08-15). The framework
> will be wired up in subsequent commits.
> 3: 5c21aa87aa2 = 3: f24401f0a87 t/clar: fix compatibility with NonStop
> 4: 06d2bce0d82 = 4: 658a601c541 clar: avoid compile error with mingw-w64
> 5: f88b3421a09 = 5: 0b8a6ac5fed clar(win32): avoid compile error due to unused `fs_copy()`
> 6: 5fb4c55be33 = 6: c50e7a0ea68 clar: stop including `shellapi.h` unnecessarily
> 7: e0dcbd5ca83 = 7: b8f3f16dd27 Makefile: fix sparse dependency on GENERATED_H
> 8: 77a03f8df70 = 8: 3d3fe443b9a Makefile: make hdr-check depend on generated headers
> 9: c91dd7327e3 = 9: 7d0f494850a Makefile: do not use sparse on third-party sources
> 10: 115c15aa9ae ! 10: 9c74c5ae019 Makefile: wire up the clar unit testing framework
> @@ Commit message
> anything. Thus, it would cause a compiler error if a function name was
> mistyped and thus not picked up by "generate.py".
>
> + The test driver "unit-test.c" is an empty stub for now. It will get
> + implemented in the next commit.
> +
> Signed-off-by: Patrick Steinhardt <ps@pks.im>
>
> ## .gitignore ##
> @@ t/unit-tests/unit-test.c (new)
> @@
> +#include "unit-test.h"
> +
> -+int cmd_main(int argc, const char **argv)
> ++int cmd_main(int argc UNUSED, const char **argv UNUSED)
> +{
> -+ const char **argv_copy;
> -+ int ret;
> -+
> -+ /* Append the "-t" flag such that the tests generate TAP output. */
> -+ ALLOC_ARRAY(argv_copy, argc + 2);
> -+ COPY_ARRAY(argv_copy, argv, argc);
> -+ argv_copy[argc++] = "-t";
> -+ argv_copy[argc] = NULL;
> -+
> -+ ret = clar_test(argc, (char **) argv_copy);
> -+
> -+ free(argv_copy);
> -+ return ret;
> ++ return 0;
> +}
>
> ## t/unit-tests/unit-test.h (new) ##
> -: ----------- > 11: 8bd5b3e2b29 t/unit-tests: implement test driver
> 11: b3b8df04872 ! 12: 3c3b9eacdfb t/unit-tests: convert strvec tests to use clar
> @@ Commit message
> clar-based tests looks like.
>
> The tests are part of the "t/unit-tests/bin/unit-tests" binary. When
> - running that binary, it generates TAP output:
> + running that binary with an injected error, it generates TAP output:
>
> # ./t/unit-tests/bin/unit-tests
> TAP version 13
> @@ Commit message
> ok 1 - strvec::init
> ok 2 - strvec::dynamic_init
> ok 3 - strvec::clear
> - ok 4 - strvec::push
> - ok 5 - strvec::pushft_pushf
> + not ok 4 - strvec::push
> + ---
> + reason: |
> + String mismatch: (&vec)->v[i] != expect[i]
> + 'foo' != 'fo' (at byte 2)
> + at:
> + file: 't/unit-tests/strvec.c'
> + line: 48
> + function: 'test_strvec__push'
> + ---
> + ok 5 - strvec::pushf
> ok 6 - strvec::pushl
> ok 7 - strvec::pushv
> ok 8 - strvec::replace_at_head
> @@ t/unit-tests/strvec.c (new)
> +#define check_strvec(vec, ...) \
> + do { \
> + const char *expect[] = { __VA_ARGS__ }; \
> -+ cl_assert(ARRAY_SIZE(expect) > 0); \
> -+ cl_assert_equal_p(expect[ARRAY_SIZE(expect) - 1], NULL); \
> -+ cl_assert_equal_i((vec)->nr, ARRAY_SIZE(expect) - 1); \
> ++ size_t expect_len = ARRAY_SIZE(expect); \
> ++ cl_assert(expect_len > 0); \
> ++ cl_assert_equal_p(expect[expect_len - 1], NULL); \
> ++ cl_assert_equal_i((vec)->nr, expect_len - 1); \
> + cl_assert((vec)->nr <= (vec)->alloc); \
> -+ for (size_t i = 0; i < ARRAY_SIZE(expect); i++) \
> ++ for (size_t i = 0; i < expect_len; i++) \
> + cl_assert_equal_s((vec)->v[i], expect[i]); \
> + } while (0)
> +
> +void test_strvec__init(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + cl_assert_equal_p(vec.v, empty_strvec);
> + cl_assert_equal_i(vec.nr, 0);
> + cl_assert_equal_i(vec.alloc, 0);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__dynamic_init(void)
> +{
> + struct strvec vec;
> ++
> + strvec_init(&vec);
> + cl_assert_equal_p(vec.v, empty_strvec);
> + cl_assert_equal_i(vec.nr, 0);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__clear(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_push(&vec, "foo");
> + strvec_clear(&vec);
> + cl_assert_equal_p(vec.v, empty_strvec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__pushf(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushf(&vec, "foo: %d", 1);
> + check_strvec(&vec, "foo: 1", NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__pushl(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + check_strvec(&vec, "foo", "bar", "baz", NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__replace_at_head(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + strvec_replace(&vec, 0, "replaced");
> + check_strvec(&vec, "replaced", "bar", "baz", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__replace_in_between(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + strvec_replace(&vec, 1, "replaced");
> + check_strvec(&vec, "foo", "replaced", "baz", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__replace_with_substring(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", NULL);
> + strvec_replace(&vec, 0, vec.v[0] + 1);
> + check_strvec(&vec, "oo", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__remove_at_head(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + strvec_remove(&vec, 0);
> + check_strvec(&vec, "bar", "baz", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__remove_at_tail(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + strvec_remove(&vec, 2);
> + check_strvec(&vec, "foo", "bar", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__remove_in_between(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + strvec_remove(&vec, 1);
> + check_strvec(&vec, "foo", "baz", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__pop_empty_array(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pop(&vec);
> + check_strvec(&vec, NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__pop_non_empty_array(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_pushl(&vec, "foo", "bar", "baz", NULL);
> + strvec_pop(&vec);
> + check_strvec(&vec, "foo", "bar", NULL);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__split_empty_string(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_split(&vec, "");
> + check_strvec(&vec, NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__split_single_item(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_split(&vec, "foo");
> + check_strvec(&vec, "foo", NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__split_multiple_items(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_split(&vec, "foo bar baz");
> + check_strvec(&vec, "foo", "bar", "baz", NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__split_whitespace_only(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_split(&vec, " \t\n");
> + check_strvec(&vec, NULL);
> + strvec_clear(&vec);
> @@ t/unit-tests/strvec.c (new)
> +void test_strvec__split_multiple_consecutive_whitespaces(void)
> +{
> + struct strvec vec = STRVEC_INIT;
> ++
> + strvec_split(&vec, "foo\n\t bar");
> + check_strvec(&vec, "foo", "bar", NULL);
> + strvec_clear(&vec);
> 12: 1ac2e48a7f2 ! 13: c8360db2f86 t/unit-tests: convert ctype tests to use clar
> @@ Commit message
> on failure:
>
> # start of suite 1: ctype
> - ok 1 - ctype::isspace
> - not ok 2 - ctype::isdigit
> + not ok 1 - ctype::isspace
> ---
> reason: |
> Test failed.
> - 0x61 is classified incorrectly
> + 0x0d is classified incorrectly: expected 0, got 1
> at:
> file: 't/unit-tests/ctype.c'
> - line: 38
> - function: 'test_ctype__isdigit'
> + line: 36
> + function: 'test_ctype__isspace'
> ---
> + ok 2 - ctype::isdigit
> ok 3 - ctype::isalpha
> ok 4 - ctype::isalnum
> ok 5 - ctype::is_glob_special
> @@ t/unit-tests/t-ctype.c => t/unit-tests/ctype.c
> - test_msg(" i: 0x%02x", i); \
> - } \
> - check(!class(EOF)); \
> -- } \
> -+ for (int i = 0; i < 256; i++) \
> -+ if (class(i) != !!memchr(string, i, len)) \
> -+ cl_failf("0x%02x is classified incorrectly", i); \
> ++ for (int i = 0; i < 256; i++) { \
> ++ int actual = class(i), expect = !!memchr(string, i, len); \
> ++ if (actual != expect) \
> ++ cl_failf("0x%02x is classified incorrectly: expected %d, got %d", \
> ++ i, expect, actual); \
> + } \
> + cl_assert(!class(EOF)); \
> } while (0)
>
> @@ t/unit-tests/unit-test.h
> +#include "strbuf.h"
> +
> +#define cl_failf(fmt, ...) do { \
> -+ char *desc = xstrfmt(fmt, __VA_ARGS__); \
> ++ char desc[4096]; \
> ++ snprintf(desc, sizeof(desc), fmt, __VA_ARGS__); \
> + clar__fail(__FILE__, __func__, __LINE__, "Test failed.", desc, 1); \
> -+ free(desc); \
> +} while (0)
> 13: 131036c398e = 14: d51c146cd9d clar: add CMake support
next prev parent reply other threads:[~2024-09-04 13:35 UTC|newest]
Thread overview: 172+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-07-31 9:04 [RFC PATCH 0/3] Introduce clar testing framework Patrick Steinhardt
2024-07-31 9:04 ` [RFC PATCH 1/3] t: import the clar unit " Patrick Steinhardt
2024-07-31 18:27 ` Josh Steadmon
2024-07-31 19:36 ` Junio C Hamano
2024-08-01 9:32 ` Patrick Steinhardt
2024-07-31 20:04 ` rsbecker
2024-08-01 9:31 ` Patrick Steinhardt
2024-08-01 12:15 ` rsbecker
2024-08-01 12:54 ` rsbecker
2024-08-01 13:37 ` Patrick Steinhardt
2024-08-01 13:47 ` rsbecker
2024-08-01 13:50 ` Patrick Steinhardt
2024-08-01 13:53 ` rsbecker
2024-08-01 13:55 ` Patrick Steinhardt
2024-08-01 14:04 ` rsbecker
2024-08-01 14:43 ` Patrick Steinhardt
2024-08-01 16:31 ` rsbecker
2024-08-01 17:06 ` rsbecker
2024-08-01 17:43 ` [RFC PATCH 1/3] t: import the clar unit testing framework (better one) rsbecker
2024-08-01 18:12 ` René Scharfe
2024-08-01 18:33 ` rsbecker
2024-07-31 9:04 ` [RFC PATCH 2/3] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-07-31 16:48 ` René Scharfe
2024-08-01 9:32 ` Patrick Steinhardt
2024-07-31 17:01 ` Junio C Hamano
2024-07-31 21:39 ` Junio C Hamano
2024-08-01 9:32 ` Patrick Steinhardt
2024-07-31 9:04 ` [RFC PATCH 3/3] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-07-31 15:51 ` [RFC PATCH 0/3] Introduce clar testing framework Junio C Hamano
2024-07-31 15:56 ` rsbecker
2024-07-31 16:52 ` Junio C Hamano
2024-07-31 20:25 ` rsbecker
2024-07-31 20:37 ` rsbecker
2024-08-01 9:31 ` Patrick Steinhardt
2024-08-01 9:31 ` Patrick Steinhardt
2024-07-31 18:33 ` Josh Steadmon
2024-08-01 9:31 ` Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 0/7] " Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 1/7] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 2/7] t: import the clar unit testing framework Patrick Steinhardt
2024-08-06 22:18 ` Josh Steadmon
2024-08-07 5:52 ` Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 3/7] t/clar: fix whitespace errors Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 4/7] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 5/7] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-08-06 14:14 ` [RFC PATCH v2 6/7] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-08-06 23:05 ` Josh Steadmon
2024-08-07 5:52 ` Patrick Steinhardt
2024-08-06 14:15 ` [RFC PATCH v2 7/7] t/unit-tests: convert ctype " Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 0/7] Introduce clar testing framework Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 1/7] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 2/7] t: import the clar unit testing framework Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 3/7] t/clar: fix whitespace errors Patrick Steinhardt
2024-08-13 15:25 ` Junio C Hamano
2024-08-13 15:31 ` rsbecker
2024-08-13 18:43 ` Junio C Hamano
2024-08-13 19:14 ` rsbecker
2024-08-13 20:42 ` Junio C Hamano
2024-08-14 5:58 ` Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 4/7] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 5/7] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 6/7] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-08-08 5:38 ` [RFC PATCH v3 7/7] t/unit-tests: convert ctype " Patrick Steinhardt
2024-08-12 18:10 ` [RFC PATCH v3 0/7] Introduce clar testing framework Josh Steadmon
2024-08-12 18:13 ` rsbecker
2024-08-12 20:50 ` Junio C Hamano
2024-08-12 20:58 ` rsbecker
2024-08-12 22:13 ` Junio C Hamano
2024-08-13 7:23 ` Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 " Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 1/7] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 2/7] t: import the clar unit testing framework Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 3/7] t/clar: fix whitespace errors Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 4/7] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 5/7] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 6/7] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-08-15 9:47 ` [PATCH v4 7/7] t/unit-tests: convert ctype " Patrick Steinhardt
2024-08-15 16:21 ` [PATCH v4 0/7] Introduce clar testing framework Junio C Hamano
2024-08-16 5:10 ` Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 0/9] " Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 1/9] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 2/9] t: import the clar unit testing framework Patrick Steinhardt
2024-08-16 13:37 ` Phillip Wood
2024-08-23 12:16 ` Johannes Schindelin
2024-08-28 13:20 ` Phillip Wood
2024-08-19 21:21 ` Junio C Hamano
2024-08-19 21:50 ` rsbecker
2024-08-19 22:13 ` Junio C Hamano
2024-08-19 22:38 ` rsbecker
2024-08-20 12:59 ` Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 3/9] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 4/9] Makefile: fix sparse dependency on GENERATED_H Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 5/9] Makefile: make hdr-check depend on generated headers Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 6/9] Makefile: do not use sparse on third-party sources Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 7/9] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-08-16 7:04 ` [PATCH v5 8/9] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-08-16 13:38 ` Phillip Wood
2024-08-16 16:11 ` Junio C Hamano
2024-08-20 12:59 ` Patrick Steinhardt
2024-08-16 7:05 ` [PATCH v5 9/9] t/unit-tests: convert ctype " Patrick Steinhardt
2024-08-16 13:38 ` Phillip Wood
2024-08-20 12:59 ` Patrick Steinhardt
2024-08-18 6:39 ` Junio C Hamano
2024-08-16 13:37 ` [PATCH v5 0/9] Introduce clar testing framework Phillip Wood
2024-08-20 12:59 ` Patrick Steinhardt
2024-08-28 15:15 ` phillip.wood123
2024-08-20 14:02 ` [PATCH v6 00/13] " Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 01/13] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 02/13] t: import the clar unit testing framework Patrick Steinhardt
2024-08-28 13:16 ` Phillip Wood
2024-09-03 7:45 ` Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 03/13] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 04/13] clar: avoid compile error with mingw-w64 Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 05/13] clar(win32): avoid compile error due to unused `fs_copy()` Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 06/13] clar: stop including `shellapi.h` unnecessarily Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 07/13] Makefile: fix sparse dependency on GENERATED_H Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 08/13] Makefile: make hdr-check depend on generated headers Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 09/13] Makefile: do not use sparse on third-party sources Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 10/13] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 11/13] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-08-28 13:17 ` Phillip Wood
2024-09-03 7:45 ` Patrick Steinhardt
2024-09-03 9:48 ` phillip.wood123
2024-09-04 6:37 ` Patrick Steinhardt
2024-09-04 9:31 ` phillip.wood123
2024-08-20 14:02 ` [PATCH v6 12/13] t/unit-tests: convert ctype " Patrick Steinhardt
2024-08-28 13:18 ` Phillip Wood
2024-09-03 7:45 ` Patrick Steinhardt
2024-08-20 14:02 ` [PATCH v6 13/13] clar: add CMake support Patrick Steinhardt
2024-08-28 13:18 ` [PATCH v6 00/13] Introduce clar testing framework Phillip Wood
2024-08-28 14:03 ` Patrick Steinhardt
2024-08-28 14:58 ` phillip.wood123
2024-09-03 9:14 ` [PATCH v7 00/14] " Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 01/14] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 02/14] t: import the clar unit testing framework Patrick Steinhardt
2024-09-03 9:47 ` Eric Sunshine
2024-09-04 6:38 ` Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 03/14] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 04/14] clar: avoid compile error with mingw-w64 Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 05/14] clar(win32): avoid compile error due to unused `fs_copy()` Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 06/14] clar: stop including `shellapi.h` unnecessarily Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 07/14] Makefile: fix sparse dependency on GENERATED_H Patrick Steinhardt
2024-09-03 9:14 ` [PATCH v7 08/14] Makefile: make hdr-check depend on generated headers Patrick Steinhardt
2024-09-03 9:15 ` [PATCH v7 09/14] Makefile: do not use sparse on third-party sources Patrick Steinhardt
2024-09-03 9:15 ` [PATCH v7 10/14] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-09-03 9:15 ` [PATCH v7 11/14] t/unit-tests: implement test driver Patrick Steinhardt
2024-09-04 13:35 ` Phillip Wood
2024-09-04 14:12 ` Patrick Steinhardt
2024-09-04 14:35 ` phillip.wood123
2024-09-03 9:15 ` [PATCH v7 12/14] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-09-03 9:15 ` [PATCH v7 13/14] t/unit-tests: convert ctype " Patrick Steinhardt
2024-09-03 9:15 ` [PATCH v7 14/14] clar: add CMake support Patrick Steinhardt
2024-09-04 13:35 ` Phillip Wood [this message]
2024-09-04 14:12 ` [PATCH v7 00/14] Introduce clar testing framework Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 " Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 01/14] t: do not pass GIT_TEST_OPTS to unit tests with prove Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 02/14] t: import the clar unit testing framework Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 03/14] t/clar: fix compatibility with NonStop Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 04/14] clar: avoid compile error with mingw-w64 Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 05/14] clar(win32): avoid compile error due to unused `fs_copy()` Patrick Steinhardt
2024-09-04 14:16 ` [PATCH v8 06/14] clar: stop including `shellapi.h` unnecessarily Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 07/14] Makefile: fix sparse dependency on GENERATED_H Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 08/14] Makefile: make hdr-check depend on generated headers Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 09/14] Makefile: do not use sparse on third-party sources Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 10/14] Makefile: wire up the clar unit testing framework Patrick Steinhardt
2024-09-09 18:17 ` Junio C Hamano
2024-09-10 6:20 ` Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 11/14] t/unit-tests: implement test driver Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 12/14] t/unit-tests: convert strvec tests to use clar Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 13/14] t/unit-tests: convert ctype " Patrick Steinhardt
2024-09-04 14:17 ` [PATCH v8 14/14] clar: add CMake support Patrick Steinhardt
2024-09-04 14:32 ` [PATCH v8 00/14] Introduce clar testing framework phillip.wood123
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=b177ffce-f5cb-4df9-8b81-79128f9185d0@gmail.com \
--to=phillip.wood123@gmail.com \
--cc=Johannes.Schindelin@gmx.de \
--cc=ethomson@edwardthomson.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=l.s.r@web.de \
--cc=phillip.wood@dunelm.org.uk \
--cc=ps@pks.im \
--cc=rsbecker@nexbridge.com \
--cc=spectral@google.com \
--cc=steadmon@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).