File: debug.bats

package info (click to toggle)
runc 1.3.3%2Bds1-3
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 3,136 kB
  • sloc: sh: 2,298; ansic: 1,125; makefile: 229
file content (73 lines) | stat: -rw-r--r-- 1,712 bytes parent folder | download | duplicates (5)
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
#!/usr/bin/env bats

load helpers

function setup() {
	setup_busybox
	update_config '.process.args = ["/bin/echo", "Hello World"]'
}

function teardown() {
	teardown_bundle
}

function check_debug() {
	[[ "$*" == *"nsexec container setup"* ]]
	[[ "$*" == *"child process in init()"* ]]
	[[ "$*" == *"init: closing the pipe to signal completion"* ]]
}

@test "global --debug" {
	# run hello-world
	runc --debug run test_hello
	[ "$status" -eq 0 ]

	# check expected debug output was sent to stderr
	[[ "${output}" == *"level=debug"* ]]
	check_debug "$output"
}

@test "global --debug to --log" {
	# run hello-world
	runc --log log.out --debug run test_hello
	[ "$status" -eq 0 ]

	# check output does not include debug info
	[[ "${output}" != *"level=debug"* ]]

	cat log.out >&2
	# check expected debug output was sent to log.out
	output=$(cat log.out)
	[[ "${output}" == *"level=debug"* ]]
	check_debug "$output"
}

@test "global --debug to --log --log-format 'text'" {
	# run hello-world
	runc --log log.out --log-format "text" --debug run test_hello
	[ "$status" -eq 0 ]

	# check output does not include debug info
	[[ "${output}" != *"level=debug"* ]]

	cat log.out >&2
	# check expected debug output was sent to log.out
	output=$(cat log.out)
	[[ "${output}" == *"level=debug"* ]]
	check_debug "$output"
}

@test "global --debug to --log --log-format 'json'" {
	# run hello-world
	runc --log log.out --log-format "json" --debug run test_hello
	[ "$status" -eq 0 ]

	# check output does not include debug info
	[[ "${output}" != *"level=debug"* ]]

	cat log.out >&2
	# check expected debug output was sent to log.out
	output=$(cat log.out)
	[[ "${output}" == *'"level":"debug"'* ]]
	check_debug "$output"
}