Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2474719pxb; Fri, 5 Feb 2021 20:41:03 -0800 (PST) X-Google-Smtp-Source: ABdhPJzlHka/qoqwpCoRGCAUhDIyX5IuJUw3alqEF3ZkZrQuPFTS8BGGtMxbp0JPfPrIxTeYPD+6 X-Received: by 2002:a17:906:dff1:: with SMTP id lc17mr6989230ejc.198.1612586463163; Fri, 05 Feb 2021 20:41:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612586463; cv=none; d=google.com; s=arc-20160816; b=MIGORk9zvRzcBXvznCpn7iv+1UkM/POeGZJb0yGFOZdlW2t0VRXckeKURX8g/IHSpL d3G+WW1NXMGm6y8WwYH+kSHsVn0fBPIXRghjnMQIwWWYTZEvMluI2YJlwcH5YeCBNbs7 WKFrffynilE3y8wEBdP2LNGp6JFcPmFrfMH4vmX60iysdgvJBgL0lTsSNg7X9BigWVEX hZVbnN0TPDZmHZvgwW1IcFQ+tmmkVCnjknC0rZ8sa9pb5XAINQOAjiaZb8vHTYUfxtDh x91IHC/0Mz4Vi9ji/p/BwCjG/UxsfRhvVRZXhk+WjEdc8x58DVeP/PTkX1CczH6Xtk2j yuaw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:mime-version:message-id:date :sender:dkim-signature; bh=d5RIDWJchB5lEhG7XVyqeqKAvmcYq4cH2DHTaZwx5/0=; b=rm+Fo26RvTrMVO2/9etSZX6JalyrGeU4uYjJLAFP3MEVZ0SoZf68XfcGMP9SzVzio9 t5oCviQtq3cCdgee5JjIvR6N3OifQIcwjkuF8arw8aDAEq44bd9nMIgwQA6sywMH25Yn NoAc6LhTwkNf7KbX+U+JO3w8qlaii7lbrArp0dv4HFA8beISmptpeQXckfL9Bp8MkMxR 6ZI7YICYSQnMVNdCVG0NlDpTlk1l0T/dtwn0gCggIruRYCz2tdk3g1IhFFDvVwyRqjI6 L3YI6ZrzX0YB3JnTvWKqe2Ax+36ZGnCqP9AcY3uaL74X01kJoWQHAOvQA2MuUoDHqG8s 4P/Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=FpnhHFz3; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p31si6822446edd.505.2021.02.05.20.40.39; Fri, 05 Feb 2021 20:41:03 -0800 (PST) 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=@google.com header.s=20161025 header.b=FpnhHFz3; 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; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231269AbhBFEhY (ORCPT + 99 others); Fri, 5 Feb 2021 23:37:24 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37190 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229650AbhBFCbT (ORCPT ); Fri, 5 Feb 2021 21:31:19 -0500 Received: from mail-yb1-xb49.google.com (mail-yb1-xb49.google.com [IPv6:2607:f8b0:4864:20::b49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 89398C06121C for ; Fri, 5 Feb 2021 14:14:19 -0800 (PST) Received: by mail-yb1-xb49.google.com with SMTP id w4so8739225ybc.7 for ; Fri, 05 Feb 2021 14:14:19 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=sender:date:message-id:mime-version:subject:from:to:cc; bh=d5RIDWJchB5lEhG7XVyqeqKAvmcYq4cH2DHTaZwx5/0=; b=FpnhHFz3tKFPWcMnsP3l/yAb+F4xtDN9a+EPKrp039W814ze9LgPS2QUt1bLmcn4Bx fjWAOs18xxnAHyRbu5jwp5G1XqxPNDGXsCCvAejg73f5vbMd0k1iKljPB2pOTJL+Wewv Fa4Fg2soTqDYR6ReE5M3CvB/4t3V2WiYPdNb8xORG7fNtAwge8iisF7XdNoPn/RN/V/y hzJND4ecNGC/Xu5xf21WqIcn8LIHawkKlNXC1NxGZy72QVzNdxCxcyfMfkZ74rg1U29m p/OKFrWOrTDBpLVDnLSpY0TxTAfhq+PmRP1rZygdoLUIxCcusgjx687xUkRQiTWOWpe7 ZL4Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:message-id:mime-version:subject:from :to:cc; bh=d5RIDWJchB5lEhG7XVyqeqKAvmcYq4cH2DHTaZwx5/0=; b=fgEU+RVP60ZRzu9xF4yoyUk3xrUU3nH1FO76833m3YdnfKSYvXo2o3gHIBvuKFyN5G f0jYFGQ6Q8aoAAP8tatE/ArpXGLGS5FtZSZqY2be1Da+ooUoze3nlN3wUs+VOHH/ZLZe ZB1sjSy0iQMuRCumktQ4zklxDzVT3wfzgAMHddYarg5qOWCO0XLD9sqBIuMF42GlzUFA IE0PbzwFLSLIerSeMnIHR0/dbQAPURVBJCo4R/GlZiRph3i1BJC/VMw506wNviSJjJqM T7DVVSJCdhqumnWROcX98kjqNE76Jfrb8F0J2bf7gZAZskWFkDTuKcDArNtOG5ZcM5UL ajDg== X-Gm-Message-State: AOAM533y0oJ1Loph83rQDUN+FkfEDCOjXIsdW07e9TsOW5jrHAKPIJ8h KLzYnJoU6HOKDqYg1zKWy2BaNzXhzA92fQ== Sender: "dlatypov via sendgmr" X-Received: from dlatypov.svl.corp.google.com ([2620:15c:2cd:202:a8b1:128a:69fa:86fb]) (user=dlatypov job=sendgmr) by 2002:a25:21d4:: with SMTP id h203mr9010706ybh.290.1612563258804; Fri, 05 Feb 2021 14:14:18 -0800 (PST) Date: Fri, 5 Feb 2021 14:14:09 -0800 Message-Id: <20210205221409.1962881-1-dlatypov@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.30.0.478.g8a0d178c01-goog Subject: [PATCH v2] kunit: don't show `1 == 1` in failed assertion messages From: Daniel Latypov To: brendanhiggins@google.com, davidgow@google.com Cc: linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, skhan@linuxfoundation.org, Daniel Latypov Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently, given something (fairly dystopian) like > KUNIT_EXPECT_EQ(test, 2 + 2, 5) KUnit will prints a failure message like this. > Expected 2 + 2 == 5, but > 2 + 2 == 4 > 5 == 5 With this patch, the output just becomes > Expected 2 + 2 == 5, but > 2 + 2 == 4 This patch is slightly hacky, but it's quite common* to compare an expression to a literal integer value, so this can make KUnit less chatty in many cases. (This patch also fixes variants like KUNIT_EXPECT_GT, LE, et al.). It also allocates an additional string briefly, but given this only happens on test failures, it doesn't seem too bad a tradeoff. Also, in most cases it'll realize the lengths are unequal and bail out before the allocation. We could save the result of the formatted string to avoid wasting this extra work, but it felt cleaner to leave it as-is. Edge case: for something silly and unrealistic like > KUNIT_EXPECT_EQ(test, 4, 5); It'll generate this message with a trailing "but" > Expected 4 == 5, but > It didn't feel worth adding a check up-front to see if both sides are literals to handle this better. *A quick grep suggests 100+ comparisons to an integer literal as the right hand side. Signed-off-by: Daniel Latypov Tested-by: David Gow Reviewed-by: Brendan Higgins --- lib/kunit/assert.c | 39 +++++++++++++++++++++++++++++++++------ 1 file changed, 33 insertions(+), 6 deletions(-) diff --git a/lib/kunit/assert.c b/lib/kunit/assert.c index 33acdaa28a7d..e0ec7d6fed6f 100644 --- a/lib/kunit/assert.c +++ b/lib/kunit/assert.c @@ -85,6 +85,29 @@ void kunit_ptr_not_err_assert_format(const struct kunit_assert *assert, } EXPORT_SYMBOL_GPL(kunit_ptr_not_err_assert_format); +/* Checks if `text` is a literal representing `value`, e.g. "5" and 5 */ +static bool is_literal(struct kunit *test, const char *text, long long value, + gfp_t gfp) +{ + char *buffer; + int len; + bool ret; + + len = snprintf(NULL, 0, "%lld", value); + if (strlen(text) != len) + return false; + + buffer = kunit_kmalloc(test, len+1, gfp); + if (!buffer) + return false; + + snprintf(buffer, len+1, "%lld", value); + ret = strncmp(buffer, text, len) == 0; + + kunit_kfree(test, buffer); + return ret; +} + void kunit_binary_assert_format(const struct kunit_assert *assert, struct string_stream *stream) { @@ -97,12 +120,16 @@ void kunit_binary_assert_format(const struct kunit_assert *assert, binary_assert->left_text, binary_assert->operation, binary_assert->right_text); - string_stream_add(stream, KUNIT_SUBSUBTEST_INDENT "%s == %lld\n", - binary_assert->left_text, - binary_assert->left_value); - string_stream_add(stream, KUNIT_SUBSUBTEST_INDENT "%s == %lld", - binary_assert->right_text, - binary_assert->right_value); + if (!is_literal(stream->test, binary_assert->left_text, + binary_assert->left_value, stream->gfp)) + string_stream_add(stream, KUNIT_SUBSUBTEST_INDENT "%s == %lld\n", + binary_assert->left_text, + binary_assert->left_value); + if (!is_literal(stream->test, binary_assert->right_text, + binary_assert->right_value, stream->gfp)) + string_stream_add(stream, KUNIT_SUBSUBTEST_INDENT "%s == %lld", + binary_assert->right_text, + binary_assert->right_value); kunit_assert_print_msg(assert, stream); } EXPORT_SYMBOL_GPL(kunit_binary_assert_format); base-commit: 1e0d27fce010b0a4a9e595506b6ede75934c31be -- 2.30.0.478.g8a0d178c01-goog