Received: by 2002:a05:6358:bb9e:b0:b9:5105:a5b4 with SMTP id df30csp3046625rwb; Mon, 5 Sep 2022 05:47:47 -0700 (PDT) X-Google-Smtp-Source: AA6agR7jailqqXv9g6u28q7IPVw9l1Px9vUYTdSPBdmfBhgZysiB5hG0NPmxswyB+M6o0OOj7/ut X-Received: by 2002:a17:90b:4a48:b0:1fd:df0a:eac1 with SMTP id lb8-20020a17090b4a4800b001fddf0aeac1mr20138132pjb.161.1662382066755; Mon, 05 Sep 2022 05:47:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662382066; cv=none; d=google.com; s=arc-20160816; b=uIk4Ik+fVKBlKyV9yYUf48qCsFcbx6w7DLQsL+HW22WNgzkAo+vkhB+IsjKU1uquny n8tIk5svMEeqUWmkNC+AmAlGDryLNfbq9exLjhyZEqYyH8S9Nc8wIaL9Kisf24NHi7Jh YvhsaWn5xuZvTMXJoayNESXmnIvHH8hOsTB09reg3Ks7zBxXJoiElRNfhJNcWSSXfXYH 1WAINgKtH9ddAt3b1JasRZyVCHEVfkQ6nHBZR3QNy3b7RcWJOywDutZyndPz4CCSPCb1 esshAYoOlsN4l8sUwC8v/VinsWgQLBaSYO2JBbJWyqLp4q0ihNt1B0FeDXVpq11WDokf KXCA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-transfer-encoding :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:feedback-id:dkim-signature:dkim-signature; bh=AZ4dQBzImW2tHrdACV6XOzXH3AtSXVLO9nUPVtHh6G4=; b=lojaRYVTK0dHU/A4Y2QEDrN9GWQDoMg2nyZBn2t8EmYDNh6OPSdR30dhHPW/su2h3z jX5k9wco/R9NF936zXm1Ufa9+phlNsY8BPzJoLS1aFdEx0IQvmJvtfobKB3RfAjN/dNJ hCseX+wdmuX0nBNfL7PpOdOOsF+2BA6wLMaandND7LKwpEZWr1V1aab0bxKspvTNuyDm PxEPJ63vDNMOcNBduhBI+/wq3vAAuWWod/zTzErXVNmhsQS2NMM5Qqrw5dv6AS67IG3v a67NahQYieI02940J0raSGsFsBdMivmjYkJvA3igxp1Ml9SQQ2bMsBz+D/ZnWgM3G/AZ 78hA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@cerno.tech header.s=fm3 header.b=PXNUMtZP; dkim=pass header.i=@messagingengine.com header.s=fm1 header.b=4Xps4K7r; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=cerno.tech Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q15-20020a63750f000000b00429bf9c39c0si10054955pgc.255.2022.09.05.05.47.35; Mon, 05 Sep 2022 05:47:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@cerno.tech header.s=fm3 header.b=PXNUMtZP; dkim=pass header.i=@messagingengine.com header.s=fm1 header.b=4Xps4K7r; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=cerno.tech Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232053AbiIEMKP (ORCPT + 99 others); Mon, 5 Sep 2022 08:10:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38582 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229822AbiIEMKN (ORCPT ); Mon, 5 Sep 2022 08:10:13 -0400 Received: from out5-smtp.messagingengine.com (out5-smtp.messagingengine.com [66.111.4.29]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 713201A3B6 for ; Mon, 5 Sep 2022 05:10:05 -0700 (PDT) Received: from compute2.internal (compute2.nyi.internal [10.202.2.46]) by mailout.nyi.internal (Postfix) with ESMTP id CACCB5C0116; Mon, 5 Sep 2022 08:10:04 -0400 (EDT) Received: from mailfrontend2 ([10.202.2.163]) by compute2.internal (MEProxy); Mon, 05 Sep 2022 08:10:04 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cerno.tech; h=cc :cc:content-transfer-encoding:content-type:date:date:from:from :in-reply-to:in-reply-to:message-id:mime-version:references :reply-to:sender:subject:subject:to:to; s=fm3; t=1662379804; x= 1662466204; bh=AZ4dQBzImW2tHrdACV6XOzXH3AtSXVLO9nUPVtHh6G4=; b=P XNUMtZP/LQxf/pkq9rs5FPGGK6CaoE+XmwQMkCOmtnI7vHTzSaoVHgPDhY9QIuGo DLF7S2VD9BaKiitRAhPOk4AyuU5dIomPsvJ8TrxVZcEy4dEArf1SOogUgiGdFS4V KIz2o7Vfqv8PGEDOMEZHvDFOSraStSZFSI2hs8qjTLYhOUt48FVrGWL0Vt6Ck/OR VoKRkTnCSDwVhrxuqi4rOXpU+vOczeXoLscdC8k07ndxg9CrsvAMVWm0cYo7LVOV L6QfNhbcwndE3i9/SMnmkjvYlssTmhbqeL+s1NvwuxFnM7T3tlB2+QLaV/iDw8eZ 0gVR6jfJ8XSOy2GYobYJQ== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:cc:content-transfer-encoding :content-type:date:date:feedback-id:feedback-id:from:from :in-reply-to:in-reply-to:message-id:mime-version:references :reply-to:sender:subject:subject:to:to:x-me-proxy:x-me-proxy :x-me-sender:x-me-sender:x-sasl-enc; s=fm1; t=1662379804; x= 1662466204; bh=AZ4dQBzImW2tHrdACV6XOzXH3AtSXVLO9nUPVtHh6G4=; b=4 Xps4K7rSCVxlGOkgti8NiEDry/OecDw1B5af385Kn6/A7XVx4uaszCKZJTxlG+vM N2X4b5Pq8SW0jWnOrrJRwDQzpIt938ta8Ojc+J+XWs0pUtdYzirowZJ8UKy3332r ShJnb3OlJPZZrwOjPnCYvAeIv2YjM1AbuF2wyfeDR8tPtQxBHLyCJlJ0dV5yY0zz XQsx6EROgNvfx8P4ysZNQZT4w/Aw0+PiPwlAmEKYJgv95y9XQUplxIzQU1XrEY1X uCubWFSX/cODkbs3ltcbdhSXeMHSq0ZR4n2mYXmTyWAaO0v7dg6rL+SSjry9hdpB Ur8Ezkurw2DdTYZrlc+kg== X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvfedrvdeliedghedtucetufdoteggodetrfdotf fvucfrrhhofhhilhgvmecuhfgrshhtofgrihhlpdfqfgfvpdfurfetoffkrfgpnffqhgen uceurghilhhouhhtmecufedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmne cujfgurhepfffhvfevuffkfhggtggugfgjsehtqhertddttdejnecuhfhrohhmpeforgig ihhmvgcutfhiphgrrhguuceomhgrgihimhgvsegtvghrnhhordhtvggthheqnecuggftrf grthhtvghrnhepudeikefffeegvddvfeetfeekkedvteffffehtddttdfgfeehlefgleev udeviedvnecuffhomhgrihhnpehkvghrnhgvlhdrohhrghenucevlhhushhtvghrufhiii gvpedtnecurfgrrhgrmhepmhgrihhlfhhrohhmpehmrgigihhmvgestggvrhhnohdrthgv tghh X-ME-Proxy: Feedback-ID: i8771445c:Fastmail Received: by mail.messagingengine.com (Postfix) with ESMTPA; Mon, 5 Sep 2022 08:10:03 -0400 (EDT) Date: Mon, 5 Sep 2022 14:10:00 +0200 From: Maxime Ripard To: =?utf-8?Q?Micha=C5=82?= Winiarski Cc: Jani Nikula , =?utf-8?B?TWHDrXJh?= Canal , Isabella Basso , magalilemes00@gmail.com, tales.aparecida@gmail.com, mwen@igalia.com, andrealmeid@riseup.net, siqueirajordao@riseup.net, Trevor Woerner , Daniel Vetter , David Airlie , Javier Martinez Canillas , David Gow , brendanhiggins@google.com, Arthur Grillo , =?utf-8?B?Sm9zw6kgRXhww7NzaXRv?= , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, kunit-dev@googlegroups.com Subject: Re: [PATCH v2 2/2] drm/tests: Change "igt_" prefix to "test_drm_" Message-ID: <20220905121000.m2xppgjlfjlmppfr@houat> References: <20220901124210.591994-1-mairacanal@riseup.net> <20220901124210.591994-2-mairacanal@riseup.net> <20220901125530.b56s4zisnkfuigvc@houat> <04aeba53-793c-3196-3137-915f0640dc2a@riseup.net> <87h71qfbi9.fsf@intel.com> <20220902123400.5ljgc7z6zw34d64m@houat> <87mtbidj3b.fsf@intel.com> <20220902133828.ufwp6bgzd37yu6bv@nostramo.hardline.pl> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: quoted-printable In-Reply-To: <20220902133828.ufwp6bgzd37yu6bv@nostramo.hardline.pl> X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,RCVD_IN_DNSWL_LOW,SPF_HELO_PASS,T_SCC_BODY_TEXT_LINE, T_SPF_TEMPERROR autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Sep 02, 2022 at 03:38:28PM +0200, Micha=C5=82 Winiarski wrote: > On Fri, Sep 02, 2022 at 04:03:20PM +0300, Jani Nikula wrote: > > On Fri, 02 Sep 2022, Maxime Ripard wrote: > > > On Fri, Sep 02, 2022 at 11:04:14AM +0300, Jani Nikula wrote: > > >> On Thu, 01 Sep 2022, Ma=C3=ADra Canal wrote: > > >> > Hi Maxime, > > >> > > > >> > On 9/1/22 09:55, Maxime Ripard wrote: > > >> >> Hi, > > >> >>=20 > > >> >> On Thu, Sep 01, 2022 at 09:42:10AM -0300, Ma=C3=ADra Canal wrote: > > >> >>> With the introduction of KUnit, IGT is no longer the only option= to run > > >> >>> the DRM unit tests, as the tests can be run through kunit-tool o= r on > > >> >>> real hardware with CONFIG_KUNIT. > > >> >>> > > >> >>> Therefore, remove the "igt_" prefix from the tests and replace i= t with > > >> >>> the "test_drm_" prefix, making the tests' names independent from= the tool > > >> >>> used. > > >> >>> > > >> >>> Signed-off-by: Ma=C3=ADra Canal > > >> >>> > > >> >>> --- > > >> >>> v1 -> v2: https://lore.kernel.org/dri-devel/20220830211603.19173= 4-1-mairacanal@riseup.net/ > > >> >>> - Change "drm_" prefix to "test_drm_", as "drm_" can be a bit co= nfusing (Jani Nikula). > > >> >>=20 > > >> >> I appreciate it's a bit of a bikeshed but I disagree with this. T= he > > >> >> majority of the kunit tests already out there start with the fram= ework > > >> >> name, including *all* the examples in the kunit doc. Plus, it's f= airly > > >> >> obvious that it's a test, kunit is only about running tests in th= e first > > >> >> place. > > >> > > > >> > Would it be better to keep it as "drm_"? > > >>=20 > > >> That's not "keeping". That's renaming igt to drm. > > > > > > Well, there's like half the tests that are prefixed with drm, the oth= er > > > with igt, so it's both really > > > > > >> > Currently, I don't think it is appropriate to hold the "igt_" pref= ix, as > > >> > the tests are not IGT exclusive, but I don't have a strong opinion= on > > >> > using the "drm_" or the "test_drm" prefixes. > > >>=20 > > >> I repeat my stance that "drm_" alone is confusing. > > > > > > What are you confusing it with? > > > > > >> For the reason alone that it pollutes the code tagging tools, mixing > > >> actual drm_ types and functions with unit test functions. > > > > > > I don't get it, I'm sorry. All these functions are static and not part > > > of any API, so I can't see how it would pollute a code tagging tool. = Or > > > at least, not more than any driver does. > > > > > > And we're part of a larger project here, it's about consistency with = the > > > rest of the ecosystem. > >=20 > > Okay, so I'm just going to explain what I mean, but say "whatever" right > > after and move on. > >=20 > > For example, drm_buddy_test.c includes drm_buddy.h so with the igt_ -> > > drm_ rename none of the test functions may clash with the drm_buddy_ > > prefixed existing functions. Ditto for all tests similarly. > >=20 > > For example drm_buddy_alloc_range() as a name sounds like something that > > allocs a range, not something that tests range allocation. On the other > > hand, you have drm_buddy_alloc_blocks() which is actually a real > > drm_buddy function, not a test. What would you call a test that tests > > that? Here, we end up with names that are all prefixed drm_buddy and you > > won't know what's the actual function and what's the test unless you > > look it up. > >=20 > > I use code tagging that I can use for finding and completing > > e.g. functions. Currently I have the following completions, for > > igt_buddy_ and drm_buddy_, respectively: > >=20 > > Possible completions are: > > igt_buddy_alloc_limit igt_buddy_alloc_optimistic igt_buddy_alloc_path= ological > > igt_buddy_alloc_pessimistic igt_buddy_alloc_range igt_buddy_alloc_smo= ke > >=20 > > Possible completions are: > > drm_buddy_alloc_blocks drm_buddy_block drm_buddy_block_is_allocated = drm_buddy_block_is_free > > drm_buddy_block_is_split drm_buddy_block_offset drm_buddy_block_order= drm_buddy_block_print > > drm_buddy_block_size drm_buddy_block_state drm_buddy_block_trim drm_= buddy_fini > > drm_buddy_free_block drm_buddy_free_list drm_buddy_init drm_buddy_in= it_test > > drm_buddy_module_exit drm_buddy_module_init drm_buddy_print > >=20 > > With the patch at hand, they'll all be lumped under drm_buddy_ > > completions, and some of them will be actual drm buddy functions and > > some not. > >=20 > > I just find it a very odd convention to name the tests in a way that's > > indistinguishable from the real things. Even *within* drm_buddy_test.c > > where you read the test code. Because currently you do have calls to > > igt_buddy_ prefixed functions from other igt_buddy_ prefixed functions, > > along with the drm_buddy_ prefixed calls. I think it's just going to be > > a mess. > >=20 > > /rant > >=20 > > Whatever. Moving on. >=20 > KUnit docs [1] state: > https://docs.kernel.org/dev-tools/kunit/style.html#test-cases > "As tests are themselves functions, their names cannot conflict with other > C identifiers in the kernel. This may require some creative naming." > And give examples of names. But this should be local to individual test s= uite - > as long as the test is readable, and the name describes what it is testin= g, we > should be fine. We don't even need to pass drm_* prefix, as this conventi= on is > expected for test suites, not test cases [2]. >=20 > Having said that - I do believe that igt_* prefix don't belong here (whic= h is > why I'm progressively trying to get rid of in the patches that refactor s= ome of > the tests). > I agree with Jani - can we take it on a case-by-case basis? > If the test name is too similar to the function that it is testing, we co= uld go > with one of the following (taking igt_buddy_alloc_limit as example): > drm_buddy_test_alloc_limit > test_drm_buddy_alloc_limit > buddy_test_alloc_limit > test_buddy_alloc_limit We also have drm_test_buddy_alloc_limit, or drm_buddy_test_alloc_limit Both would be fine for me, with a small preference for the former, which should also address Jani's concerns? > And either of those is fine in my opinion (I'd personally go with > test_buddy_alloc_limit in this case). > We don't really need a DRM-wide (or worse, kernel wide) convention for te= st case > names (it's only really needed for test suites). Sure we do. kunit.py can take some filters too. Being able to only run DRM tests with a single filter is super convenient, and if we fail to provide a consistent naming we're pretty much sure people running the tests are going to miss some. Maxime