Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp2945821yba; Fri, 10 May 2019 23:59:06 -0700 (PDT) X-Google-Smtp-Source: APXvYqzrb75awJiLxpIHH2ApHpl5erzU4FxrDg+fVgbsgCdDMzLIeuRMEP/UD7WEGd5ZJnkCFSrz X-Received: by 2002:a17:902:3281:: with SMTP id z1mr17765410plb.44.1557557946264; Fri, 10 May 2019 23:59:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1557557946; cv=none; d=google.com; s=arc-20160816; b=poGHJZzLLx0SdZ3FTwtYMSRcLuIbfQRqtzQxEqZqYZSkOwVKoSdRhdk7G1NzSEXoj+ N0WTmWfdmpzjT2atn26lJEfQ6IaosmjHdUsJelqYr1UarWx4eeA+EAnGreOSQGXUsBwc 6diqklZNeoAFNOnc80s+yBPBAUTRPb1cJOA/dRKbttXkhgoM2V9wi2lJLz9egdcLA1wR PyISqL+P8esy4+SYqvK1T6s/emq53kldWKqUSWhVgr33qDPB/MRuPZeZQGT95w3stGd4 NWQRp5zlrPSewK+vg8vTrGZoN4Q0M0nBa0lIyhthMOslooa/uwNM1/8OBnwWD5GXjeHc aQXw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=1QK6W6CC3+ccPxrSKF4xwoDQTey+3Zw3yM7Vill3vMM=; b=yeqH9kEuI2viQh6YSGVn5I7OMbCg0ZWWid04jxLW1InL/zWq62f5CVpx8p4OKkRteO ageeYyK6AVHY7vpyTKZKmBd2LYH1zVgUdQzIG8zE0bf+k2bReSFs5lJHhKuaW/E6BXGL 5J5b8GPVaBq9P/LMpL4UTnnSgkYI+NqOKRhOMhUIJ7r5zLBX7MZxeekAomAbwKWxCXj+ raapmb6QgNZr5kZcNpHJHhBPxpil9fwhuX0awzesnYwkMwoGTZgzObxXujOrp36XU7XC 3lLpZb53TOd8oggLwroKsEDc0x45oeeXA25dYghS3dj19KMs85FLwjr3pb8aYyEtQ39G /a7g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b="QQHgm/Gp"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id bf12si9246308plb.126.2019.05.10.23.58.49; Fri, 10 May 2019 23:59:06 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b="QQHgm/Gp"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728397AbfEKGq2 (ORCPT + 99 others); Sat, 11 May 2019 02:46:28 -0400 Received: from userp2130.oracle.com ([156.151.31.86]:34762 "EHLO userp2130.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726849AbfEKGq1 (ORCPT ); Sat, 11 May 2019 02:46:27 -0400 Received: from pps.filterd (userp2130.oracle.com [127.0.0.1]) by userp2130.oracle.com (8.16.0.27/8.16.0.27) with SMTP id x4B6g6Uq025673; Sat, 11 May 2019 06:43:48 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=message-id : subject : from : to : cc : date : in-reply-to : references : content-type : mime-version : content-transfer-encoding; s=corp-2018-07-02; bh=1QK6W6CC3+ccPxrSKF4xwoDQTey+3Zw3yM7Vill3vMM=; b=QQHgm/GpaI2EpKx/jn7Af9br5xSVhUWmBFJd3PkW2bcaGv976ySRePWf8kwN53fDx/wU MuQR2dOJUUaxxCw3FeCPwqR7e7SbRaCd+mhoOK/dcK8UbTgKem6mBoNtjwARrxZ3cERN qRaeWsGwNlQZtsPQZOJl+mjJYvR5wZYPEdHRf3i+GtOFdr256BsLlD4JITMTzt+eJeMK 8SWLoBGotUshwFCeu4xcqOc/tVajjJdK/iQzvJZ2GrHjmK0X0F6NKFClch59CdxuaLHa eKAWdh42ASUprSfj5Sny1WLuuq8xHB+WSyqJCZKauAUUKn1XACJUOXhYhExQJX47kQ6o 5Q== Received: from userp3030.oracle.com (userp3030.oracle.com [156.151.31.80]) by userp2130.oracle.com with ESMTP id 2sdntt8ab3-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Sat, 11 May 2019 06:43:48 +0000 Received: from pps.filterd (userp3030.oracle.com [127.0.0.1]) by userp3030.oracle.com (8.16.0.27/8.16.0.27) with SMTP id x4B6g536022877; Sat, 11 May 2019 06:43:47 GMT Received: from aserv0121.oracle.com (aserv0121.oracle.com [141.146.126.235]) by userp3030.oracle.com with ESMTP id 2sdkgsucd1-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Sat, 11 May 2019 06:43:47 +0000 Received: from abhmp0017.oracle.com (abhmp0017.oracle.com [141.146.116.23]) by aserv0121.oracle.com (8.14.4/8.13.8) with ESMTP id x4B6hXIn027461; Sat, 11 May 2019 06:43:34 GMT Received: from asu (/92.220.18.196) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Fri, 10 May 2019 23:43:33 -0700 Message-ID: Subject: Re: [PATCH v2 00/17] kunit: introduce KUnit, the Linux kernel unit testing framework From: Knut Omang To: Frank Rowand , Brendan Higgins , Daniel Vetter Cc: Logan Gunthorpe , "Theodore Ts'o" , "Bird, Timothy" , Greg KH , Kees Cook , Kieran Bingham , "Luis R. Rodriguez" , Rob Herring , Stephen Boyd , Shuah Khan , devicetree , dri-devel , kunit-dev@googlegroups.com, Linux Doc Mailing List , linux-fsdevel@vger.kernel.org, linux-kbuild , Linux Kernel Mailing List , "open list:KERNEL SELFTEST FRAMEWORK" , linux-nvdimm , linux-um@lists.infradead.org, Sasha Levin , Amir Goldstein , Dan Carpenter , Dan Williams , Jeff Dike , Joel Stanley , Julia Lawall , Kevin Hilman , Michael Ellerman , Petr Mladek , Richard Weinberger , David Rientjes , Steven Rostedt , wfg@linux.intel.com Date: Sat, 11 May 2019 08:43:23 +0200 In-Reply-To: <8abaf5f2-dd33-98d0-7b34-b57de7fe7c8b@gmail.com> References: <20190509015856.GB7031@mit.edu> <580e092f-fa4e-eedc-9e9a-a57dd085f0a6@gmail.com> <20190509032017.GA29703@mit.edu> <7fd35df81c06f6eb319223a22e7b93f29926edb9.camel@oracle.com> <20190509133551.GD29703@mit.edu> <875c546d-9713-bb59-47e4-77a1d2c69a6d@gmail.com> <20190509214233.GA20877@mit.edu> <20190509233043.GC20877@mit.edu> <8914afef-1e66-e6e3-f891-5855768d3018@deltatee.com> <6d6e91ec-33d3-830b-4895-4d7a20ba7d45@gmail.com> <8abaf5f2-dd33-98d0-7b34-b57de7fe7c8b@gmail.com> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.30.5 (3.30.5-1.fc29) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=9253 signatures=668686 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=0 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1810050000 definitions=main-1905110045 X-Proofpoint-Virus-Version: vendor=nai engine=5900 definitions=9253 signatures=668686 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1015 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1810050000 definitions=main-1905110045 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 2019-05-10 at 14:59 -0700, Frank Rowand wrote: > On 5/10/19 3:23 AM, Brendan Higgins wrote: > >> On Fri, May 10, 2019 at 7:49 AM Knut Omang wrote: > >>> > >>> On Thu, 2019-05-09 at 22:18 -0700, Frank Rowand wrote: > >>>> On 5/9/19 4:40 PM, Logan Gunthorpe wrote: > >>>>> > >>>>> > >>>>> On 2019-05-09 5:30 p.m., Theodore Ts'o wrote: > >>>>>> On Thu, May 09, 2019 at 04:20:05PM -0600, Logan Gunthorpe wrote: > >>>>>>> > >>>>>>> The second item, arguably, does have significant overlap with kselftest. > >>>>>>> Whether you are running short tests in a light weight UML environment or > >>>>>>> higher level tests in an heavier VM the two could be using the same > >>>>>>> framework for writing or defining in-kernel tests. It *may* also be valuable > >>>>>>> for some people to be able to run all the UML tests in the heavy VM > >>>>>>> environment along side other higher level tests. > >>>>>>> > >>>>>>> Looking at the selftests tree in the repo, we already have similar items to > >>>>>>> what Kunit is adding as I described in point (2) above. kselftest_harness.h > >>>>>>> contains macros like EXPECT_* and ASSERT_* with very similar intentions to > >>>>>>> the new KUNIT_EXECPT_* and KUNIT_ASSERT_* macros. > >>>>>>> > >>>>>>> However, the number of users of this harness appears to be quite small. Most > >>>>>>> of the code in the selftests tree seems to be a random mismash of scripts > >>>>>>> and userspace code so it's not hard to see it as something completely > >>>>>>> different from the new Kunit: > >>>>>>> > >>>>>>> $ git grep --files-with-matches kselftest_harness.h * > >>>>>> > >>>>>> To the extent that we can unify how tests are written, I agree that > >>>>>> this would be a good thing. However, you should note that > >>>>>> kselftest_harness.h is currently assums that it will be included in > >>>>>> userspace programs. This is most obviously seen if you look closely > >>>>>> at the functions defined in the header files which makes calls to > >>>>>> fork(), abort() and fprintf(). > >>>>> > >>>>> Ah, yes. I obviously did not dig deep enough. Using kunit for > >>>>> in-kernel tests and kselftest_harness for userspace tests seems like > >>>>> a sensible line to draw to me. Trying to unify kernel and userspace > >>>>> here sounds like it could be difficult so it's probably not worth > >>>>> forcing the issue unless someone wants to do some really fancy work > >>>>> to get it done. > >>>>> > >>>>> Based on some of the other commenters, I was under the impression > >>>>> that kselftests had in-kernel tests but I'm not sure where or if they > >>>>> exist. > >>>> > >>>> YES, kselftest has in-kernel tests. (Excuse the shouting...) > >>>> > >>>> Here is a likely list of them in the kernel source tree: > >>>> > >>>> $ grep module_init lib/test_*.c > >>>> lib/test_bitfield.c:module_init(test_bitfields) > >>>> lib/test_bitmap.c:module_init(test_bitmap_init); > >>>> lib/test_bpf.c:module_init(test_bpf_init); > >>>> lib/test_debug_virtual.c:module_init(test_debug_virtual_init); > >>>> lib/test_firmware.c:module_init(test_firmware_init); > >>>> lib/test_hash.c:module_init(test_hash_init); /* Does everything */ > >>>> lib/test_hexdump.c:module_init(test_hexdump_init); > >>>> lib/test_ida.c:module_init(ida_checks); > >>>> lib/test_kasan.c:module_init(kmalloc_tests_init); > >>>> lib/test_list_sort.c:module_init(list_sort_test); > >>>> lib/test_memcat_p.c:module_init(test_memcat_p_init); > >>>> lib/test_module.c:static int __init test_module_init(void) > >>>> lib/test_module.c:module_init(test_module_init); > >>>> lib/test_objagg.c:module_init(test_objagg_init); > >>>> lib/test_overflow.c:static int __init test_module_init(void) > >>>> lib/test_overflow.c:module_init(test_module_init); > >>>> lib/test_parman.c:module_init(test_parman_init); > >>>> lib/test_printf.c:module_init(test_printf_init); > >>>> lib/test_rhashtable.c:module_init(test_rht_init); > >>>> lib/test_siphash.c:module_init(siphash_test_init); > >>>> lib/test_sort.c:module_init(test_sort_init); > >>>> lib/test_stackinit.c:module_init(test_stackinit_init); > >>>> lib/test_static_key_base.c:module_init(test_static_key_base_init); > >>>> lib/test_static_keys.c:module_init(test_static_key_init); > >>>> lib/test_string.c:module_init(string_selftest_init); > >>>> lib/test_ubsan.c:module_init(test_ubsan_init); > >>>> lib/test_user_copy.c:module_init(test_user_copy_init); > >>>> lib/test_uuid.c:module_init(test_uuid_init); > >>>> lib/test_vmalloc.c:module_init(vmalloc_test_init) > >>>> lib/test_xarray.c:module_init(xarray_checks); > >>>> > >>>> > >>>>> If they do exists, it seems like it would make sense to > >>>>> convert those to kunit and have Kunit tests run-able in a VM or > >>>>> baremetal instance. > >>>> > >>>> They already run in a VM. > >>>> > >>>> They already run on bare metal. > >>>> > >>>> They already run in UML. > >>>> > >>>> This is not to say that KUnit does not make sense. But I'm still trying > >>>> to get a better description of the KUnit features (and there are > >>>> some). > >>> > >>> FYI, I have a master student who looks at converting some of these to KTF, such as > for > >>> instance the XArray tests, which lended themselves quite good to a semi-automated > >>> conversion. > >>> > >>> The result is also a somewhat more compact code as well as the flexibility > >>> provided by the Googletest executor and the KTF frameworks, such as running selected > >>> tests, output formatting, debugging features etc. > >> > >> So is KTF already in upstream? Or is the plan to unify the KTF and > > > > I am not certain about KTF's upstream plans, but I assume that Knut > > would have CC'ed me on the thread if he had started working on it. > > > >> Kunit in-kernel test harnesses? Because there's tons of these > > > > No, no plan. Knut and I talked about this a good while ago and it > > seemed that we had pretty fundamentally different approaches both in > > terms of implementation and end goal. Combining them seemed pretty > > infeasible, at least from a technical perspective. Anyway, I am sure > > Knut would like to give him perspective on the matter and I don't want > > to say too much without first giving him a chance to chime in on the > > matter. > > > > Nevertheless, I hope you don't see resolving this as a condition for > > accepting this patchset. I had several rounds of RFC on KUnit, and no > > one had previously brought this up. > > I seem to recall a request in reply to the KUnit RFC email threads to > work together. You recall right. I wanted us to work together to refine a common approach. I still think that's possible. > However whether that impacts acceptance of this patch set is up to > the maintainer and how she wants to resolve the potential collision > of KUnit and KTF (if there is indeed any sort of collision). I believe there's overlap and potential for unification and code sharing. My concern is to make sure that that can happen without disrupting too many test users. I'd really like to get some more time to explore that. It strikes me that the main difference in the two approaches lies in the way reporting is done by default. Since KUnit handles all the reporting itself, while KTF relies on Googletest for that, a lot more code in KUnit revolves around that part, while with KTF we have focused more on features to enable writing powerful and effective tests. The reporting part can possibly be made configurable: Reporting with printk or reporting via netlink to user space. In fact, as a KTF debugging option KTF already supports printk reporting which can be enabled via sysfs. If macros can have the same syntax, then there's likely features in KTF that KUnit users would benefit from too. But this of course have to be tried out. Knut > >> in-kernel unit tests already, and every merge we get more (Frank's > >> list didn't even look into drivers or anywhere else, e.g. it's missing > >> the locking self tests I worked on in the past), and a more structured > >> approach would really be good. > > > > Well, that's what I am trying to do. I hope you like it! > > > > Cheers! > > . > > >