X-Git-Url: https://git.lttng.org/?a=blobdiff_plain;ds=sidebyside;f=tests%2Fregression%2Ftools%2Fregen-metadata%2Ftest_kernel;h=840be8e8515d7d2beb4bb62085ba363c5fb1cf79;hb=33e557114a2ba28e26e220a833e8a449c78b8b65;hp=04746dbbc090cd695e5448be3624e24c43d20405;hpb=9d16b343fb9e781fc8d8fa3c448a3f382306dd33;p=lttng-tools.git diff --git a/tests/regression/tools/regen-metadata/test_kernel b/tests/regression/tools/regen-metadata/test_kernel index 04746dbbc..840be8e85 100755 --- a/tests/regression/tools/regen-metadata/test_kernel +++ b/tests/regression/tools/regen-metadata/test_kernel @@ -11,47 +11,69 @@ TESTDIR=$CURDIR/../../.. EVENT_NAME="lttng_test_filter_event" SESSION_NAME="" -TRACE_PATH=$(mktemp -d) +TRACE_PATH=$(mktemp --tmpdir -d tmp.test_regen_metadata_kernel_trace_path.XXXXXX) -NUM_TESTS=18 +NUM_TESTS=24 source $TESTDIR/utils/utils.sh function test_kernel_streaming () { + local metadata_path + diag "Test kernel streaming with metadata regeneration" create_lttng_session_uri $SESSION_NAME net://localhost lttng_enable_kernel_event $SESSION_NAME $EVENT_NAME start_lttng_tracing_ok $SESSION_NAME echo -n "100" > /proc/lttng-test-filter-event + + # Baseline + stop_lttng_tracing_ok $SESSION_NAME + validate_trace $EVENT_NAME $TRACE_PATH/$HOSTNAME/$SESSION_NAME* + + # Find the metadata file + metadata_path=$(find "$TRACE_PATH/$HOSTNAME/$SESSION_NAME"* -name "metadata") + + # Empty the metadata file + echo -n > "$metadata_path" + + start_lttng_tracing_ok $SESSION_NAME regenerate_metadata_ok $SESSION_NAME stop_lttng_tracing_ok $SESSION_NAME # Validate test validate_trace $EVENT_NAME $TRACE_PATH/$HOSTNAME/$SESSION_NAME* - if [ $? -eq 0 ]; then - # Only delete if successful - rm -rf $TRACE_PATH - else - break - fi destroy_lttng_session_ok $SESSION_NAME + rm -rf "$TRACE_PATH" } function test_kernel_local () { + local metadata_path + diag "Test kernel local with metadata regeneration" create_lttng_session_ok $SESSION_NAME $TRACE_PATH lttng_enable_kernel_event $SESSION_NAME $EVENT_NAME start_lttng_tracing_ok $SESSION_NAME + + # Baseline echo -n "100" > /proc/lttng-test-filter-event + stop_lttng_tracing_ok $SESSION_NAME + validate_trace $EVENT_NAME "$TRACE_PATH" + + # Find the metadata file + metadata_path=$(find "$TRACE_PATH"* -name "metadata") + + # Empty the metadata file + echo -n > "$metadata_path" + + start_lttng_tracing_ok $SESSION_NAME regenerate_metadata_ok $SESSION_NAME stop_lttng_tracing_ok $SESSION_NAME + validate_trace $EVENT_NAME $TRACE_PATH - if [ $? -eq 0 ]; then - # Only delete if successful - rm -rf $TRACE_PATH - fi destroy_lttng_session_ok $SESSION_NAME + + rm -rf "$TRACE_PATH" } plan_tests $NUM_TESTS @@ -80,7 +102,7 @@ skip $isroot "Root access is needed. Skipping all kernel streaming tests." $NUM_ ${fct_test} done - rmmod lttng-test + modprobe --remove lttng-test stop_lttng_sessiond stop_lttng_relayd }