234 lines
5.9 KiB
Bash
234 lines
5.9 KiB
Bash
#!/usr/bin/env bats
|
|
|
|
load helpers
|
|
|
|
function setup() {
|
|
teardown_busybox
|
|
setup_busybox
|
|
}
|
|
|
|
function teardown() {
|
|
teardown_busybox
|
|
}
|
|
|
|
@test "runc run [tty ptsname]" {
|
|
# Replace sh script with readlink.
|
|
update_config '(.. | select(.[]? == "sh")) += ["-c", "for file in /proc/self/fd/[012]; do readlink $file; done"]'
|
|
|
|
# run busybox
|
|
runc run test_busybox
|
|
[ "$status" -eq 0 ]
|
|
[[ ${lines[0]} =~ /dev/pts/+ ]]
|
|
[[ ${lines[1]} =~ /dev/pts/+ ]]
|
|
[[ ${lines[2]} =~ /dev/pts/+ ]]
|
|
}
|
|
|
|
@test "runc run [tty owner]" {
|
|
# tty chmod is not doable in rootless containers without idmap.
|
|
# TODO: this can be made as a change to the gid test.
|
|
[[ "$ROOTLESS" -ne 0 ]] && requires rootless_idmap
|
|
|
|
# Replace sh script with stat.
|
|
update_config '(.. | select(.[]? == "sh")) += ["-c", "stat -c %u:%g $(tty) | tr : \\\\n"]'
|
|
|
|
# run busybox
|
|
runc run test_busybox
|
|
[ "$status" -eq 0 ]
|
|
[[ ${lines[0]} =~ 0 ]]
|
|
# This is set by the default config.json (it corresponds to the standard tty group).
|
|
[[ ${lines[1]} =~ 5 ]]
|
|
}
|
|
|
|
@test "runc run [tty owner] ({u,g}id != 0)" {
|
|
# tty chmod is not doable in rootless containers without idmap.
|
|
[[ "$ROOTLESS" -ne 0 ]] && requires rootless_idmap
|
|
|
|
# replace "uid": 0 with "uid": 1000
|
|
# and do a similar thing for gid.
|
|
# Replace sh script with stat.
|
|
update_config ' (.. | select(.uid? == 0)) .uid |= 1000
|
|
| (.. | select(.gid? == 0)) .gid |= 100
|
|
| (.. | select(.[]? == "sh")) += ["-c", "stat -c %u:%g $(tty) | tr : \\\\n"]'
|
|
|
|
# run busybox
|
|
runc run test_busybox
|
|
[ "$status" -eq 0 ]
|
|
[[ ${lines[0]} =~ 1000 ]]
|
|
# This is set by the default config.json (it corresponds to the standard tty group).
|
|
[[ ${lines[1]} =~ 5 ]]
|
|
}
|
|
|
|
@test "runc exec [tty ptsname]" {
|
|
# run busybox detached
|
|
runc run -d --console-socket $CONSOLE_SOCKET test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
# make sure we're running
|
|
testcontainer test_busybox running
|
|
|
|
# run the exec
|
|
runc exec -t test_busybox sh -c 'for file in /proc/self/fd/[012]; do readlink $file; done'
|
|
[ "$status" -eq 0 ]
|
|
[[ ${lines[0]} =~ /dev/pts/+ ]]
|
|
[[ ${lines[1]} =~ /dev/pts/+ ]]
|
|
[[ ${lines[2]} =~ /dev/pts/+ ]]
|
|
}
|
|
|
|
@test "runc exec [tty owner]" {
|
|
# tty chmod is not doable in rootless containers without idmap.
|
|
# TODO: this can be made as a change to the gid test.
|
|
[[ "$ROOTLESS" -ne 0 ]] && requires rootless_idmap
|
|
|
|
# run busybox detached
|
|
runc run -d --console-socket $CONSOLE_SOCKET test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
# make sure we're running
|
|
testcontainer test_busybox running
|
|
|
|
# run the exec
|
|
runc exec -t test_busybox sh -c 'stat -c %u:%g $(tty) | tr : \\n'
|
|
[ "$status" -eq 0 ]
|
|
[[ ${lines[0]} =~ 0 ]]
|
|
[[ ${lines[1]} =~ 5 ]]
|
|
}
|
|
|
|
@test "runc exec [tty owner] ({u,g}id != 0)" {
|
|
# tty chmod is not doable in rootless containers without idmap.
|
|
[[ "$ROOTLESS" -ne 0 ]] && requires rootless_idmap
|
|
|
|
# replace "uid": 0 with "uid": 1000
|
|
# and do a similar thing for gid.
|
|
update_config ' (.. | select(.uid? == 0)) .uid |= 1000
|
|
| (.. | select(.gid? == 0)) .gid |= 100'
|
|
|
|
# run busybox detached
|
|
runc run -d --console-socket $CONSOLE_SOCKET test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
# make sure we're running
|
|
testcontainer test_busybox running
|
|
|
|
# run the exec
|
|
runc exec -t test_busybox sh -c 'stat -c %u:%g $(tty) | tr : \\n'
|
|
[ "$status" -eq 0 ]
|
|
[[ ${lines[0]} =~ 1000 ]]
|
|
[[ ${lines[1]} =~ 5 ]]
|
|
}
|
|
|
|
@test "runc exec [tty consolesize]" {
|
|
# allow writing to filesystem
|
|
update_config '(.. | select(.readonly? != null)) .readonly |= false'
|
|
|
|
# run busybox detached
|
|
runc run -d --console-socket $CONSOLE_SOCKET test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
# make sure we're running
|
|
testcontainer test_busybox running
|
|
|
|
tty_info_with_consize_size=$( cat <<EOF
|
|
{
|
|
"terminal": true,
|
|
"consoleSize": {
|
|
"height": 10,
|
|
"width": 110
|
|
},
|
|
"args": [
|
|
"/bin/sh",
|
|
"-c",
|
|
"/bin/stty -a > /tmp/tty-info"
|
|
],
|
|
"cwd": "/"
|
|
}
|
|
EOF
|
|
)
|
|
|
|
# run the exec
|
|
runc exec -t --pid-file pid.txt -d --console-socket $CONSOLE_SOCKET -p <( echo $tty_info_with_consize_size ) test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
# check the pid was generated
|
|
[ -e pid.txt ]
|
|
|
|
#wait user process to finish
|
|
timeout 1 tail --pid=$(head -n 1 pid.txt) -f /dev/null
|
|
|
|
tty_info=$( cat <<EOF
|
|
{
|
|
"args": [
|
|
"/bin/cat",
|
|
"/tmp/tty-info"
|
|
],
|
|
"cwd": "/"
|
|
}
|
|
EOF
|
|
)
|
|
|
|
# run the exec
|
|
runc exec -t -p <( echo $tty_info ) test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
# test tty width and height against original process.json
|
|
[[ ${lines[0]} =~ "rows 10; columns 110" ]]
|
|
}
|
|
|
|
@test "runc create [terminal=false]" {
|
|
# Disable terminal creation.
|
|
# Replace sh script with sleep.
|
|
update_config ' (.. | select(.terminal? != null)) .terminal |= false
|
|
| (.. | select(.[]? == "sh")) += ["sleep", "1000s"]
|
|
| del(.. | select(.? == "sh"))'
|
|
|
|
# Make sure that the handling of detached IO is done properly. See #1354.
|
|
__runc create test_busybox
|
|
|
|
# Start the command.
|
|
runc start test_busybox
|
|
[ "$status" -eq 0 ]
|
|
|
|
testcontainer test_busybox running
|
|
|
|
# Kill the container.
|
|
runc kill test_busybox KILL
|
|
[ "$status" -eq 0 ]
|
|
}
|
|
|
|
@test "runc run [terminal=false]" {
|
|
# Disable terminal creation.
|
|
# Replace sh script with sleep.
|
|
|
|
update_config ' (.. | select(.terminal? != null)) .terminal |= false
|
|
| (.. | select(.[]? == "sh")) += ["sleep", "1000s"]
|
|
| del(.. | select(.? == "sh"))'
|
|
|
|
# Make sure that the handling of non-detached IO is done properly. See #1354.
|
|
(
|
|
__runc run test_busybox
|
|
) &
|
|
|
|
wait_for_container 15 1 test_busybox running
|
|
testcontainer test_busybox running
|
|
|
|
# Kill the container.
|
|
runc kill test_busybox KILL
|
|
[ "$status" -eq 0 ]
|
|
}
|
|
|
|
@test "runc run -d [terminal=false]" {
|
|
# Disable terminal creation.
|
|
# Replace sh script with sleep.
|
|
update_config ' (.. | select(.terminal? != null)) .terminal |= false
|
|
| (.. | select(.[]? == "sh")) += ["sleep", "1000s"]
|
|
| del(.. | select(.? == "sh"))'
|
|
|
|
# Make sure that the handling of detached IO is done properly. See #1354.
|
|
__runc run -d test_busybox
|
|
|
|
testcontainer test_busybox running
|
|
|
|
# Kill the container.
|
|
runc kill test_busybox KILL
|
|
[ "$status" -eq 0 ]
|
|
}
|