[igt-dev] [PATCH 2/3] runner/runner_tests: Unit tests for binary-name-only testlist entries
Kamil Konieczny
kamil.konieczny at linux.intel.com
Tue Oct 24 16:53:50 UTC 2023
Hi Petri,
Please add a description here, see checkpatch.pl:
WARNING: Missing commit description - Add an appropriate one
On 2023-10-20 at 16:30:40 +0300, Petri Latvala wrote:
> Signed-off-by: Petri Latvala <adrinael at adrinael.net>
> ---
> runner/runner_tests.c | 70 +++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 70 insertions(+)
>
> diff --git a/runner/runner_tests.c b/runner/runner_tests.c
> index a7e968f85..e6024de11 100644
> --- a/runner/runner_tests.c
> +++ b/runner/runner_tests.c
> @@ -1810,6 +1810,76 @@ igt_main
> }
> }
>
> + igt_subtest_group {
> + const char testlisttext[] = "igt at successtest";
WARNING: const array should probably be static const
> + const char blocktext[] = "igt at successtest@first";
Same here.
> + struct job_list *list = malloc(sizeof(*list));
> + volatile int dirfd = -1;
WARNING: Use of volatile is usually wrong: see Documentation/process/volatile-considered-harmful.rst
Maybe static?
> + char dirname[] = "tmpdirXXXXXX";
> + volatile int listfd;
--------^
Same here.
> + volatile int blockfd;
--------^
Same here.
> + char listfilename[] = "tmplistXXXXXX";
> + char blockfilename[] = "tmpblockXXXXXX";
> +
> + igt_fixture {
> + igt_require(mkdtemp(dirname) != NULL);
> + rmdir(dirname);
> +
> + igt_require((listfd = mkstemp(listfilename)) >= 0);
> + igt_require(write(listfd, testlisttext, strlen(testlisttext)) == strlen(testlisttext));
> + igt_require((blockfd = mkstemp(blockfilename)) >= 0);
> + igt_require(write(blockfd, blocktext, strlen(blocktext)) == strlen(blocktext));
> + close(listfd);
> + close(blockfd);
> +
> + init_job_list(list);
> + }
> +
> + igt_subtest("only-binary-name-in-testlist") {
> + const char *argv[] = { "runner",
WARNING: char * array declaration might be better as static const
> + "--allow-non-root",
> + "--test-list", listfilename,
> + testdatadir,
> + dirname,
> + };
> +
> + igt_assert(parse_options(ARRAY_SIZE(argv), (char**)argv, settings));
ERROR: "(foo**)" should be "(foo **)"
> +
> + igt_assert(create_job_list(list, settings));
> + /* No multi-mode, binary has two subtests, should be normalized to have individual subtests */
> + igt_assert_eq(list->size, 2);
> + igt_assert_eq(list->entries[0].subtest_count, 1);
> + igt_assert_eq(list->entries[1].subtest_count, 1);
> + }
> +
> + igt_subtest("only-binary-name-in-testlist-with-blocks") {
> + const char *argv[] = { "runner",
WARNING: char * array declaration might be better as static const
> + "--allow-non-root",
> + "--test-list", listfilename,
> + "-b", blockfilename,
> + testdatadir,
> + dirname,
> + };
> +
> + igt_assert(parse_options(ARRAY_SIZE(argv), (char**)argv, settings));
ERROR: "(foo**)" should be "(foo **)"
Looks ok, tests passes.
Regards,
Kamil
> +
> + igt_assert(create_job_list(list, settings));
> + /* No multi-mode, binary has two subtests, one of them blocked */
> + igt_assert_eq(list->size, 1);
> + igt_assert_eq(list->entries[0].subtest_count, 1);
> + igt_assert_eqstr(list->entries[0].subtests[0], "second-subtest");
> + }
> +
> + igt_fixture {
> + unlink(listfilename);
> + unlink(blockfilename);
> + close(dirfd);
> + clear_directory(dirname);
> + free_job_list(list);
> + free(list);
> + }
> + }
> +
> igt_subtest_group {
> struct job_list *list = malloc(sizeof(*list));
> volatile int dirfd = -1;
> --
> 2.39.2
>
More information about the igt-dev
mailing list