Received: by 2002:a05:7412:a9a2:b0:e2:908c:2ebd with SMTP id o34csp893237rdh; Thu, 26 Oct 2023 20:57:40 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEcAS+wh5NAz0z1spBoKD13i61xrxafO2KrRjMJHf8eaQ6uhmSmD2lHVqb57D/5T7Hyw5o+ X-Received: by 2002:a81:760f:0:b0:59b:fda7:9d7f with SMTP id r15-20020a81760f000000b0059bfda79d7fmr1273595ywc.49.1698379059826; Thu, 26 Oct 2023 20:57:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698379059; cv=none; d=google.com; s=arc-20160816; b=1Jiqf5FzDyTzgPAsizyJYUEbPCbm18tY/5exPWApAl1fqqRL1gTpM4tvzy2bdQHeLG 5nJ7K+yIVBlu+s5ETdI/cVHW0hMtzCSon853juTZPFpWOAL4kG6nFKF25hYgfwLmCLSD TfBlOsoYrktOkL/VKVscrEg3gDTwZjdkiONd8VHBIHPkTYidBjwpla1tPZ1idWhS2smD MKmFk7eur3LFBCIGtkyXZ2893I2FtGsgVCGZgcn5Qi34sOS895Rh8EiueqBdMF+Zp8JW y4nVfWbR8LJ+zQg6ze8p3Tcy5Zg8De8ceyqURkiBfi5Bh3WpbX805K5BbdWVrIsybKuU qwPg== 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=8jcrh8lDKS8BsAuWR5NHIqaq+BMfiP1tei+uAd7lUCI=; fh=7zD82PFMOyYJwd9wTLrXyhUw2rYJBiVOh0CnLPfYeMs=; b=ycVVhVJ0EVuwy9xZ9JX3Hyy5ULIlBxtksLq0tgTrdOJJsOnnbiJ9mZJiLxdiipxL8y 7xJ4d+nDOiiavRPkHa5BSm6i17La2fcqnduj4qnSRc+zmYNsCTreKM8wM9wDgzh9ayj0 OKrMaedbN9JVaf+1+QkGEdbhqbL0bzO1aA3Fx9fx95CfxztstGWvadPjY+cM9Q3CNOFy dzTyuxdzHk1xNkkmz8rjDbKp+AVH77/GPRYepUi29dt71XbMuAbUfryGYeDBsMVg2P18 3atiwaIL2RBzeA9wc7riOyX6Y+LrE2oJVdWlmoYoyrukL3Sdi62KIDfy4+ZxVtvYfoBg KyTw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=OWdenBUE; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id g67-20020a0df646000000b0059c2412e526si1142670ywf.468.2023.10.26.20.57.39 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 26 Oct 2023 20:57:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20230601 header.b=OWdenBUE; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id B086C804F607; Thu, 26 Oct 2023 20:57:24 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229501AbjJ0D5S (ORCPT + 99 others); Thu, 26 Oct 2023 23:57:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44596 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229590AbjJ0D5Q (ORCPT ); Thu, 26 Oct 2023 23:57:16 -0400 Received: from mail-lf1-x12f.google.com (mail-lf1-x12f.google.com [IPv6:2a00:1450:4864:20::12f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7929C1AD for ; Thu, 26 Oct 2023 20:57:13 -0700 (PDT) Received: by mail-lf1-x12f.google.com with SMTP id 2adb3069b0e04-507c9305727so1325e87.1 for ; Thu, 26 Oct 2023 20:57:13 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1698379032; x=1698983832; darn=vger.kernel.org; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=8jcrh8lDKS8BsAuWR5NHIqaq+BMfiP1tei+uAd7lUCI=; b=OWdenBUEu+938OpuLZiCQAiMlVL1QUNQ/wsjEbaunYBz2OWT21RCGp8DbbaRuXxJpD C83Pw5rPkTOVmXWOC+cEukc/PAv/vPsStSJZLMYfLG6aKWsivZ5+EZ3KyuUCUifR/IwN x5gpbbPEFJV8BdYC6Yozgqg/AtGscjo6n+Oz/oEAxeIajPf/l8xWDRz01l7AwE8CTPxg RsoVdIv3qQ/370g13k6+zgN7ALd8F1jy9y6yFMd+4ueMmRe01wQDiN97uqrqo63o5Pew j6bFf2ZB7juCEGQTRBdCyKTzkzlR39sAd7q/5/8oJ7svY789htsWH3+WLxv5fDqHFxj3 B2CA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1698379032; x=1698983832; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=8jcrh8lDKS8BsAuWR5NHIqaq+BMfiP1tei+uAd7lUCI=; b=Hv8wWsmjSFh1130F5vbWBROBLHKvs0vxepaQSgZiHaw6loM7Rl60FNJnEoLA3Pri4O OifNZUkx0/wAJ0UypOCgrfa3XZl0ZaI8YSvApMMLNvma0Q4spIJTsHIA6SOE9xr8iddd gRtRZL4JV9dXSyr1dmXPhuW3PQ/QfuWd2PAiwDD0plago9BtREgwUhxDVpaOB3bjNxN9 xAq6x43f4LAT9nVs+IMi4Zqu3gxnercKlCGuVsw8bx+AbY0Lp+TZJgkOS0O3JfdI+2Rf m7Dhwwi6GMFtAdiozQJLXSlsPNr5pLBymfUMl35Uirb1MquEMhR34j8MJ9gX+n/BM0M2 n/3Q== X-Gm-Message-State: AOJu0YzjUC0IHgMS0nxnH9bL771NW1dkiOdIx4iG7aCRW8i0s+hN9wWp sQYJ6EujmdKDnJCiiZOEEtNFXGLD8xmHALxvPIGtIA== X-Received: by 2002:a05:6512:3490:b0:504:7b50:ec9a with SMTP id v16-20020a056512349000b005047b50ec9amr28933lfr.1.1698379031549; Thu, 26 Oct 2023 20:57:11 -0700 (PDT) MIME-Version: 1.0 References: <20231026085931.883824-1-mripard@kernel.org> In-Reply-To: <20231026085931.883824-1-mripard@kernel.org> From: David Gow Date: Fri, 27 Oct 2023 11:56:59 +0800 Message-ID: Subject: Re: [PATCH v3] kunit: Warn if tests are slow To: Maxime Ripard Cc: Brendan Higgins , Jani Nikula , Rae Moar , linux-kselftest@vger.kernel.org, kunit-dev@googlegroups.com, linux-kernel@vger.kernel.org Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-256; boundary="000000000000e5b5350608aaae77" X-Spam-Status: No, score=-17.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS, USER_IN_DEF_DKIM_WL,USER_IN_DEF_SPF_WL 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 X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Thu, 26 Oct 2023 20:57:24 -0700 (PDT) --000000000000e5b5350608aaae77 Content-Type: text/plain; charset="UTF-8" On Thu, 26 Oct 2023 at 16:59, Maxime Ripard wrote: > > Kunit recently gained support to setup attributes, the first one being > the speed of a given test, then allowing to filter out slow tests. > > A slow test is defined in the documentation as taking more than one > second. There's an another speed attribute called "super slow" but whose > definition is less clear. > > Add support to the test runner to check the test execution time, and > report tests that should be marked as slow but aren't. > > Signed-off-by: Maxime Ripard > > --- Looks good to me! Reviewed-by: David Gow Thanks, -- David > > To: Brendan Higgins > To: David Gow > Cc: Jani Nikula > Cc: Rae Moar > Cc: linux-kselftest@vger.kernel.org > Cc: kunit-dev@googlegroups.com > Cc: linux-kernel@vger.kernel.org > > Changes from v2: > - Add defines and comments to make the warning reporting threshold more > obvious > - Switch the duration comparisons to timespec64_compare to be more > accurate > - Link: https://lore.kernel.org/all/20230920084903.1522728-1-mripard@kernel.org/ > > Changes from v1: > - Split the patch out of the series > - Change to trigger the warning only if the runtime is twice the > threshold (Jani, Rae) > - Split the speed check into a separate function (Rae) > - Link: https://lore.kernel.org/all/20230911-kms-slow-tests-v1-0-d3800a69a1a1@kernel.org/ > --- > lib/kunit/test.c | 38 ++++++++++++++++++++++++++++++++++++++ > 1 file changed, 38 insertions(+) > > diff --git a/lib/kunit/test.c b/lib/kunit/test.c > index 49698a168437..4b710c92340a 100644 > --- a/lib/kunit/test.c > +++ b/lib/kunit/test.c > @@ -372,6 +372,36 @@ void kunit_init_test(struct kunit *test, const char *name, char *log) > } > EXPORT_SYMBOL_GPL(kunit_init_test); > > +/* Only warn when a test takes more than twice the threshold */ > +#define KUNIT_SPEED_WARNING_MULTIPLIER 2 > + > +/* Slow tests are defined as taking more than 1s */ > +#define KUNIT_SPEED_SLOW_THRESHOLD_S 1 > + > +#define KUNIT_SPEED_SLOW_WARNING_THRESHOLD_S \ > + (KUNIT_SPEED_WARNING_MULTIPLIER * KUNIT_SPEED_SLOW_THRESHOLD_S) > + > +#define s_to_timespec64(s) ns_to_timespec64((s) * NSEC_PER_SEC) > + > +static void kunit_run_case_check_speed(struct kunit *test, > + struct kunit_case *test_case, > + struct timespec64 duration) > +{ > + struct timespec64 slow_thr = > + s_to_timespec64(KUNIT_SPEED_SLOW_WARNING_THRESHOLD_S); > + enum kunit_speed speed = test_case->attr.speed; > + > + if (timespec64_compare(&duration, &slow_thr) < 0) > + return; > + > + if (speed == KUNIT_SPEED_VERY_SLOW || speed == KUNIT_SPEED_SLOW) > + return; > + > + kunit_warn(test, > + "Test should be marked slow (runtime: %lld.%09lds)", > + duration.tv_sec, duration.tv_nsec); > +} > + > /* > * Initializes and runs test case. Does not clean up or do post validations. > */ > @@ -379,6 +409,8 @@ static void kunit_run_case_internal(struct kunit *test, > struct kunit_suite *suite, > struct kunit_case *test_case) > { > + struct timespec64 start, end; > + > if (suite->init) { > int ret; > > @@ -390,7 +422,13 @@ static void kunit_run_case_internal(struct kunit *test, > } > } > > + ktime_get_ts64(&start); > + > test_case->run_case(test); > + > + ktime_get_ts64(&end); > + > + kunit_run_case_check_speed(test, test_case, timespec64_sub(end, start)); > } > > static void kunit_case_internal_cleanup(struct kunit *test) > -- > 2.41.0 > --000000000000e5b5350608aaae77 Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature MIIPnwYJKoZIhvcNAQcCoIIPkDCCD4wCAQExDzANBglghkgBZQMEAgEFADALBgkqhkiG9w0BBwGg ggz5MIIEtjCCA56gAwIBAgIQeAMYYHb81ngUVR0WyMTzqzANBgkqhkiG9w0BAQsFADBMMSAwHgYD VQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMzETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UE AxMKR2xvYmFsU2lnbjAeFw0yMDA3MjgwMDAwMDBaFw0yOTAzMTgwMDAwMDBaMFQxCzAJBgNVBAYT AkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMSowKAYDVQQDEyFHbG9iYWxTaWduIEF0bGFz IFIzIFNNSU1FIENBIDIwMjAwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvLe9xPU9W dpiHLAvX7kFnaFZPuJLey7LYaMO8P/xSngB9IN73mVc7YiLov12Fekdtn5kL8PjmDBEvTYmWsuQS 6VBo3vdlqqXZ0M9eMkjcKqijrmDRleudEoPDzTumwQ18VB/3I+vbN039HIaRQ5x+NHGiPHVfk6Rx c6KAbYceyeqqfuJEcq23vhTdium/Bf5hHqYUhuJwnBQ+dAUcFndUKMJrth6lHeoifkbw2bv81zxJ I9cvIy516+oUekqiSFGfzAqByv41OrgLV4fLGCDH3yRh1tj7EtV3l2TngqtrDLUs5R+sWIItPa/4 AJXB1Q3nGNl2tNjVpcSn0uJ7aFPbAgMBAAGjggGKMIIBhjAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0l BBYwFAYIKwYBBQUHAwIGCCsGAQUFBwMEMBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFHzM CmjXouseLHIb0c1dlW+N+/JjMB8GA1UdIwQYMBaAFI/wS3+oLkUkrk1Q+mOai97i3Ru8MHsGCCsG AQUFBwEBBG8wbTAuBggrBgEFBQcwAYYiaHR0cDovL29jc3AyLmdsb2JhbHNpZ24uY29tL3Jvb3Ry MzA7BggrBgEFBQcwAoYvaHR0cDovL3NlY3VyZS5nbG9iYWxzaWduLmNvbS9jYWNlcnQvcm9vdC1y My5jcnQwNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5nbG9iYWxzaWduLmNvbS9yb290LXIz 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 ddIn9n5Jt6Z1o79zxraLMEwGA1UdIARFMEMwQQYJKwYBBAGgMgEoMDQwMgYIKwYBBQUHAgEWJmh0 dHBzOi8vd3d3Lmdsb2JhbHNpZ24uY29tL3JlcG9zaXRvcnkvMAwGA1UdEwEB/wQCMAAwgZoGCCsG AQUFBwEBBIGNMIGKMD4GCCsGAQUFBzABhjJodHRwOi8vb2NzcC5nbG9iYWxzaWduLmNvbS9jYS9n c2F0bGFzcjNzbWltZWNhMjAyMDBIBggrBgEFBQcwAoY8aHR0cDovL3NlY3VyZS5nbG9iYWxzaWdu LmNvbS9jYWNlcnQvZ3NhdGxhc3Izc21pbWVjYTIwMjAuY3J0MB8GA1UdIwQYMBaAFHzMCmjXouse LHIb0c1dlW+N+/JjMEYGA1UdHwQ/MD0wO6A5oDeGNWh0dHA6Ly9jcmwuZ2xvYmFsc2lnbi5jb20v Y2EvZ3NhdGxhc3Izc21pbWVjYTIwMjAuY3JsMA0GCSqGSIb3DQEBCwUAA4IBAQBtHFwIgQZjer5K H+4Q+wns10k7qN+4wN2Uf+JsyOYjukaMEgdLErfA1wwtQ9uHkoYQZcWBuVVkQFa5hI+sqI2m1Weq riMCFSiU38s1tADdMX12IMfJRN60Nznhrw+nPyDRZqRhUTW24TwnHorkDnFPW8PHo7fAw4FrpI0n impZAng7ccvvK09K3ZuhwTIxJMsPXCZYsrXWORTw5sczRAP6XvKbPBJnsJoSTe5dFBPBHOQJOGhU qWfEfWnWMJPF3LxSGLpLFQXO3RwQqmxv08avwXfVPouh1xuB3FX7rpDabT8YDhu9JgIZkLEKko7L yQt6zWwng7k8YF/jGbiAta6VMYICajCCAmYCAQEwaDBUMQswCQYDVQQGEwJCRTEZMBcGA1UEChMQ R2xvYmFsU2lnbiBudi1zYTEqMCgGA1UEAxMhR2xvYmFsU2lnbiBBdGxhcyBSMyBTTUlNRSBDQSAy MDIwAhABzgV+4+mJnUzG7XDy6d2uMA0GCWCGSAFlAwQCAQUAoIHUMC8GCSqGSIb3DQEJBDEiBCBj RDBMEsC8fqwSd1jNxHzyBKVqOFyBp93V9wOoX1D6pTAYBgkqhkiG9w0BCQMxCwYJKoZIhvcNAQcB MBwGCSqGSIb3DQEJBTEPFw0yMzEwMjcwMzU3MTJaMGkGCSqGSIb3DQEJDzFcMFowCwYJYIZIAWUD BAEqMAsGCWCGSAFlAwQBFjALBglghkgBZQMEAQIwCgYIKoZIhvcNAwcwCwYJKoZIhvcNAQEKMAsG CSqGSIb3DQEBBzALBglghkgBZQMEAgEwDQYJKoZIhvcNAQEBBQAEggEAQt30HoFZMWImBnjQXkcs TwwG3dj0Hn+FN8srIXfYE6fOyN0IvImTk6wfpUzRuD8DZRVtbkq6YzbJB/UpTyda72fGAi70yvYK /f8hizhFmxYpZPFzr3EkD7vsFPV+WY1pV+UPE5yFOgtGhbvOGNU1IfxejMmjtlCoygQjsg4DG2u5 XyXMls/81hheWGlmjCsvq1LjYLPiDmAyVXKuxFBVIIBzHHs1xFyDLUTfXA2+TQECd/iavY6jbmGV v7Il9sChBPot0ZC64lHvQJ7XUhSq1aScsUPRzA8kYiduv4er2YJ9rgKWwp0PdY6xf7+lUWfwlYrQ q1R5rJde+nUrGk1n9w== --000000000000e5b5350608aaae77--