#!/bin/sh test_description='test trace2 facility (normal target)' TEST_PASSES_SANITIZE_LEAK=true . ./test-lib.sh # Turn off any inherited trace2 settings for this test. sane_unset GIT_TRACE2 GIT_TRACE2_PERF GIT_TRACE2_EVENT sane_unset GIT_TRACE2_BRIEF sane_unset GIT_TRACE2_CONFIG_PARAMS # Add t/helper directory to PATH so that we can use a relative # path to run nested instances of test-tool.exe (see 004child). # This helps with HEREDOC comparisons later. TTDIR="$GIT_BUILD_DIR/t/helper/" && export TTDIR PATH="$TTDIR:$PATH" && export PATH # Warning: use of 'test_cmp' may run test-tool.exe and/or git.exe # Warning: to do the actual diff/comparison, so the HEREDOCs here # Warning: only cover our actual calls to test-tool and/or git. # Warning: So you may see extra lines in artifact files when # Warning: interactively debugging. V=$(git version | sed -e 's/^git version //') && export V # There are multiple trace2 targets: normal, perf, and event. # Trace2 events will/can be written to each active target (subject # to whatever filtering that target decides to do). # This script tests the normal target in isolation. # # Defer setting GIT_TRACE2 until the actual command line we want to test # because hidden git and test-tool commands run by the test harness # can contaminate our output. # Enable "brief" feature which turns off "<clock> <file>:<line> " prefix. GIT_TRACE2_BRIEF=1 && export GIT_TRACE2_BRIEF # Basic tests of the trace2 normal stream. Since this stream is used # primarily with printf-style debugging/tracing, we do limited testing # here. # # We do confirm the following API features: # [] the 'version <v>' event # [] the 'start <argv>' event # [] the 'cmd_name <name>' event # [] the 'exit <time> code:<code>' event # [] the 'atexit <time> code:<code>' event # # Fields of the form _FIELD_ are tokens that have been replaced (such # as the elapsed time). # Verb 001return # # Implicit return from cmd_<verb> function propagates <code>. test_expect_success 'normal stream, return code 0' ' test_when_finished "rm trace.normal actual expect" && GIT_TRACE2="$(pwd)/trace.normal" test-tool trace2 001return 0 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 001return 0 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:0 atexit elapsed:_TIME_ code:0 EOF test_cmp expect actual ' test_expect_success 'normal stream, return code 1' ' test_when_finished "rm trace.normal actual expect" && test_must_fail env GIT_TRACE2="$(pwd)/trace.normal" test-tool trace2 001return 1 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 001return 1 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:1 atexit elapsed:_TIME_ code:1 EOF test_cmp expect actual ' test_expect_success 'automatic filename' ' test_when_finished "rm -r traces actual expect" && mkdir traces && GIT_TRACE2="$(pwd)/traces" test-tool trace2 001return 0 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <"$(ls traces/*)" >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 001return 0 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:0 atexit elapsed:_TIME_ code:0 EOF test_cmp expect actual ' # Verb 002exit # # Explicit exit(code) from within cmd_<verb> propagates <code>. test_expect_success 'normal stream, exit code 0' ' test_when_finished "rm trace.normal actual expect" && GIT_TRACE2="$(pwd)/trace.normal" test-tool trace2 002exit 0 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 002exit 0 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:0 atexit elapsed:_TIME_ code:0 EOF test_cmp expect actual ' test_expect_success 'normal stream, exit code 1' ' test_when_finished "rm trace.normal actual expect" && test_must_fail env GIT_TRACE2="$(pwd)/trace.normal" test-tool trace2 002exit 1 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 002exit 1 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:1 atexit elapsed:_TIME_ code:1 EOF test_cmp expect actual ' # Verb 003error # # To the above, add multiple 'error <msg>' events test_expect_success 'normal stream, error event' ' test_when_finished "rm trace.normal actual expect" && GIT_TRACE2="$(pwd)/trace.normal" test-tool trace2 003error "hello world" "this is a test" && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 003error '\''hello world'\'' '\''this is a test'\'' cmd_name trace2 (trace2) error hello world error this is a test exit elapsed:_TIME_ code:0 atexit elapsed:_TIME_ code:0 EOF test_cmp expect actual ' # Verb 007bug # # Check that BUG writes to trace2 test_expect_success 'BUG messages are written to trace2' ' test_when_finished "rm trace.normal actual expect" && test_must_fail env GIT_TRACE2="$(pwd)/trace.normal" test-tool trace2 007bug && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 007bug cmd_name trace2 (trace2) error the bug message exit elapsed:_TIME_ code:99 atexit elapsed:_TIME_ code:99 EOF test_cmp expect actual ' test_expect_success 'bug messages with BUG_if_bug() are written to trace2' ' test_when_finished "rm trace.normal actual expect" && test_expect_code 99 env GIT_TRACE2="$(pwd)/trace.normal" \ test-tool trace2 008bug 2>err && cat >expect <<-\EOF && a bug message another bug message an explicit BUG_if_bug() following bug() call(s) is nice, but not required EOF sed "s/^.*: //" <err >actual && test_cmp expect actual && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 008bug cmd_name trace2 (trace2) error a bug message error another bug message error an explicit BUG_if_bug() following bug() call(s) is nice, but not required exit elapsed:_TIME_ code:99 atexit elapsed:_TIME_ code:99 EOF test_cmp expect actual ' test_expect_success 'bug messages without explicit BUG_if_bug() are written to trace2' ' test_when_finished "rm trace.normal actual expect" && test_expect_code 99 env GIT_TRACE2="$(pwd)/trace.normal" \ test-tool trace2 009bug_BUG 2>err && cat >expect <<-\EOF && a bug message another bug message had bug() call(s) in this process without explicit BUG_if_bug() EOF sed "s/^.*: //" <err >actual && test_cmp expect actual && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 009bug_BUG cmd_name trace2 (trace2) error a bug message error another bug message error on exit(): had bug() call(s) in this process without explicit BUG_if_bug() exit elapsed:_TIME_ code:99 atexit elapsed:_TIME_ code:99 EOF test_cmp expect actual ' test_expect_success 'bug messages followed by BUG() are written to trace2' ' test_when_finished "rm trace.normal actual expect" && test_expect_code 99 env GIT_TRACE2="$(pwd)/trace.normal" \ test-tool trace2 010bug_BUG 2>err && cat >expect <<-\EOF && a bug message a BUG message EOF sed "s/^.*: //" <err >actual && test_cmp expect actual && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 010bug_BUG cmd_name trace2 (trace2) error a bug message error a BUG message exit elapsed:_TIME_ code:99 atexit elapsed:_TIME_ code:99 EOF test_cmp expect actual ' sane_unset GIT_TRACE2_BRIEF # Now test without environment variables and get all Trace2 settings # from the global config. test_expect_success 'using global config, normal stream, return code 0' ' test_when_finished "rm trace.normal actual expect" && test_config_global trace2.normalBrief 1 && test_config_global trace2.normalTarget "$(pwd)/trace.normal" && test-tool trace2 001return 0 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 001return 0 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:0 atexit elapsed:_TIME_ code:0 EOF test_cmp expect actual ' test_expect_success 'using global config with include' ' test_when_finished "rm trace.normal actual expect real.gitconfig" && test_config_global trace2.normalBrief 1 && test_config_global trace2.normalTarget "$(pwd)/trace.normal" && mv "$(pwd)/.gitconfig" "$(pwd)/real.gitconfig" && test_config_global include.path "$(pwd)/real.gitconfig" && test-tool trace2 001return 0 && perl "$TEST_DIRECTORY/t0210/scrub_normal.perl" <trace.normal >actual && cat >expect <<-EOF && version $V start _EXE_ trace2 001return 0 cmd_name trace2 (trace2) exit elapsed:_TIME_ code:0 atexit elapsed:_TIME_ code:0 EOF test_cmp expect actual ' test_done