File: test_exit-fast.py

package info (click to toggle)
ltt-control 2.14.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 21,860 kB
  • sloc: cpp: 192,012; sh: 28,777; ansic: 10,960; python: 7,108; makefile: 3,520; java: 109; xml: 46
file content (118 lines) | stat: -rw-r--r-- 3,344 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#!/usr/bin/env python3
#
# SPDX-FileCopyrightText: 2013 Jérémie Galarneau <jeremie.galarneau@efficios.com>
#
# SPDX-License-Identifier: GPL-2.0-only

import os
import subprocess
import re
import shutil
import sys

test_path = os.path.dirname(os.path.abspath(__file__)) + "/"
test_utils_path = test_path
for i in range(4):
    test_utils_path = os.path.dirname(test_utils_path)
test_utils_path = test_utils_path + "/utils"
sys.path.append(test_utils_path)
from test_utils import *


normal_exit_message = "exit-fast tracepoint normal exit"
suicide_exit_message = "exit-fast tracepoint suicide"
NR_TESTS = 5
current_test = 1
print("1..{0}".format(NR_TESTS))

# Check if a sessiond is running... bail out if none found.
if session_daemon_alive() == 0:
    bail(
        'No sessiond running. Please make sure you are running this test with the "run" shell script and verify that the lttng tools are properly installed.'
    )

session_info = create_session()
enable_ust_tracepoint_event(session_info, "ust_tests_exitfast*")
start_session(session_info)

test_env = os.environ.copy()
test_env["LTTNG_UST_REGISTER_TIMEOUT"] = "-1"

exit_fast_process = subprocess.Popen(
    test_path + "exit-fast",
    stdout=subprocess.DEVNULL,
    stderr=subprocess.DEVNULL,
    env=test_env,
)
exit_fast_process.wait()

print_test_result(
    exit_fast_process.returncode == 0, current_test, "Test application exited normally"
)
current_test += 1

exit_fast_process = subprocess.Popen(
    [test_path + "exit-fast", "suicide"],
    stdout=subprocess.DEVNULL,
    stderr=subprocess.DEVNULL,
    env=test_env,
)
exit_fast_process.wait()

stop_session(session_info)

# Check both events (normal exit and suicide messages) are present in the resulting trace
try:
    babeltrace_process = subprocess.Popen(
        [BABELTRACE_BIN, session_info.trace_path],
        stdout=subprocess.PIPE,
        stderr=subprocess.PIPE,
    )
except FileNotFoundError:
    bail("Could not open {}. Please make sure it is installed.".format(BABELTRACE_BIN))

event_lines = []
for event_line in babeltrace_process.stdout:
    event_line = event_line.decode("utf-8").replace("\n", "")
    event_lines.append(event_line)
babeltrace_process.wait()

print_test_result(
    babeltrace_process.returncode == 0, current_test, "Resulting trace is readable"
)
current_test += 1

if babeltrace_process.returncode != 0:
    bail("Unreadable trace; can't proceed with analysis.")

print_test_result(
    len(event_lines) == 2,
    current_test,
    "Correct number of events found in resulting trace",
)
current_test += 1

if len(event_lines) != 2:
    bail(
        "Unexpected number of events found in resulting trace ("
        + session_info.trace_path
        + ")."
    )

match = re.search(r".*message = \"(.*)\"", event_lines[0])
print_test_result(
    match is not None and match.group(1) == normal_exit_message,
    current_test,
    "Tracepoint message generated during normal exit run is present in trace and has the expected value",
)
current_test += 1

match = re.search(r".*message = \"(.*)\"", event_lines[1])
print_test_result(
    match is not None and match.group(1) == suicide_exit_message,
    current_test,
    "Tracepoint message generated during suicide run is present in trace and has the expected value",
)
current_test += 1

shutil.rmtree(session_info.tmp_directory)