Tests: Add syscall enable/disable scenarios
[lttng-tools.git] / tests / regression / kernel / test_syscall
index 7e95dbe10a7ba3cfda786026f27de850093ba709..9ce40dcc52bf5fc84ae7643090169d87630552ec 100755 (executable)
@@ -1,26 +1,16 @@
 #!/bin/bash
 #
-# Copyright (C) 2013 Christian Babeux <christian.babeux@efficios.com>
-# Copyright (C) 2014 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
+# Copyright (C) 2013 Christian Babeux <christian.babeux@efficios.com>
+# Copyright (C) 2014 Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
 #
-# This program is free software; you can redistribute it and/or modify it
-# under the terms of the GNU General Public License, version 2 only, as
-# published by the Free Software Foundation.
+# SPDX-License-Identifier: GPL-2.0-only
 #
-# This program is distributed in the hope that it will be useful, but WITHOUT
-# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
-# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
-# more details.
-#
-# You should have received a copy of the GNU General Public License along with
-# this program; if not, write to the Free Software Foundation, Inc., 51
-# Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 
 TEST_DESC="Kernel tracer - System calls"
 
 CURDIR=$(dirname $0)/
 TESTDIR=$CURDIR/../..
-NUM_TESTS=183
+NUM_TESTS=214
 
 # `gen-syscall-event` starts and waits for the creation a file passed by
 # arguments to start executing 3 syscalls (open,read,close) and returning.
@@ -339,6 +329,96 @@ function test_syscall_enable_all_disable_all_enable_all()
        rm -rf $TRACE_PATH
 }
 
+function test_syscall_enable_all_enable_one_disable_all()
+{
+       TRACE_PATH=$(mktemp -d)
+       SESSION_NAME="kernel_syscall_enable_all_enable_one_disable_all"
+
+       diag "Syscall trace all events, enable one and disable all"
+
+       create_lttng_session_ok $SESSION_NAME "$TRACE_PATH"
+
+       # enable all syscalls
+       lttng_enable_kernel_syscall_ok $SESSION_NAME
+
+       # enable one specific syscall, "openat"
+       lttng_enable_kernel_syscall_ok $SESSION_NAME openat
+
+       # disable all syscalls
+       lttng_disable_kernel_syscall_ok $SESSION_NAME
+
+       trace_testapp
+
+       # The trace shouldn't contain any syscalls, disable-all should disable
+       # even individually specified syscalls
+       trace_match_only openat 0 "$TRACE_PATH"
+
+       destroy_lttng_session_ok $SESSION_NAME
+
+       rm -rf "$TRACE_PATH"
+}
+
+function test_syscall_enable_one_enable_all_disable_one()
+{
+       TRACE_PATH=$(mktemp -d)
+       SESSION_NAME="kernel_syscall_enable_one_enable_all_disable_one"
+
+       diag "Syscall trace all events and enable/disable one"
+
+       create_lttng_session_ok $SESSION_NAME "$TRACE_PATH"
+
+       # enable one specific syscall, "openat"
+       lttng_enable_kernel_syscall_ok $SESSION_NAME openat
+
+       # enable all syscalls
+       lttng_enable_kernel_syscall_ok $SESSION_NAME
+
+       # disable one specific syscall, "openat"
+       lttng_disable_kernel_syscall_ok $SESSION_NAME openat
+
+       trace_testapp
+
+       # The trace should contain all syscalls, including 'openat' because
+       # enable-all overrides individually disabled syscalls.
+       validate_trace openat "$TRACE_PATH"
+
+       destroy_lttng_session_ok $SESSION_NAME
+
+       rm -rf "$TRACE_PATH"
+}
+
+function test_syscall_enable_one_enable_all_disable_all_disable_one()
+{
+       TRACE_PATH=$(mktemp -d)
+       SESSION_NAME="kernel_syscall_enable_one_enable_all_disable_all_disable_one"
+
+       diag "Syscall trace all events and enable/disable one"
+
+       create_lttng_session_ok $SESSION_NAME "$TRACE_PATH"
+
+       # enable one specific syscall, "openat"
+       lttng_enable_kernel_syscall_ok $SESSION_NAME openat
+
+       # enable all syscalls
+       lttng_enable_kernel_syscall_ok $SESSION_NAME
+
+       # disable all syscalls
+       lttng_disable_kernel_syscall_ok $SESSION_NAME
+
+       # disable one specific syscall, "openat"
+       lttng_disable_kernel_syscall_ok $SESSION_NAME openat
+
+       trace_testapp
+
+       # The trace shouldn't contain any syscalls, disable-all should disable
+       # even individually specified syscalls
+       trace_match_only openat 0 "$TRACE_PATH"
+
+       destroy_lttng_session_ok $SESSION_NAME
+
+       rm -rf "$TRACE_PATH"
+}
+
 function test_syscall_enable_all_disable_all_twice()
 {
        TRACE_PATH=$(mktemp -d)
@@ -606,6 +686,9 @@ skip $isroot "Root access is needed. Skipping all tests." $NUM_TESTS ||
        test_syscall_enable_all_disable_all
        test_syscall_enable_all_disable_all_enable_all
        test_syscall_enable_all_disable_all_twice
+       test_syscall_enable_all_enable_one_disable_all
+       test_syscall_enable_one_enable_all_disable_one
+       test_syscall_enable_one_enable_all_disable_all_disable_one
        test_syscall_enable_one_disable_one
        test_syscall_enable_two_disable_two
        test_syscall_enable_two_disable_one
This page took 0.024652 seconds and 4 git commands to generate.