Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp969865yba; Fri, 3 May 2019 13:36:06 -0700 (PDT) X-Google-Smtp-Source: APXvYqzVE6tOfsxtq8KKGVWSZYlxp/hc5gI3SHXWUGLDq49VuFQpY10DVxyu1Cn62L7tbrOzsvf5 X-Received: by 2002:a17:902:b20f:: with SMTP id t15mr13425202plr.341.1556915766207; Fri, 03 May 2019 13:36:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556915766; cv=none; d=google.com; s=arc-20160816; b=k17bAAOcs26+db4STLcL438S/DiV93Hjm1gZl5wn7WWVcd/k2AtRDRbCPkNF9ryZIe n5qNaxCb8Kgl59aeCt8QSahwGIl4Egv6qUL+omgR1WorN1+AQZqyEO8QhpLR8YPYPyd3 ALSJf00CAMi8hSLyhqN/Re9kQMlVq1g/tpPLoJcpR475+0OvZSfwU/++TdPRsYBAZCzQ C2BAXdU+jz35c9/Dt3pXF81/MqhekXi5DqJom038SO5jQIMlWeCLI3Tn+Vc/fwPrJ+Pz Nbg2sA4aCRcYTYQsz/tBNHJze3HZASBrq+5KNmcV4izLihbpn9gN38uL7aaEDwxgydaZ BnuQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=ADpdDwLHxFyfFWAX1if0+NpffCsUFbkjDEInr1QTSC4=; b=RfNvGXriQmkPoFFqq/fTzHvmrKiEDc75ICc4ev7OQFrzJaCBe6XkHviU/aPkLjLIca 3p099cTZGwLoxlDStNv1PuhSRsGYQ6Ode6cBny06Dj1PfBN8XM+NXeOufpEeR0SF5AoL oF3R6VBKMYjFW5NjXfdCFBqEfzT/6T+jQJTCztrDRYugxOJnZ5YpqAxN0OQghj+WLd6j wnMbyNiXpDLrkmzBBHbn8NbzTalUVQxbILvAv25T9BggUl1sKfwEy2geh205J7nXf+Bq a3E2zmX+NT9AZasTH/cnYOz7qIPwluHkpYAEsZemW31zyyFON5TegzlLvCesMBnHgO4+ vhow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=VrvZIthS; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 6si3833034pgl.470.2019.05.03.13.35.50; Fri, 03 May 2019 13:36: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=@gmail.com header.s=20161025 header.b=VrvZIthS; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726810AbfECS7i (ORCPT + 99 others); Fri, 3 May 2019 14:59:38 -0400 Received: from mail-pl1-f194.google.com ([209.85.214.194]:39673 "EHLO mail-pl1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726776AbfECS7h (ORCPT ); Fri, 3 May 2019 14:59:37 -0400 Received: by mail-pl1-f194.google.com with SMTP id e92so3110555plb.6; Fri, 03 May 2019 11:59:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=ADpdDwLHxFyfFWAX1if0+NpffCsUFbkjDEInr1QTSC4=; b=VrvZIthSvvpLa9ofdi1TVHc0CvLr2VIODR9OjnFm+Up9we0zDAZUBWMLlTbOSItHKo Pbam23b4EY+ccSifRG/ZxjMcIQVAiXiA3KyIi8wmckJ7RJLpCpUuffuKoF64akwkaZ+a 3QcFYyfiYX8VkGbLXp+59LQq0XggiQTSFvsoJX1JIXyAy+67nRdTPeZZes4fPGEw0SNJ /9swLP5EtM7Jh7wPv9iAEyde8+QQDQGJVMKmJBfXFZRut96aOVsFH2VBxXFKDhAr7gl6 0FaZZo8MGkaVEpcuBTPxzyLi+qG9bWgEYJF7h83gR5avy0pM2sQoY06ujQlTV4yL6n8q BstA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=ADpdDwLHxFyfFWAX1if0+NpffCsUFbkjDEInr1QTSC4=; b=nNO3Uy8nfTx7DcFJUhocsCye11Py6t+73V2kfxLXrNOiKjUCs47u/VaFUFCiKm19bv rGwbXJQcOU6qtBuVG6QYdRIIjaZzwtASEMBxeuwCallv2FJMukmmM3lfieJ8fT9RvdXh tgDA06s06sDhCiQFtgGHjBHXj5BY9c6NgI1C5DbP9og/37RsUUOPvT3cZvtsxbx2oFdh ZRgxlfiOYTeLp5ufkZODr8aRBvSBjMO9WgaQkoNxbxd5zCZk4OOkkqPNOSUbAfHwzbFz QnEEt1pQvizsFjqGra4/FS3vHFs5BsV2kzRvfwAPbELQKLe5IRS7cTZW9BkttxIbr7O5 UhPQ== X-Gm-Message-State: APjAAAVl8YIA4n/Q9++ZFkFjokvrluZmu6GGWoN6mciGnGl/vR9TfCVu 7LtL+isNyLbRPMkQyCp0LhA= X-Received: by 2002:a17:902:bf44:: with SMTP id u4mr12529409pls.171.1556909976558; Fri, 03 May 2019 11:59:36 -0700 (PDT) Received: from [192.168.1.70] (c-24-6-192-50.hsd1.ca.comcast.net. [24.6.192.50]) by smtp.gmail.com with ESMTPSA id l2sm3517136pgl.2.2019.05.03.11.59.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 03 May 2019 11:59:35 -0700 (PDT) Subject: Re: [PATCH v2 12/17] kunit: tool: add Python wrappers for running KUnit tests To: Brendan Higgins Cc: Greg KH , Kees Cook , Kieran Bingham , Luis Chamberlain , Rob Herring , Stephen Boyd , shuah@kernel.org, devicetree , dri-devel , kunit-dev@googlegroups.com, linux-doc@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-kbuild@vger.kernel.org, Linux Kernel Mailing List , linux-kselftest@vger.kernel.org, linux-nvdimm , linux-um@lists.infradead.org, Sasha Levin , "Bird, Timothy" , Amir Goldstein , Dan Carpenter , Dan Williams , Daniel Vetter , Jeff Dike , Joel Stanley , Julia Lawall , Kevin Hilman , Knut Omang , Logan Gunthorpe , Michael Ellerman , Petr Mladek , Richard Weinberger , David Rientjes , Steven Rostedt , wfg@linux.intel.com, Felix Guo References: <20190501230126.229218-1-brendanhiggins@google.com> <20190501230126.229218-13-brendanhiggins@google.com> <20190502110220.GD12416@kroah.com> <1a5f3c44-9fa9-d423-66bf-45255a90c468@gmail.com> From: Frank Rowand Message-ID: <052fa196-4ea9-8384-79b7-fe6bacc0ee82@gmail.com> Date: Fri, 3 May 2019 11:59:33 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.6.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 5/2/19 10:36 PM, Brendan Higgins wrote: > On Thu, May 2, 2019 at 6:45 PM Frank Rowand wrote: >> >> On 5/2/19 4:45 PM, Brendan Higgins wrote: >>> On Thu, May 2, 2019 at 2:16 PM Frank Rowand wrote: >>>> >>>> On 5/2/19 11:07 AM, Brendan Higgins wrote: >>>>> On Thu, May 2, 2019 at 4:02 AM Greg KH wrote: >>>>>> >>>>>> On Wed, May 01, 2019 at 04:01:21PM -0700, Brendan Higgins wrote: >>>>>>> From: Felix Guo >>>>>>> >>>>>>> The ultimate goal is to create minimal isolated test binaries; in the >>>>>>> meantime we are using UML to provide the infrastructure to run tests, so >>>>>>> define an abstract way to configure and run tests that allow us to >>>>>>> change the context in which tests are built without affecting the user. >>>>>>> This also makes pretty and dynamic error reporting, and a lot of other >>>>>>> nice features easier. >>>>>>> >>>>>>> kunit_config.py: >>>>>>> - parse .config and Kconfig files. >>>>>>> >>>>>>> kunit_kernel.py: provides helper functions to: >>>>>>> - configure the kernel using kunitconfig. >>>>>>> - build the kernel with the appropriate configuration. >>>>>>> - provide function to invoke the kernel and stream the output back. >>>>>>> >>>>>>> Signed-off-by: Felix Guo >>>>>>> Signed-off-by: Brendan Higgins >>>>>> >>>>>> Ah, here's probably my answer to my previous logging format question, >>>>>> right? What's the chance that these wrappers output stuff in a standard >>>>>> format that test-framework-tools can already parse? :) >>> >>> To be clear, the test-framework-tools format we are talking about is >>> TAP13[1], correct? >> >> I'm not sure what the test community prefers for a format. I'll let them >> jump in and debate that question. >> >> >>> >>> My understanding is that is what kselftest is being converted to use. >>> >>>>> >>>>> It should be pretty easy to do. I had some patches that pack up the >>>>> results into a serialized format for a presubmit service; it should be >>>>> pretty straightforward to take the same logic and just change the >>>>> output format. >>>> >>>> When examining and trying out the previous versions of the patch I found >>>> the wrappers useful to provide information about how to control and use >>>> the tests, but I had no interest in using the scripts as they do not >>>> fit in with my personal environment and workflow. >>>> >>>> In the previous versions of the patch, these helper scripts are optional, >>>> which is good for my use case. If the helper scripts are required to >>> >>> They are still optional. >>> >>>> get the data into the proper format then the scripts are not quite so >>>> optional, they become the expected environment. I think the proper >>>> format should exist without the helper scripts. >>> >>> That's a good point. A couple things, >>> >>> First off, supporting TAP13, either in the kernel or the wrapper >>> script is not hard, but I don't think that is the real issue that you >>> raise. >>> >>> If your only concern is that you will always be able to have human >>> readable KUnit results printed to the kernel log, that is a guarantee >>> I feel comfortable making. Beyond that, I think it is going to take a >>> long while before I would feel comfortable guaranteeing anything about >>> how will KUnit work, what kind of data it will want to expose, and how >>> it will be organized. I think the wrapper script provides a nice >>> facade that I can maintain, can mediate between the implementation >>> details and the user, and can mediate between the implementation >>> details and other pieces of software that might want to consume >>> results. >>> >>> [1] https://testanything.org/tap-version-13-specification.html >> >> My concern is based on a focus on my little part of the world >> (which in _previous_ versions of the patch series was the devicetree >> unittest.c tests being converted to use the kunit infrastructure). >> If I step back and think of the entire kernel globally I may end >> up with a different conclusion - but I'm going to remain myopic >> for this email. >> >> I want the test results to be usable by me and my fellow >> developers. I prefer that the test results be easily accessible >> (current printk() implementation means that kunit messages are >> just as accessible as the current unittest.c printk() output). >> If the printk() output needs to be filtered through a script >> to generate the actual test results then that is sub-optimal >> to me. It is one more step added to my workflow. And >> potentially with an embedded target a major pain to get a >> data file (the kernel log file) transferred from a target >> to my development host. > > That's fair. If that is indeed your only concern, then I don't think > the wrapper script will ever be an issue for you. You will always be > able to execute a given test the old fashioned/manual way, and the > wrapper script only summarizes results, it does not change the > contents. > >> >> I want a reported test failure to be easy to trace back to the >> point in the source where the failure is reported. With printk() >> the search is a simple grep for the failure message. If the >> failure message has been processed by a script, and then the >> failure reported to me in an email, then I may have to look >> at the script to reverse engineer how the original failure >> message was transformed into the message that was reported >> to me in the email. Then I search for the point in the >> source where the failure is reported. So a basic task has >> just become more difficult and time consuming. > > That seems to be a valid concern. I would reiterate that you shouldn't > be concerned by any processing done by the wrapper script itself, but > the reality is that depending on what happens with automated > testing/presubmit/CI other people might end up parsing and > transforming test results - it might happen, it might not. You seem to be missing my point. Greg asked that the output be in a standard format. You replied that the standard format could be created by the wrapper script. Now you say that "it might happen, it might not". In other words the output may or may not end up in the standard format. As Greg points out in comments to patch 12: "The core of kunit should also log the messages in this format as well, and not rely on the helper scripts as Frank points out, not everyone will use/want them. Might as well make it easy for everyone to always do the right thing and not force it to always be added in later." I am requesting that the original message be in the standard format. Of course anyone is free to transform the messages in later processing, no big deal. > I currently > have a CI system set up for KUnit on my public repo that I don't think > you would be offended by, but I don't know what we are going to do > when it comes time to integrate with existing upstream CI systems. > > In anycase, I don't think that either sticking with or doing away with > the wrapper script is going to have any long term bearing on what > happens in this regard. > > Cheers >