Received: by 10.192.165.148 with SMTP id m20csp682525imm; Fri, 4 May 2018 18:17:28 -0700 (PDT) X-Google-Smtp-Source: AB8JxZq4NhTXzboFO/tIFGSABY1f3Txh2lDJONxVQUSSfphUbj7anhazKX1qUr9qOpmR7vRn7jEO X-Received: by 2002:a63:6fc8:: with SMTP id k191-v6mr23952199pgc.330.1525483048638; Fri, 04 May 2018 18:17:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525483048; cv=none; d=google.com; s=arc-20160816; b=HC8oDXbZMhuUYp1yDRTBiQofC6XQF6tbjVZvpG+cXEA3kpKF+D5ViK7Upepj0CuIzt KalYwTGvj4Dm0fRMiGQFrcEyptZdXBkS1mFL6jMXLNmIoZZMLjMga5WfkO6fqMOYIso7 JkHTvMkIQTGYV+2ktsAXINNI1k/DX63Dx+gylfpMeIutk4eSI524AiuNq1hdJWSIV0RO S4j+/vVBLiUUpB1I/fvyGFe2imfpmQeYbx8kzo/NRzwi3S+o4wDiqknuL8y8mIqCXXcb S68CpTkJpkD32RwSSq5Zmk37dxo/+611rZI9DiyR6DPqbbVFBtUih1hmBKnJOrD/yxTi NTtw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=QHWo5CbokO9qnwo3kQ4cz/cjf7h50zLK97pGY76eWcY=; b=IwNdMhgYu6tfZ6UWgA49AM3r8ciLqKEJtuaB3PfRjjLEauoPsrFpAWxvVB9SshwBNe jCvgE2JyIb/rmvo2qpZd6YQdyf0KWc7zNQdjgdTn+tCLbUvKOQSm0/9zC3Wc6z7WdSNC cMQWfI8xggcXF7ETt+8bGp02pM3XTvif1gvYuSrJb3FBv4EmobsGWUBUu4JVW3MCUUoF HcT3OJFoIO5s1NNZNrv6KDVXbcgsoHh5U8+ov/ZETcKdrzFCFvdAxc8YfUSI1xYs0qkm MAeJSxaLWqkKVxYNFFcH8lSe4Eh6fWyW11R668EA58lzGuAmaadNMqrvMU+sLn/S5YGJ 2A7w== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k2si16992235pfg.75.2018.05.04.18.17.13; Fri, 04 May 2018 18:17:28 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752130AbeEEBQb (ORCPT + 99 others); Fri, 4 May 2018 21:16:31 -0400 Received: from mailout.easymail.ca ([64.68.200.34]:50521 "EHLO mailout.easymail.ca" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751808AbeEEBQ3 (ORCPT ); Fri, 4 May 2018 21:16:29 -0400 Received: from localhost (localhost [127.0.0.1]) by mailout.easymail.ca (Postfix) with ESMTP id 964A12125D; Sat, 5 May 2018 01:16:28 +0000 (UTC) Received: from mailout.easymail.ca ([127.0.0.1]) by localhost (emo02-pco.easydns.vpn [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id loPxx5uic3e0; Sat, 5 May 2018 01:16:28 +0000 (UTC) Received: from localhost.localdomain (c-24-9-64-241.hsd1.co.comcast.net [24.9.64.241]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mailout.easymail.ca (Postfix) with ESMTPSA id 3164021020; Sat, 5 May 2018 01:16:20 +0000 (UTC) From: "Shuah Khan (Samsung OSG)" To: shuah@kernel.org, pbonzini@redhat.com, hofsass@google.com Cc: linux-kselftest@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 14/24] selftests: kvm: return Kselftest Skip code for skipped tests Date: Fri, 4 May 2018 19:13:18 -0600 Message-Id: <20180505011328.32078-14-shuah@kernel.org> X-Mailer: git-send-email 2.14.1 In-Reply-To: <20180505011328.32078-1-shuah@kernel.org> References: <20180505011328.32078-1-shuah@kernel.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When kvm test is skipped because of unmet dependencies and/or unsupported configuration, it exits with error which is treated as a fail by the Kselftest framework. This leads to false negative result even when the test could not be run. Change it to return kselftest skip code when a test gets skipped to clearly report that the test could not be run. Change it to use ksft_exit_skip() when the test is skipped. In addition, refine test_assert() message to include strerror() string and add explicit check for root user to clearly identofy non-root user skip case. Signed-off-by: Shuah Khan (Samsung OSG) --- tools/testing/selftests/kvm/lib/assert.c | 10 ++++++++-- tools/testing/selftests/kvm/vmx_tsc_adjust_test.c | 4 +++- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/tools/testing/selftests/kvm/lib/assert.c b/tools/testing/selftests/kvm/lib/assert.c index c9f5b7d4ce38..4705729d847e 100644 --- a/tools/testing/selftests/kvm/lib/assert.c +++ b/tools/testing/selftests/kvm/lib/assert.c @@ -13,6 +13,8 @@ #include #include +#include "../../kselftest.h" + /* Dumps the current stack trace to stderr. */ static void __attribute__((noinline)) test_dump_stack(void); static void test_dump_stack(void) @@ -65,13 +67,17 @@ test_assert(bool exp, const char *exp_str, { va_list ap; + if (getuid() != 0) + ksft_exit_skip("Please run the test as root - Exiting.\n"); + if (!(exp)) { va_start(ap, fmt); fprintf(stderr, "==== Test Assertion Failure ====\n" " %s:%u: %s\n" - " pid=%d tid=%d\n", - file, line, exp_str, getpid(), gettid()); + " pid=%d tid=%d - %s\n", + file, line, exp_str, getpid(), gettid(), + strerror(errno)); test_dump_stack(); if (fmt) { fputs(" ", stderr); diff --git a/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c b/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c index 8f7f62093add..62fb73699eb6 100644 --- a/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c +++ b/tools/testing/selftests/kvm/vmx_tsc_adjust_test.c @@ -28,6 +28,8 @@ #include #include +#include "../kselftest.h" + #ifndef MSR_IA32_TSC_ADJUST #define MSR_IA32_TSC_ADJUST 0x3b #endif @@ -190,7 +192,7 @@ int main(int argc, char *argv[]) if (!(entry->ecx & CPUID_VMX)) { printf("nested VMX not enabled, skipping test"); - return 0; + return KSFT_SKIP; } vm = vm_create_default_vmx(VCPU_ID, (void *) l1_guest_code); -- 2.14.1