Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp541385pxu; Thu, 15 Oct 2020 10:03:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx71QitQuaOxaw+ZGyjNUysboOVDFmWC+kSADLOrS0lBeQX5THhsEdmaxGb6pdsgx1zfeku X-Received: by 2002:a50:9ec6:: with SMTP id a64mr5316653edf.382.1602781425392; Thu, 15 Oct 2020 10:03:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602781425; cv=none; d=google.com; s=arc-20160816; b=C3InbRqX1AW4xx+iYxMEUJNAwHTVeJmeQ42P1KZYDFZUMxM1gGXJ95bV7aO1k0qGs/ xM/o6pzZEM03W79GWwMHjqm32OvaqtAU2LjA5A+fdxKhm6Umv8Z8bLsuKDb3VKqJr9fG ek/HMfJQkamUgdVWK2RZhDnw1WVuO++jWD4fZM1PEZwpRvv+k1IRNT2xo7yHBiWrW3mf utvTpfFnBeToSuDL79avQXODXPNVIQz2K3fTCEaYXyyLuDipCm7hVQYmVPXPKYrlAQRl ykGkQrRyTRknXPhfvUDztjP4R6jnz7L4clKc+WdD0dyP/luv5gVg2cR035gux+ZxNyuk kmPg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=pRJa+JTBxjpybniwHzuLNlcZWPVzh1B/YCuXreTnx1Y=; b=PjKxcjFJpAdN5mg4cKxmzFh19KZc0ZhOXJ7WaR5MOLZ16AJfm62haIt9R90gFEMesT iERYxcI3nTd6henG0RdaYz8NN12Od/GjC/QeVC0p+IxIhc1exYQm4I6iF1B9JLBeFXkc ++LWyoIxGY5/9Qk4IPIo0vBD27LdpriKuubzfOhjBNSLywmz6UMY4oljLYmKOlYkaNZR 93YoHlTlZn3yas9dyKDVzSU/jDWdyWIhovQcM7ZCj1Iity5E+o+qrrR8kgO/lxykzg7N +trLA9eu5f20KdbFMgWuBpKB7txXbHrxXkEXO7iAie0hzY8j+wO+i3x8Mt9KQkxUqR6h rArg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@massaru-org.20150623.gappssmtp.com header.s=20150623 header.b=MF80TclT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m27si2602474eji.326.2020.10.15.10.03.14; Thu, 15 Oct 2020 10:03:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@massaru-org.20150623.gappssmtp.com header.s=20150623 header.b=MF80TclT; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389933AbgJOQ5i (ORCPT + 99 others); Thu, 15 Oct 2020 12:57:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52026 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388946AbgJOQ5i (ORCPT ); Thu, 15 Oct 2020 12:57:38 -0400 Received: from mail-yb1-xb42.google.com (mail-yb1-xb42.google.com [IPv6:2607:f8b0:4864:20::b42]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 27626C061755 for ; Thu, 15 Oct 2020 09:57:36 -0700 (PDT) Received: by mail-yb1-xb42.google.com with SMTP id n142so2813768ybf.7 for ; Thu, 15 Oct 2020 09:57:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=massaru-org.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=pRJa+JTBxjpybniwHzuLNlcZWPVzh1B/YCuXreTnx1Y=; b=MF80TclTsq3KUYL4cHkQi8yGG5UzqcpzPJ6iZ65WadP7lnemhjnzWDQAsq3nQe+LIz x6eBsaMzJb70GjETfJQDvVBSmSg9ftHaoylzruLwATBVz/EDTMolvrbYshswR5WjAL04 MsjGzqzscfv7JGzomGofoqNAA0XrLOmNvsIS3h7ArfpkYjU9Iit6zTwgn6SvKFaga5R+ t6RtyCOMdUl0t4TwvnqJJzAMiZ1ogVV5C3Oa9i++g96guMzorVorq5n57I354OEyaqqR iy211+PiThigTCDqGfcJaoU2WI7x4k3CEGWXtyg4b8tkWd+Pae24chxgB7r3pLS81Urf uxPg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=pRJa+JTBxjpybniwHzuLNlcZWPVzh1B/YCuXreTnx1Y=; b=EhnXu08LYCV4ZSJD6lKqfBooZHPXx4JZqu85/e4Lg9SgB2yhiBh6rHFAanKCjTH8FK DvQDuifLEYFrxyTZnheSHfoncd/BQc+P1LFMNLjxVAdgQcDpmvIziy2QLaxKky6W6m0p EuRcVNzWTsLK3en90/qdaJwiIOmOyedOhZx44svpNnMTgnz6J7WSdNa8zZGDStS/q6Yl m0tK4PNunm2FhAbmBP6G+xyAE2A09iK5e7HkoDiQnGh/r+hcdSoxZ5Hd8EDIOpMhdnuY YwWx4pxp6DfSJIiO9uBmlL0vgFgsYTnhdsOrCARBM8rPXmbySc1x8ipDwcksTuH6lAHM v1Ig== X-Gm-Message-State: AOAM531qYbT29S1A8dIf9q2TZIg4C0LJc3NPGF/bhDywA2uRVhDojfPV J12dX31F5TKJkt4GjqRQt0kpzGWKUskXcsjExgBUmw== X-Received: by 2002:a25:2311:: with SMTP id j17mr6906084ybj.362.1602781055178; Thu, 15 Oct 2020 09:57:35 -0700 (PDT) MIME-Version: 1.0 References: <20200729201146.537433-1-vitor@massaru.org> In-Reply-To: From: Vitor Massaru Iha Date: Thu, 15 Oct 2020 13:56:59 -0300 Message-ID: Subject: Re: [PATCH] lib: kunit: add test_min_heap test conversion to KUnit To: Ian Rogers Cc: KUnit Development , "open list:KERNEL SELFTEST FRAMEWORK" , LKML , Brendan Higgins , Shuah Khan , linux-kernel-mentees@lists.linuxfoundation.org, Peter Zijlstra , Ingo Molnar Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ian, On Thu, Oct 15, 2020 at 1:30 PM Ian Rogers wrote: > > On Wed, Oct 14, 2020 at 4:49 PM Vitor Massaru Iha wrote: > > > > Hi Ian, > > > > > > On Wed, Jul 29, 2020 at 7:57 PM Ian Rogers wrote: > > > > > > On Wed, Jul 29, 2020 at 1:11 PM Vitor Massaru Iha wrote: > > > > > > > > This adds the conversion of the runtime tests of test_min_heap, > > > > from `lib/test_min_heap.c` to KUnit tests. > > > > > > > > Please apply this commit first (linux-kselftest/kunit-fixes): > > > > 3f37d14b8a3152441f36b6bc74000996679f0998 kunit: kunit_config: Fix parsing of CONFIG options with space > > > > > > Thanks for this, I'm a fan of testing frameworks :-) > > > > > > > Signed-off-by: Vitor Massaru Iha > > > > --- > > > > lib/Kconfig.debug | 29 ++++-- > > > > lib/Makefile | 2 +- > > > > lib/{test_min_heap.c => min_heap_kunit.c} | 117 ++++++++++++---------- > > > > 3 files changed, 83 insertions(+), 65 deletions(-) > > > > rename lib/{test_min_heap.c => min_heap_kunit.c} (60%) > > > > > > > > diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug > > > > index 9ad9210d70a1..46674fc4972c 100644 > > > > --- a/lib/Kconfig.debug > > > > +++ b/lib/Kconfig.debug > > > > @@ -1864,16 +1864,6 @@ config TEST_LIST_SORT > > > > > > > > If unsure, say N. > > > > > > > > -config TEST_MIN_HEAP > > > > - tristate "Min heap test" > > > > - depends on DEBUG_KERNEL || m > > > > - help > > > > - Enable this to turn on min heap function tests. This test is > > > > - executed only once during system boot (so affects only boot time), > > > > - or at module load time. > > > > - > > > > - If unsure, say N. > > > > - > > > > config TEST_SORT > > > > tristate "Array-based sort test" > > > > depends on DEBUG_KERNEL || m > > > > @@ -2185,6 +2175,25 @@ config LINEAR_RANGES_TEST > > > > > > > > If unsure, say N. > > > > > > > > +config MIN_HEAP_KUNIT > > > > + tristate "KUnit test for Min heap" > > > > + depends on KUNIT > > > > + depends on DEBUG_KERNEL || m > > > > + help > > > > + Enable this to turn on min heap function tests. This test is > > > > + executed only once during system boot (so affects only boot time), > > > > + or at module load time. > > > > + > > > > + KUnit tests run during boot and output the results to the debug log > > > > + in TAP format (http://testanything.org/). Only useful for kernel devs > > > > + running the KUnit test harness, and not intended for inclusion into a > > > > + production build. > > > > + > > > > + For more information on KUnit and unit tests in general please refer > > > > + to the KUnit documentation in Documentation/dev-tools/kunit/. > > > > + > > > > + If unsure, say N. > > > > + > > > > > > It's a shame we need a config option for this. Could we have one > > > option to cover all basic library tests? > > > > > > > config TEST_UDELAY > > > > tristate "udelay test driver" > > > > help > > > > diff --git a/lib/Makefile b/lib/Makefile > > > > index b1c42c10073b..748f57063160 100644 > > > > --- a/lib/Makefile > > > > +++ b/lib/Makefile > > > > @@ -72,7 +72,6 @@ CFLAGS_test_ubsan.o += $(call cc-disable-warning, vla) > > > > UBSAN_SANITIZE_test_ubsan.o := y > > > > obj-$(CONFIG_TEST_KSTRTOX) += test-kstrtox.o > > > > obj-$(CONFIG_TEST_LIST_SORT) += test_list_sort.o > > > > -obj-$(CONFIG_TEST_MIN_HEAP) += test_min_heap.o > > > > obj-$(CONFIG_TEST_LKM) += test_module.o > > > > obj-$(CONFIG_TEST_VMALLOC) += test_vmalloc.o > > > > obj-$(CONFIG_TEST_OVERFLOW) += test_overflow.o > > > > @@ -318,3 +317,4 @@ obj-$(CONFIG_OBJAGG) += objagg.o > > > > # KUnit tests > > > > obj-$(CONFIG_LIST_KUNIT_TEST) += list-test.o > > > > obj-$(CONFIG_LINEAR_RANGES_TEST) += test_linear_ranges.o > > > > +obj-$(CONFIG_MIN_HEAP_KUNIT) += min_heap_kunit.o > > > > diff --git a/lib/test_min_heap.c b/lib/min_heap_kunit.c > > > > similarity index 60% > > > > rename from lib/test_min_heap.c > > > > rename to lib/min_heap_kunit.c > > > > index d19c8080fd4d..398db1c63146 100644 > > > > --- a/lib/test_min_heap.c > > > > +++ b/lib/min_heap_kunit.c > > > > @@ -7,9 +7,8 @@ > > > > > > > > #include > > > > #include > > > > -#include > > > > -#include > > > > #include > > > > +#include > > > > > > > > static __init bool less_than(const void *lhs, const void *rhs) > > > > { > > > > @@ -29,37 +28,34 @@ static __init void swap_ints(void *lhs, void *rhs) > > > > *(int *)rhs = temp; > > > > } > > > > > > > > -static __init int pop_verify_heap(bool min_heap, > > > > +static __init void pop_verify_heap(struct kunit *context, > > > > + bool min_heap, > > > > struct min_heap *heap, > > > > const struct min_heap_callbacks *funcs) > > > > { > > > > int *values = heap->data; > > > > - int err = 0; > > > > int last; > > > > > > > > last = values[0]; > > > > min_heap_pop(heap, funcs); > > > > while (heap->nr > 0) { > > > > if (min_heap) { > > > > - if (last > values[0]) { > > > > - pr_err("error: expected %d <= %d\n", last, > > > > - values[0]); > > > > - err++; > > > > - } > > > > + KUNIT_EXPECT_FALSE_MSG(context, > > > > + last > values[0], > > > > + "expected %d <= %d\n", > > > > + last, values[0]); > > > > > > I'm not familiar with kunit, is there a reason not to prefer: > > > KUNIT_EXPECT_LT(context, last, values[0]); > > > > > > > } else { > > > > - if (last < values[0]) { > > > > - pr_err("error: expected %d >= %d\n", last, > > > > - values[0]); > > > > - err++; > > > > - } > > > > + KUNIT_EXPECT_FALSE_MSG(context, > > > > + last < values[0], > > > > + "expected %d >= %d\n", > > > > + last, values[0]); > > > > > > Similarly KUNIT_EXPECT_GT. > > > > In relation to this, instead of KUNIT_EXPECT_LT, we would have to have > > something like KUNIT_EXPECT_LT_FALSE. > > Otherwise the test will always fail. > > Does KUNIT_EXPECT_GE not work? The error message suggests it should at least. My bad, both expect work, I will send v3 now. I'm working with other projects in parallel, and my context switch failed :( > Thanks, > Ian > > > > > > > Thanks, > > > Ian > > > > > > > } > > > > last = values[0]; > > > > min_heap_pop(heap, funcs); > > > > } > > > > - return err; > > > > } > > > > > > > > -static __init int test_heapify_all(bool min_heap) > > > > +static __init void test_heapify_all(struct kunit *context, bool min_heap) > > > > { > > > > int values[] = { 3, 1, 2, 4, 0x8000000, 0x7FFFFFF, 0, > > > > -3, -1, -2, -4, 0x8000000, 0x7FFFFFF }; > > > > @@ -73,12 +69,11 @@ static __init int test_heapify_all(bool min_heap) > > > > .less = min_heap ? less_than : greater_than, > > > > .swp = swap_ints, > > > > }; > > > > - int i, err; > > > > + int i; > > > > > > > > /* Test with known set of values. */ > > > > min_heapify_all(&heap, &funcs); > > > > - err = pop_verify_heap(min_heap, &heap, &funcs); > > > > - > > > > + pop_verify_heap(context, min_heap, &heap, &funcs); > > > > > > > > /* Test with randomly generated values. */ > > > > heap.nr = ARRAY_SIZE(values); > > > > @@ -86,12 +81,10 @@ static __init int test_heapify_all(bool min_heap) > > > > values[i] = get_random_int(); > > > > > > > > min_heapify_all(&heap, &funcs); > > > > - err += pop_verify_heap(min_heap, &heap, &funcs); > > > > - > > > > - return err; > > > > + pop_verify_heap(context, min_heap, &heap, &funcs); > > > > } > > > > > > > > -static __init int test_heap_push(bool min_heap) > > > > +static __init void test_heap_push(struct kunit *context, bool min_heap) > > > > { > > > > const int data[] = { 3, 1, 2, 4, 0x80000000, 0x7FFFFFFF, 0, > > > > -3, -1, -2, -4, 0x80000000, 0x7FFFFFFF }; > > > > @@ -106,25 +99,22 @@ static __init int test_heap_push(bool min_heap) > > > > .less = min_heap ? less_than : greater_than, > > > > .swp = swap_ints, > > > > }; > > > > - int i, temp, err; > > > > + int i, temp; > > > > > > > > /* Test with known set of values copied from data. */ > > > > for (i = 0; i < ARRAY_SIZE(data); i++) > > > > min_heap_push(&heap, &data[i], &funcs); > > > > - > > > > - err = pop_verify_heap(min_heap, &heap, &funcs); > > > > + pop_verify_heap(context, min_heap, &heap, &funcs); > > > > > > > > /* Test with randomly generated values. */ > > > > while (heap.nr < heap.size) { > > > > temp = get_random_int(); > > > > min_heap_push(&heap, &temp, &funcs); > > > > } > > > > - err += pop_verify_heap(min_heap, &heap, &funcs); > > > > - > > > > - return err; > > > > + pop_verify_heap(context, min_heap, &heap, &funcs); > > > > } > > > > > > > > -static __init int test_heap_pop_push(bool min_heap) > > > > +static __init void test_heap_pop_push(struct kunit *context, bool min_heap) > > > > { > > > > const int data[] = { 3, 1, 2, 4, 0x80000000, 0x7FFFFFFF, 0, > > > > -3, -1, -2, -4, 0x80000000, 0x7FFFFFFF }; > > > > @@ -139,7 +129,7 @@ static __init int test_heap_pop_push(bool min_heap) > > > > .less = min_heap ? less_than : greater_than, > > > > .swp = swap_ints, > > > > }; > > > > - int i, temp, err; > > > > + int i, temp; > > > > > > > > /* Fill values with data to pop and replace. */ > > > > temp = min_heap ? 0x80000000 : 0x7FFFFFFF; > > > > @@ -149,8 +139,7 @@ static __init int test_heap_pop_push(bool min_heap) > > > > /* Test with known set of values copied from data. */ > > > > for (i = 0; i < ARRAY_SIZE(data); i++) > > > > min_heap_pop_push(&heap, &data[i], &funcs); > > > > - > > > > - err = pop_verify_heap(min_heap, &heap, &funcs); > > > > + pop_verify_heap(context, min_heap, &heap, &funcs); > > > > > > > > heap.nr = 0; > > > > for (i = 0; i < ARRAY_SIZE(data); i++) > > > > @@ -161,34 +150,54 @@ static __init int test_heap_pop_push(bool min_heap) > > > > temp = get_random_int(); > > > > min_heap_pop_push(&heap, &temp, &funcs); > > > > } > > > > - err += pop_verify_heap(min_heap, &heap, &funcs); > > > > + pop_verify_heap(context, min_heap, &heap, &funcs); > > > > +} > > > > > > > > - return err; > > > > +static void __init test_heapify_all_true(struct kunit *context) > > > > +{ > > > > + test_heapify_all(context, true); > > > > } > > > > > > > > -static int __init test_min_heap_init(void) > > > > +static void __init test_heapify_all_false(struct kunit *context) > > > > { > > > > - int err = 0; > > > > - > > > > - err += test_heapify_all(true); > > > > - err += test_heapify_all(false); > > > > - err += test_heap_push(true); > > > > - err += test_heap_push(false); > > > > - err += test_heap_pop_push(true); > > > > - err += test_heap_pop_push(false); > > > > - if (err) { > > > > - pr_err("test failed with %d errors\n", err); > > > > - return -EINVAL; > > > > - } > > > > - pr_info("test passed\n"); > > > > - return 0; > > > > + test_heapify_all(context, true); > > > > +} > > > > + > > > > +static void __init test_heap_push_true(struct kunit *context) > > > > +{ > > > > + test_heap_push(context, true); > > > > +} > > > > + > > > > +static void __init test_heap_push_false(struct kunit *context) > > > > +{ > > > > + test_heap_push(context, false); > > > > } > > > > -module_init(test_min_heap_init); > > > > > > > > -static void __exit test_min_heap_exit(void) > > > > +static void __init test_heap_pop_push_true(struct kunit *context) > > > > { > > > > - /* do nothing */ > > > > + test_heap_pop_push(context, true); > > > > } > > > > -module_exit(test_min_heap_exit); > > > > + > > > > +static void __init test_heap_pop_push_false(struct kunit *context) > > > > +{ > > > > + test_heap_pop_push(context, false); > > > > +} > > > > + > > > > +static struct kunit_case __refdata min_heap_test_cases[] = { > > > > + KUNIT_CASE(test_heapify_all_true), > > > > + KUNIT_CASE(test_heapify_all_false), > > > > + KUNIT_CASE(test_heap_push_true), > > > > + KUNIT_CASE(test_heap_push_false), > > > > + KUNIT_CASE(test_heap_pop_push_true), > > > > + KUNIT_CASE(test_heap_pop_push_false), > > > > + {} > > > > +}; > > > > + > > > > +static struct kunit_suite min_heap_test_suite = { > > > > + .name = "min-heap", > > > > + .test_cases = min_heap_test_cases, > > > > +}; > > > > + > > > > +kunit_test_suites(&min_heap_test_suite); > > > > > > > > MODULE_LICENSE("GPL"); > > > > > > > > base-commit: d43c7fb05765152d4d4a39a8ef957c4ea14d8847 > > > > -- > > > > 2.26.2 > > > >