Merge pull request #812 from cyphar/integration-fix-cgroup-parsing

integration: fix cgroup parsing
This commit is contained in:
Mrunal Patel 2016-05-16 19:32:19 -07:00
commit 0d8878a6c0
20 changed files with 192 additions and 196 deletions

View File

@ -6,6 +6,7 @@ RUN echo 'deb http://httpredir.debian.org/debian jessie-backports main' > /etc/a
RUN apt-get update && apt-get install -y \ RUN apt-get update && apt-get install -y \
build-essential \ build-essential \
curl \ curl \
gawk \
iptables \ iptables \
libaio-dev \ libaio-dev \
libcap-dev \ libcap-dev \

View File

@ -21,7 +21,7 @@ Alternatively, you can run integration tests directly on your host through make:
``` ```
$ sudo make localintegration $ sudo make localintegration
``` ```
Or you can just run them directly using bats Or you can just run them directly using bats
``` ```
$ sudo bats tests/integration $ sudo bats tests/integration
``` ```
@ -32,17 +32,17 @@ $ make integration TESTFLAGS="/checkpoint.bats"
To run them on your host, you will need to setup a development environment plus To run them on your host, you will need to setup a development environment plus
[bats](https://github.com/sstephenson/bats#installing-bats-from-source) [bats](https://github.com/sstephenson/bats#installing-bats-from-source)
For example: For example:
``` ```
$ cd ~/go/src/github.com $ cd ~/go/src/github.com
$ git clone https://github.com/sstephenson/bats.git $ git clone https://github.com/sstephenson/bats.git
$ cd bats $ cd bats
$ ./install.sh /usr/local $ ./install.sh /usr/local
``` ```
> **Note**: There are known issues running the integration tests using > **Note**: There are known issues running the integration tests using
> **devicemapper** as a storage driver, make sure that your docker daemon > **devicemapper** as a storage driver, make sure that your docker daemon
> is using **aufs** if you want to successfully run the integration tests. > is using **aufs** if you want to successfully run the integration tests.
## Writing integration tests ## Writing integration tests

View File

@ -2,20 +2,17 @@
load helpers load helpers
UPDATE_TEST_RUNC_ROOT="$BATS_TMPDIR/runc-cgroups-integration-test"
CGROUP_MEMORY="" CGROUP_MEMORY=""
TEST_CGROUP_NAME="runc-cgroups-integration-test" TEST_CGROUP_NAME="runc-cgroups-integration-test"
function init_cgroup_path() { function init_cgroup_path() {
base_path=$(grep "rw," /proc/self/mountinfo | grep -i -m 1 'MEMORY$' | cut -d ' ' -f 5) base_path=$(grep "cgroup" /proc/self/mountinfo | gawk 'toupper($NF) ~ /\<MEMORY\>/ { print $5; exit }')
CGROUP_MEMORY="${base_path}/${TEST_CGROUP_NAME}" CGROUP_MEMORY="${base_path}/${TEST_CGROUP_NAME}"
} }
function teardown() { function teardown() {
rm -f $BATS_TMPDIR/runc-update-integration-test.json rm -f $BATS_TMPDIR/runc-update-integration-test.json
teardown_running_container_inroot test_cgroups_kmem $UPDATE_TEST_RUNC_ROOT teardown_running_container test_cgroups_kmem
teardown_busybox teardown_busybox
} }
@ -37,7 +34,7 @@ function check_cgroup_value() {
[ "$current" -eq "$expected" ] [ "$current" -eq "$expected" ]
} }
@test "cgroups-kernel-memory-initialized" { @test "runc update --kernel-memory (initialized)" {
# Add cgroup path # Add cgroup path
sed -i 's/\("linux": {\)/\1\n "cgroupsPath": "runc-cgroups-integration-test",/' ${BUSYBOX_BUNDLE}/config.json sed -i 's/\("linux": {\)/\1\n "cgroupsPath": "runc-cgroups-integration-test",/' ${BUSYBOX_BUNDLE}/config.json
@ -52,26 +49,26 @@ EOF
sed -i "s/\(\"resources\": {\)/\1\n${DATA}/" ${BUSYBOX_BUNDLE}/config.json sed -i "s/\(\"resources\": {\)/\1\n${DATA}/" ${BUSYBOX_BUNDLE}/config.json
# start a detached busybox to work with # start a detached busybox to work with
"$RUNC" --root $UPDATE_TEST_RUNC_ROOT start -d --console /dev/pts/ptmx test_cgroups_kmem run "$RUNC" start -d --console /dev/pts/ptmx test_cgroups_kmem
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container_inroot 15 1 test_cgroups_kmem $UPDATE_TEST_RUNC_ROOT wait_for_container 15 1 test_cgroups_kmem
# update kernel memory limit # update kernel memory limit
"$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_cgroups_kmem --kernel-memory 50331648 run "$RUNC" update test_cgroups_kmem --kernel-memory 50331648
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_MEMORY "memory.kmem.limit_in_bytes" 50331648 check_cgroup_value $CGROUP_MEMORY "memory.kmem.limit_in_bytes" 50331648
} }
@test "cgroups-kernel-memory-uninitialized" { @test "runc update --kernel-memory (uninitialized)" {
# Add cgroup path # Add cgroup path
sed -i 's/\("linux": {\)/\1\n "cgroupsPath": "runc-cgroups-integration-test",/' ${BUSYBOX_BUNDLE}/config.json sed -i 's/\("linux": {\)/\1\n "cgroupsPath": "runc-cgroups-integration-test",/' ${BUSYBOX_BUNDLE}/config.json
# start a detached busybox to work with # start a detached busybox to work with
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT start -d --console /dev/pts/ptmx test_cgroups_kmem run "$RUNC" start -d --console /dev/pts/ptmx test_cgroups_kmem
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container_inroot 15 1 test_cgroups_kmem $UPDATE_TEST_RUNC_ROOT wait_for_container 15 1 test_cgroups_kmem
# update kernel memory limit # update kernel memory limit
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_cgroups_kmem --kernel-memory 50331648 run "$RUNC" update test_cgroups_kmem --kernel-memory 50331648
[ ! "$status" -eq 0 ] [ ! "$status" -eq 0 ]
} }

View File

@ -15,27 +15,27 @@ function teardown() {
if [ ! -e "$CRIU" ] ; then if [ ! -e "$CRIU" ] ; then
skip skip
fi fi
# criu does not work with external terminals so.. # criu does not work with external terminals so..
# setting terminal and root:readonly: to false # setting terminal and root:readonly: to false
sed -i 's;"terminal": true;"terminal": false;' config.json sed -i 's;"terminal": true;"terminal": false;' config.json
sed -i 's;"readonly": true;"readonly": false;' config.json sed -i 's;"readonly": true;"readonly": false;' config.json
sed -i 's/"sh"/"sh","-c","while :; do date; sleep 1; done"/' config.json sed -i 's/"sh"/"sh","-c","while :; do date; sleep 1; done"/' config.json
( (
# start busybox (not detached) # start busybox (not detached)
run "$RUNC" start test_busybox run "$RUNC" start test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
) & ) &
# check state # check state
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
run "$RUNC" state test_busybox run "$RUNC" state test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${output}" == *"running"* ]] [[ "${output}" == *"running"* ]]
# checkpoint the running container # checkpoint the running container
run "$RUNC" --criu "$CRIU" checkpoint test_busybox run "$RUNC" --criu "$CRIU" checkpoint test_busybox
# if you are having problems getting criu to work uncomment the following dump: # if you are having problems getting criu to work uncomment the following dump:
#cat /run/opencontainer/containers/test_busybox/criu.work/dump.log #cat /run/opencontainer/containers/test_busybox/criu.work/dump.log
@ -44,13 +44,13 @@ function teardown() {
# after checkpoint busybox is no longer running # after checkpoint busybox is no longer running
run "$RUNC" state test_busybox run "$RUNC" state test_busybox
[ "$status" -ne 0 ] [ "$status" -ne 0 ]
# restore from checkpoint # restore from checkpoint
( (
run "$RUNC" --criu "$CRIU" restore test_busybox run "$RUNC" --criu "$CRIU" restore test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
) & ) &
# check state # check state
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox

View File

@ -25,10 +25,10 @@ function teardown() {
# check output does not include debug info # check output does not include debug info
[[ "${output}" != *"level=debug"* ]] [[ "${output}" != *"level=debug"* ]]
# check log.out was generated # check log.out was generated
[ -e log.out ] [ -e log.out ]
# check expected debug output was sent to log.out # check expected debug output was sent to log.out
run cat log.out run cat log.out
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
@ -43,9 +43,9 @@ function teardown() {
# check output does not include debug info # check output does not include debug info
[[ "${output}" != *"level=debug"* ]] [[ "${output}" != *"level=debug"* ]]
# check log.out was generated # check log.out was generated
[ -e log.out ] [ -e log.out ]
# check expected debug output was sent to log.out # check expected debug output was sent to log.out
run cat log.out run cat log.out
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
@ -56,13 +56,13 @@ function teardown() {
# start hello-world # start hello-world
run "$RUNC" --log log.out --log-format "json" --debug start test_hello run "$RUNC" --log log.out --log-format "json" --debug start test_hello
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# check output does not include debug info # check output does not include debug info
[[ "${output}" != *"level=debug"* ]] [[ "${output}" != *"level=debug"* ]]
# check log.out was generated # check log.out was generated
[ -e log.out ] [ -e log.out ]
# check expected debug output was sent to log.out # check expected debug output was sent to log.out
run cat log.out run cat log.out
[ "$status" -eq 0 ] [ "$status" -eq 0 ]

View File

@ -20,14 +20,14 @@ function teardown() {
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
testcontainer test_busybox running testcontainer test_busybox running
run "$RUNC" kill test_busybox KILL run "$RUNC" kill test_busybox KILL
# wait for busybox to be in the destroyed state # wait for busybox to be in the destroyed state
retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'"
# delete test_busybox # delete test_busybox
run "$RUNC" delete test_busybox run "$RUNC" delete test_busybox
run "$RUNC" state test_busybox run "$RUNC" state test_busybox
[ "$status" -ne 0 ] [ "$status" -ne 0 ]
} }

View File

@ -23,7 +23,7 @@ function startup_events() {
# check state # check state
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
# generate stats # generate stats
run "$RUNC" events --stats test_busybox run "$RUNC" events --stats test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${lines[0]}" == [\{]"\"type\""[:]"\"stats\""[,]"\"id\""[:]"\"test_busybox\""[,]* ]] [[ "${lines[0]}" == [\{]"\"type\""[:]"\"stats\""[,]"\"id\""[:]"\"test_busybox\""[,]* ]]
@ -37,20 +37,20 @@ function startup_events() {
# check state # check state
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
# spawn two sub processes (shells) # spawn two sub processes (shells)
# the first sub process is an event logger that sends stats events to events.log # the first sub process is an event logger that sends stats events to events.log
# the second sub process waits for an event that incudes test_busybox then # the second sub process waits for an event that incudes test_busybox then
# kills the test_busybox container which causes the event logger to exit # kills the test_busybox container which causes the event logger to exit
("$RUNC" events test_busybox > events.log) & ("$RUNC" events test_busybox > events.log) &
( (
retry 10 1 eval "grep -q 'test_busybox' events.log" retry 10 1 eval "grep -q 'test_busybox' events.log"
teardown_running_container test_busybox teardown_running_container test_busybox
) & ) &
wait # wait for the above sub shells to finish wait # wait for the above sub shells to finish
[ -e events.log ] [ -e events.log ]
run cat events.log run cat events.log
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${lines[0]}" == [\{]"\"type\""[:]"\"stats\""[,]"\"id\""[:]"\"test_busybox\""[,]* ]] [[ "${lines[0]}" == [\{]"\"type\""[:]"\"stats\""[,]"\"id\""[:]"\"test_busybox\""[,]* ]]
@ -64,21 +64,21 @@ function startup_events() {
# check state # check state
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
# spawn two sub processes (shells) # spawn two sub processes (shells)
# the first sub process is an event logger that sends stats events to events.log once a second # the first sub process is an event logger that sends stats events to events.log once a second
# the second sub process tries 3 times for an event that incudes test_busybox # the second sub process tries 3 times for an event that incudes test_busybox
# pausing 1s between each attempt then kills the test_busybox container which # pausing 1s between each attempt then kills the test_busybox container which
# causes the event logger to exit # causes the event logger to exit
("$RUNC" events --interval 1s test_busybox > events.log) & ("$RUNC" events --interval 1s test_busybox > events.log) &
( (
retry 3 1 eval "grep -q 'test_busybox' events.log" retry 3 1 eval "grep -q 'test_busybox' events.log"
teardown_running_container test_busybox teardown_running_container test_busybox
) & ) &
wait # wait for the above sub shells to finish wait # wait for the above sub shells to finish
[ -e events.log ] [ -e events.log ]
run eval "grep -q 'test_busybox' events.log" run eval "grep -q 'test_busybox' events.log"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
} }
@ -90,24 +90,24 @@ function startup_events() {
# check state # check state
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
#prove there is no carry over of events.log from a prior test #prove there is no carry over of events.log from a prior test
[ ! -e events.log ] [ ! -e events.log ]
# spawn two sub processes (shells) # spawn two sub processes (shells)
# the first sub process is an event logger that sends stats events to events.log once every 100ms # the first sub process is an event logger that sends stats events to events.log once every 100ms
# the second sub process tries 3 times for an event that incudes test_busybox # the second sub process tries 3 times for an event that incudes test_busybox
# pausing 100s between each attempt then kills the test_busybox container which # pausing 100s between each attempt then kills the test_busybox container which
# causes the event logger to exit # causes the event logger to exit
("$RUNC" events --interval 100ms test_busybox > events.log) & ("$RUNC" events --interval 100ms test_busybox > events.log) &
( (
retry 3 0.100 eval "grep -q 'test_busybox' events.log" retry 3 0.100 eval "grep -q 'test_busybox' events.log"
teardown_running_container test_busybox teardown_running_container test_busybox
) & ) &
wait # wait for the above sub shells to finish wait # wait for the above sub shells to finish
[ -e events.log ] [ -e events.log ]
run eval "grep -q 'test_busybox' events.log" run eval "grep -q 'test_busybox' events.log"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
} }

View File

@ -18,9 +18,9 @@ function teardown() {
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
run "$RUNC" exec test_busybox echo Hello from exec run "$RUNC" exec test_busybox echo Hello from exec
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
echo text echoed = "'""${output}""'" echo text echoed = "'""${output}""'"
[[ "${output}" == *"Hello from exec"* ]] [[ "${output}" == *"Hello from exec"* ]]
} }
@ -31,12 +31,12 @@ function teardown() {
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
run "$RUNC" exec --pid-file pid.txt test_busybox echo Hello from exec run "$RUNC" exec --pid-file pid.txt test_busybox echo Hello from exec
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
echo text echoed = "'""${output}""'" echo text echoed = "'""${output}""'"
[[ "${output}" == *"Hello from exec"* ]] [[ "${output}" == *"Hello from exec"* ]]
# check pid.txt was generated # check pid.txt was generated
[ -e pid.txt ] [ -e pid.txt ]
run cat pid.txt run cat pid.txt

View File

@ -7,7 +7,7 @@ load helpers
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ NAME:+ ]] [[ ${lines[0]} =~ NAME:+ ]]
[[ ${lines[1]} =~ runc\ '-'\ Open\ Container\ Initiative\ runtime+ ]] [[ ${lines[1]} =~ runc\ '-'\ Open\ Container\ Initiative\ runtime+ ]]
run "$RUNC" --help run "$RUNC" --help
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ NAME:+ ]] [[ ${lines[0]} =~ NAME:+ ]]
@ -18,11 +18,11 @@ load helpers
run "$RUNC" checkpoint -h run "$RUNC" checkpoint -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ checkpoint+ ]] [[ ${lines[1]} =~ runc\ checkpoint+ ]]
run "$RUNC" delete -h run "$RUNC" delete -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ delete+ ]] [[ ${lines[1]} =~ runc\ delete+ ]]
run "$RUNC" events -h run "$RUNC" events -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ events+ ]] [[ ${lines[1]} =~ runc\ events+ ]]
@ -30,49 +30,49 @@ load helpers
run "$RUNC" exec -h run "$RUNC" exec -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ exec+ ]] [[ ${lines[1]} =~ runc\ exec+ ]]
run "$RUNC" kill -h run "$RUNC" kill -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ kill+ ]] [[ ${lines[1]} =~ runc\ kill+ ]]
run "$RUNC" list -h run "$RUNC" list -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ NAME:+ ]] [[ ${lines[0]} =~ NAME:+ ]]
[[ ${lines[1]} =~ runc\ list+ ]] [[ ${lines[1]} =~ runc\ list+ ]]
run "$RUNC" list --help run "$RUNC" list --help
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ NAME:+ ]] [[ ${lines[0]} =~ NAME:+ ]]
[[ ${lines[1]} =~ runc\ list+ ]] [[ ${lines[1]} =~ runc\ list+ ]]
run "$RUNC" pause -h run "$RUNC" pause -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ pause+ ]] [[ ${lines[1]} =~ runc\ pause+ ]]
run "$RUNC" restore -h run "$RUNC" restore -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ restore+ ]] [[ ${lines[1]} =~ runc\ restore+ ]]
run "$RUNC" resume -h run "$RUNC" resume -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ resume+ ]] [[ ${lines[1]} =~ runc\ resume+ ]]
run "$RUNC" spec -h run "$RUNC" spec -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ spec+ ]] [[ ${lines[1]} =~ runc\ spec+ ]]
run "$RUNC" start -h run "$RUNC" start -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ start+ ]] [[ ${lines[1]} =~ runc\ start+ ]]
run "$RUNC" state -h run "$RUNC" state -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ state+ ]] [[ ${lines[1]} =~ runc\ state+ ]]
run "$RUNC" delete -h run "$RUNC" delete -h
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[1]} =~ runc\ delete+ ]] [[ ${lines[1]} =~ runc\ delete+ ]]
} }
@test "runc foo -h" { @test "runc foo -h" {

View File

@ -8,11 +8,11 @@ GOPATH="${INTEGRATION_ROOT}/../../../.."
# Test data path. # Test data path.
TESTDATA="${INTEGRATION_ROOT}/testdata" TESTDATA="${INTEGRATION_ROOT}/testdata"
# Busybox image # Busybox image
BUSYBOX_IMAGE="$BATS_TMPDIR/busybox.tar" BUSYBOX_IMAGE="$BATS_TMPDIR/busybox.tar"
BUSYBOX_BUNDLE="$BATS_TMPDIR/busyboxtest" BUSYBOX_BUNDLE="$BATS_TMPDIR/busyboxtest"
# hello-world in tar format # hello-world in tar format
HELLO_IMAGE="$TESTDATA/hello-world.tar" HELLO_IMAGE="$TESTDATA/hello-world.tar"
HELLO_BUNDLE="$BATS_TMPDIR/hello-world" HELLO_BUNDLE="$BATS_TMPDIR/hello-world"
@ -78,20 +78,20 @@ function wait_for_container_inroot() {
} }
function testcontainer() { function testcontainer() {
# test state of container # test state of container
run "$RUNC" state $1 run "$RUNC" state $1
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${output}" == *"$2"* ]] [[ "${output}" == *"$2"* ]]
} }
function setup_busybox() { function setup_busybox() {
run mkdir "$BUSYBOX_BUNDLE" run mkdir "$BUSYBOX_BUNDLE"
run mkdir "$BUSYBOX_BUNDLE"/rootfs run mkdir "$BUSYBOX_BUNDLE"/rootfs
if [ -e "/testdata/busybox.tar" ]; then if [ -e "/testdata/busybox.tar" ]; then
BUSYBOX_IMAGE="/testdata/busybox.tar" BUSYBOX_IMAGE="/testdata/busybox.tar"
fi fi
if [ ! -e $BUSYBOX_IMAGE ]; then if [ ! -e $BUSYBOX_IMAGE ]; then
curl -o $BUSYBOX_IMAGE -sSL 'https://github.com/jpetazzo/docker-busybox/raw/buildroot-2014.11/rootfs.tar' curl -o $BUSYBOX_IMAGE -sSL 'https://github.com/jpetazzo/docker-busybox/raw/buildroot-2014.11/rootfs.tar'
fi fi
tar -C "$BUSYBOX_BUNDLE"/rootfs -xf "$BUSYBOX_IMAGE" tar -C "$BUSYBOX_BUNDLE"/rootfs -xf "$BUSYBOX_IMAGE"
cd "$BUSYBOX_BUNDLE" cd "$BUSYBOX_BUNDLE"
@ -99,7 +99,7 @@ function setup_busybox() {
} }
function setup_hello() { function setup_hello() {
run mkdir "$HELLO_BUNDLE" run mkdir "$HELLO_BUNDLE"
run mkdir "$HELLO_BUNDLE"/rootfs run mkdir "$HELLO_BUNDLE"/rootfs
tar -C "$HELLO_BUNDLE"/rootfs -xf "$HELLO_IMAGE" tar -C "$HELLO_BUNDLE"/rootfs -xf "$HELLO_IMAGE"
cd "$HELLO_BUNDLE" cd "$HELLO_BUNDLE"
@ -108,19 +108,19 @@ function setup_hello() {
} }
function teardown_running_container() { function teardown_running_container() {
run "$RUNC" list run "$RUNC" list
if [[ "${output}" == *"$1"* ]]; then if [[ "${output}" == *"$1"* ]]; then
run "$RUNC" kill $1 KILL run "$RUNC" kill $1 KILL
retry 10 1 eval "'$RUNC' state '$1' | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' state '$1' | grep -q 'destroyed'"
run "$RUNC" delete $1 run "$RUNC" delete $1
fi fi
} }
function teardown_running_container_inroot() { function teardown_running_container_inroot() {
run "$RUNC" --root $2 list run "$RUNC" --root $2 list
if [[ "${output}" == *"$1"* ]]; then if [[ "${output}" == *"$1"* ]]; then
run "$RUNC" --root $2 kill $1 KILL run "$RUNC" --root $2 kill $1 KILL
retry 10 1 eval "'$RUNC' --root '$2' state '$1' | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' --root '$2' state '$1' | grep -q 'destroyed'"
run "$RUNC" --root $2 delete $1 run "$RUNC" --root $2 delete $1
fi fi
} }

View File

@ -13,7 +13,7 @@ function teardown() {
@test "kill detached busybox" { @test "kill detached busybox" {
# start busybox detached # start busybox detached
run "$RUNC" start -d --console /dev/pts/ptmx test_busybox run "$RUNC" start -d --console /dev/pts/ptmx test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
@ -22,12 +22,12 @@ function teardown() {
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
testcontainer test_busybox running testcontainer test_busybox running
run "$RUNC" kill test_busybox KILL run "$RUNC" kill test_busybox KILL
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'"
run "$RUNC" delete test_busybox run "$RUNC" delete test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
} }

View File

@ -22,29 +22,29 @@ function teardown() {
run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_box1 run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_box1
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container_inroot 15 1 test_box1 $HELLO_BUNDLE wait_for_container_inroot 15 1 test_box1 $HELLO_BUNDLE
run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_box2 run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_box2
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container_inroot 15 1 test_box2 $HELLO_BUNDLE wait_for_container_inroot 15 1 test_box2 $HELLO_BUNDLE
run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_box3 run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_box3
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container_inroot 15 1 test_box3 $HELLO_BUNDLE wait_for_container_inroot 15 1 test_box3 $HELLO_BUNDLE
run "$RUNC" --root $HELLO_BUNDLE list run "$RUNC" --root $HELLO_BUNDLE list
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ ID\ +PID\ +STATUS\ +BUNDLE\ +CREATED+ ]] [[ ${lines[0]} =~ ID\ +PID\ +STATUS\ +BUNDLE\ +CREATED+ ]]
[[ "${lines[1]}" == *"test_box1"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]] [[ "${lines[1]}" == *"test_box1"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]]
[[ "${lines[2]}" == *"test_box2"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]] [[ "${lines[2]}" == *"test_box2"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]]
[[ "${lines[3]}" == *"test_box3"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]] [[ "${lines[3]}" == *"test_box3"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]]
run "$RUNC" --root $HELLO_BUNDLE list --format table run "$RUNC" --root $HELLO_BUNDLE list --format table
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ ID\ +PID\ +STATUS\ +BUNDLE\ +CREATED+ ]] [[ ${lines[0]} =~ ID\ +PID\ +STATUS\ +BUNDLE\ +CREATED+ ]]
[[ "${lines[1]}" == *"test_box1"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]] [[ "${lines[1]}" == *"test_box1"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]]
[[ "${lines[2]}" == *"test_box2"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]] [[ "${lines[2]}" == *"test_box2"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]]
[[ "${lines[3]}" == *"test_box3"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]] [[ "${lines[3]}" == *"test_box3"*[0-9]*"running"*$BUSYBOX_BUNDLE*[0-9]* ]]
run "$RUNC" --root $HELLO_BUNDLE list --format json run "$RUNC" --root $HELLO_BUNDLE list --format json
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${lines[0]}" == [\[][\{]"\"id\""[:]"\"test_box1\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"created\""[:]*[0-9]*[\}]* ]] [[ "${lines[0]}" == [\[][\{]"\"id\""[:]"\"test_box1\""[,]"\"pid\""[:]*[0-9][,]"\"status\""[:]*"\"running\""[,]"\"bundle\""[:]*$BUSYBOX_BUNDLE*[,]"\"created\""[:]*[0-9]*[\}]* ]]

View File

@ -15,20 +15,20 @@ function teardown() {
# start busybox detached # start busybox detached
run "$RUNC" start -d --console /dev/pts/ptmx test_busybox run "$RUNC" start -d --console /dev/pts/ptmx test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
# pause busybox # pause busybox
run "$RUNC" pause test_busybox run "$RUNC" pause test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# test state of busybox is paused # test state of busybox is paused
testcontainer test_busybox paused testcontainer test_busybox paused
# resume busybox # resume busybox
run "$RUNC" resume test_busybox run "$RUNC" resume test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# test state of busybox is back to running # test state of busybox is back to running
testcontainer test_busybox running testcontainer test_busybox running
} }

View File

@ -14,41 +14,41 @@ function teardown() {
} }
@test "global --root" { @test "global --root" {
# start busybox detached using $HELLO_BUNDLE for state # start busybox detached using $HELLO_BUNDLE for state
run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_dotbox run "$RUNC" --root $HELLO_BUNDLE start -d --console /dev/pts/ptmx test_dotbox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# start busybox detached in default root # start busybox detached in default root
run "$RUNC" start -d --console /dev/pts/ptmx test_busybox run "$RUNC" start -d --console /dev/pts/ptmx test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# check state of the busyboxes are only in their respective root path # check state of the busyboxes are only in their respective root path
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
wait_for_container_inroot 15 1 test_dotbox $HELLO_BUNDLE wait_for_container_inroot 15 1 test_dotbox $HELLO_BUNDLE
run "$RUNC" state test_busybox run "$RUNC" state test_busybox
[ "$status" -eq 0 ]
[[ "${output}" == *"running"* ]]
run "$RUNC" --root $HELLO_BUNDLE state test_dotbox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${output}" == *"running"* ]] [[ "${output}" == *"running"* ]]
run "$RUNC" --root $HELLO_BUNDLE state test_busybox run "$RUNC" --root $HELLO_BUNDLE state test_dotbox
[ "$status" -eq 0 ]
[[ "${output}" == *"running"* ]]
run "$RUNC" --root $HELLO_BUNDLE state test_busybox
[ "$status" -ne 0 ] [ "$status" -ne 0 ]
run "$RUNC" state test_dotbox run "$RUNC" state test_dotbox
[ "$status" -ne 0 ] [ "$status" -ne 0 ]
run "$RUNC" kill test_busybox KILL run "$RUNC" kill test_busybox KILL
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'"
run "$RUNC" delete test_busybox run "$RUNC" delete test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
run "$RUNC" --root $HELLO_BUNDLE kill test_dotbox KILL run "$RUNC" --root $HELLO_BUNDLE kill test_dotbox KILL
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
retry 10 1 eval "'$RUNC' --root $HELLO_BUNDLE state test_dotbox | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' --root $HELLO_BUNDLE state test_dotbox | grep -q 'destroyed'"
run "$RUNC" --root $HELLO_BUNDLE delete test_dotbox run "$RUNC" --root $HELLO_BUNDLE delete test_dotbox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
} }

View File

@ -6,9 +6,9 @@ function setup() {
# initial cleanup in case a prior test exited and did not cleanup # initial cleanup in case a prior test exited and did not cleanup
cd "$INTEGRATION_ROOT" cd "$INTEGRATION_ROOT"
run rm -f -r "$HELLO_BUNDLE" run rm -f -r "$HELLO_BUNDLE"
# setup hello-world for spec generation testing # setup hello-world for spec generation testing
run mkdir "$HELLO_BUNDLE" run mkdir "$HELLO_BUNDLE"
run mkdir "$HELLO_BUNDLE"/rootfs run mkdir "$HELLO_BUNDLE"/rootfs
run tar -C "$HELLO_BUNDLE"/rootfs -xf "$HELLO_IMAGE" run tar -C "$HELLO_BUNDLE"/rootfs -xf "$HELLO_IMAGE"
} }
@ -21,21 +21,21 @@ function teardown() {
@test "spec generation cwd" { @test "spec generation cwd" {
cd "$HELLO_BUNDLE" cd "$HELLO_BUNDLE"
# note this test runs from the bundle not the integration root # note this test runs from the bundle not the integration root
# test that config.json does not exist after the above partial setup # test that config.json does not exist after the above partial setup
[ ! -e config.json ] [ ! -e config.json ]
# test generation of spec does not return an error # test generation of spec does not return an error
run "$RUNC" spec run "$RUNC" spec
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# test generation of spec created our config.json (spec) # test generation of spec created our config.json (spec)
[ -e config.json ] [ -e config.json ]
# test existence of required args parameter in the generated config.json # test existence of required args parameter in the generated config.json
run bash -c "grep -A2 'args' config.json | grep 'sh'" run bash -c "grep -A2 'args' config.json | grep 'sh'"
[[ "${output}" == *"sh"* ]] [[ "${output}" == *"sh"* ]]
# change the default args parameter from sh to hello # change the default args parameter from sh to hello
sed -i 's;"sh";"/hello";' config.json sed -i 's;"sh";"/hello";' config.json
@ -45,18 +45,18 @@ function teardown() {
} }
@test "spec generation --bundle" { @test "spec generation --bundle" {
# note this test runs from the integration root not the bundle # note this test runs from the integration root not the bundle
# test that config.json does not exist after the above partial setup # test that config.json does not exist after the above partial setup
[ ! -e "$HELLO_BUNDLE"/config.json ] [ ! -e "$HELLO_BUNDLE"/config.json ]
# test generation of spec does not return an error # test generation of spec does not return an error
run "$RUNC" spec --bundle "$HELLO_BUNDLE" run "$RUNC" spec --bundle "$HELLO_BUNDLE"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# test generation of spec created our config.json (spec) # test generation of spec created our config.json (spec)
[ -e "$HELLO_BUNDLE"/config.json ] [ -e "$HELLO_BUNDLE"/config.json ]
# change the default args parameter from sh to hello # change the default args parameter from sh to hello
sed -i 's;"sh";"/hello";' "$HELLO_BUNDLE"/config.json sed -i 's;"sh";"/hello";' "$HELLO_BUNDLE"/config.json
@ -69,20 +69,20 @@ function teardown() {
cd "$HELLO_BUNDLE" cd "$HELLO_BUNDLE"
# note this test runs from the temporary bundle directory not the integration root # note this test runs from the temporary bundle directory not the integration root
# note this test is brittle against specs changes that lead runc's spec command # note this test is brittle against specs changes that lead runc's spec command
# todo get the validate program, gojsonschema, and schema/*s.json from godeps? # todo get the validate program, gojsonschema, and schema/*s.json from godeps?
run git clone https://github.com/opencontainers/runtime-spec.git src/runtime-spec run git clone https://github.com/opencontainers/runtime-spec.git src/runtime-spec
[ -e src/runtime-spec/schema/schema.json ] [ -e src/runtime-spec/schema/schema.json ]
run bash -c "GOPATH='$GOPATH' go get github.com/xeipuuv/gojsonschema" run bash -c "GOPATH='$GOPATH' go get github.com/xeipuuv/gojsonschema"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
GOPATH="$GOPATH" go build src/runtime-spec/schema/validate.go GOPATH="$GOPATH" go build src/runtime-spec/schema/validate.go
[ -e ./validate ] [ -e ./validate ]
run "$RUNC" spec run "$RUNC" spec
[ -e config.json ] [ -e config.json ]
run ./validate src/runtime-spec/schema/schema.json config.json run ./validate src/runtime-spec/schema/schema.json config.json
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${lines[0]}" == *"The document is valid"* ]] [[ "${lines[0]}" == *"The document is valid"* ]]

View File

@ -32,7 +32,7 @@ function teardown() {
testcontainer test_busybox running testcontainer test_busybox running
# check pid.txt was generated # check pid.txt was generated
[ -e pid.txt ] [ -e pid.txt ]
run cat pid.txt run cat pid.txt

View File

@ -13,9 +13,9 @@ function teardown() {
@test "runc start" { @test "runc start" {
# start hello-world # start hello-world
run "$RUNC" start test_hello run "$RUNC" start test_hello
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# check expected output # check expected output
[[ "${output}" == *"Hello"* ]] [[ "${output}" == *"Hello"* ]]
} }
@ -37,8 +37,8 @@ function teardown() {
run "$RUNC" start --pid-file pid.txt test_hello run "$RUNC" start --pid-file pid.txt test_hello
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ "${output}" == *"Hello"* ]] [[ "${output}" == *"Hello"* ]]
# check pid.txt was generated # check pid.txt was generated
[ -e pid.txt ] [ -e pid.txt ]
run cat pid.txt run cat pid.txt

View File

@ -14,7 +14,7 @@ function teardown() {
@test "state" { @test "state" {
run "$RUNC" state test_busybox run "$RUNC" state test_busybox
[ "$status" -ne 0 ] [ "$status" -ne 0 ]
# start busybox detached # start busybox detached
run "$RUNC" start -d --console /dev/pts/ptmx test_busybox run "$RUNC" start -d --console /dev/pts/ptmx test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
@ -23,28 +23,28 @@ function teardown() {
wait_for_container 15 1 test_busybox wait_for_container 15 1 test_busybox
testcontainer test_busybox running testcontainer test_busybox running
# pause busybox # pause busybox
run "$RUNC" pause test_busybox run "$RUNC" pause test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# test state of busybox is paused # test state of busybox is paused
testcontainer test_busybox paused testcontainer test_busybox paused
# resume busybox # resume busybox
run "$RUNC" resume test_busybox run "$RUNC" resume test_busybox
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
# test state of busybox is back to running # test state of busybox is back to running
testcontainer test_busybox running testcontainer test_busybox running
run "$RUNC" kill test_busybox KILL run "$RUNC" kill test_busybox KILL
# wait for busybox to be in the destroyed state # wait for busybox to be in the destroyed state
retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'" retry 10 1 eval "'$RUNC' state test_busybox | grep -q 'destroyed'"
# delete test_busybox # delete test_busybox
run "$RUNC" delete test_busybox run "$RUNC" delete test_busybox
run "$RUNC" state test_busybox run "$RUNC" state test_busybox
[ "$status" -ne 0 ] [ "$status" -ne 0 ]
} }

View File

@ -2,8 +2,6 @@
load helpers load helpers
UPDATE_TEST_RUNC_ROOT="$BATS_TMPDIR/runc-update-integration-test"
CGROUP_MEMORY="" CGROUP_MEMORY=""
CGROUP_CPUSET="" CGROUP_CPUSET=""
CGROUP_CPU="" CGROUP_CPU=""
@ -11,14 +9,14 @@ CGROUP_BLKIO=""
function init_cgroup_path() { function init_cgroup_path() {
for g in MEMORY CPUSET CPU BLKIO; do for g in MEMORY CPUSET CPU BLKIO; do
base_path=$(grep "rw," /proc/self/mountinfo | grep -i -m 1 "$g\$" | cut -d ' ' -f 5) base_path=$(grep "cgroup" /proc/self/mountinfo | gawk 'toupper($NF) ~ /\<'${g}'\>/ { print $5; exit }')
eval CGROUP_${g}="${base_path}/runc-update-integration-test" eval CGROUP_${g}="${base_path}/runc-update-integration-test"
done done
} }
function teardown() { function teardown() {
rm -f $BATS_TMPDIR/runc-update-integration-test.json rm -f $BATS_TMPDIR/runc-update-integration-test.json
teardown_running_container_inroot test_update $UPDATE_TEST_RUNC_ROOT teardown_running_container test_update
teardown_busybox teardown_busybox
} }
@ -63,9 +61,9 @@ function check_cgroup_value() {
@test "update" { @test "update" {
# start a few busyboxes detached # start a few busyboxes detached
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT start -d --console /dev/pts/ptmx test_update run "$RUNC" start -d --console /dev/pts/ptmx test_update
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
wait_for_container_inroot 15 1 test_update $UPDATE_TEST_RUNC_ROOT wait_for_container 15 1 test_update
init_cgroup_path init_cgroup_path
@ -81,62 +79,62 @@ function check_cgroup_value() {
check_cgroup_value $CGROUP_MEMORY "memory.soft_limit_in_bytes" 25165824 check_cgroup_value $CGROUP_MEMORY "memory.soft_limit_in_bytes" 25165824
# update blkio-weight # update blkio-weight
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --blkio-weight 500 run "$RUNC" update test_update --blkio-weight 500
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_BLKIO "blkio.weight" 500 check_cgroup_value $CGROUP_BLKIO "blkio.weight" 500
# update cpu-period # update cpu-period
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --cpu-period 900000 run "$RUNC" update test_update --cpu-period 900000
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_CPU "cpu.cfs_period_us" 900000 check_cgroup_value $CGROUP_CPU "cpu.cfs_period_us" 900000
# update cpu-quota # update cpu-quota
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --cpu-quota 600000 run "$RUNC" update test_update --cpu-quota 600000
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_CPU "cpu.cfs_quota_us" 600000 check_cgroup_value $CGROUP_CPU "cpu.cfs_quota_us" 600000
# update cpu-shares # update cpu-shares
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --cpu-share 200 run "$RUNC" update test_update --cpu-share 200
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_CPU "cpu.shares" 200 check_cgroup_value $CGROUP_CPU "cpu.shares" 200
# update cpuset if supported (i.e. we're running on a multicore cpu) # update cpuset if supported (i.e. we're running on a multicore cpu)
cpu_count=$(grep '^processor' /proc/cpuinfo | wc -l) cpu_count=$(grep '^processor' /proc/cpuinfo | wc -l)
if [ $cpu_count -ge 1 ]; then if [ $cpu_count -ge 1 ]; then
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --cpuset-cpus "1" run "$RUNC" update test_update --cpuset-cpus "1"
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_CPUSET "cpuset.cpus" 1 check_cgroup_value $CGROUP_CPUSET "cpuset.cpus" 1
fi fi
# update memory limit # update memory limit
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --memory 67108864 run "$RUNC" update test_update --memory 67108864
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_MEMORY "memory.limit_in_bytes" 67108864 check_cgroup_value $CGROUP_MEMORY "memory.limit_in_bytes" 67108864
# update memory soft limit # update memory soft limit
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --memory-reservation 33554432 run "$RUNC" update test_update --memory-reservation 33554432
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_MEMORY "memory.soft_limit_in_bytes" 33554432 check_cgroup_value $CGROUP_MEMORY "memory.soft_limit_in_bytes" 33554432
# update memory swap (if available) # update memory swap (if available)
if [ -f "$CGROUP_MEMORY/memory.memsw.limit_in_bytes" ]; then if [ -f "$CGROUP_MEMORY/memory.memsw.limit_in_bytes" ]; then
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --memory-swap 96468992 run "$RUNC" update test_update --memory-swap 96468992
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_MEMORY "memory.memsw.limit_in_bytes" 96468992 check_cgroup_value $CGROUP_MEMORY "memory.memsw.limit_in_bytes" 96468992
fi fi
# update kernel memory limit # update kernel memory limit
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --kernel-memory 50331648 run "$RUNC" update test_update --kernel-memory 50331648
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_MEMORY "memory.kmem.limit_in_bytes" 50331648 check_cgroup_value $CGROUP_MEMORY "memory.kmem.limit_in_bytes" 50331648
# update kernel memory tcp limit # update kernel memory tcp limit
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --kernel-memory-tcp 41943040 run "$RUNC" update test_update --kernel-memory-tcp 41943040
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_MEMORY "memory.kmem.tcp.limit_in_bytes" 41943040 check_cgroup_value $CGROUP_MEMORY "memory.kmem.tcp.limit_in_bytes" 41943040
# Revert to the test initial value via json on stding # Revert to the test initial value via json on stding
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update -r - test_update <<EOF run "$RUNC" update -r - test_update <<EOF
{ {
"memory": { "memory": {
"limit": 33554432, "limit": 33554432,
@ -167,7 +165,7 @@ EOF
check_cgroup_value $CGROUP_MEMORY "memory.soft_limit_in_bytes" 25165824 check_cgroup_value $CGROUP_MEMORY "memory.soft_limit_in_bytes" 25165824
# redo all the changes at once # redo all the changes at once
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update test_update --blkio-weight 500 \ run "$RUNC" update test_update --blkio-weight 500 \
--cpu-period 900000 --cpu-quota 600000 --cpu-share 200 --memory 67108864 \ --cpu-period 900000 --cpu-quota 600000 --cpu-share 200 --memory 67108864 \
--memory-reservation 33554432 --kernel-memory 50331648 --kernel-memory-tcp 41943040 --memory-reservation 33554432 --kernel-memory 50331648 --kernel-memory-tcp 41943040
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
@ -203,7 +201,7 @@ EOF
) )
echo $DATA > $BATS_TMPDIR/runc-update-integration-test.json echo $DATA > $BATS_TMPDIR/runc-update-integration-test.json
run "$RUNC" --root $UPDATE_TEST_RUNC_ROOT update -r $BATS_TMPDIR/runc-update-integration-test.json test_update run "$RUNC" update -r $BATS_TMPDIR/runc-update-integration-test.json test_update
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
check_cgroup_value $CGROUP_BLKIO "blkio.weight" 1000 check_cgroup_value $CGROUP_BLKIO "blkio.weight" 1000
check_cgroup_value $CGROUP_CPU "cpu.cfs_period_us" 1000000 check_cgroup_value $CGROUP_CPU "cpu.cfs_period_us" 1000000

View File

@ -6,6 +6,6 @@ load helpers
run "$RUNC" -v run "$RUNC" -v
[ "$status" -eq 0 ] [ "$status" -eq 0 ]
[[ ${lines[0]} =~ runc\ version\ [0-9]+\.[0-9]+\.[0-9]+ ]] [[ ${lines[0]} =~ runc\ version\ [0-9]+\.[0-9]+\.[0-9]+ ]]
[[ ${lines[1]} =~ commit:+ ]] [[ ${lines[1]} =~ commit:+ ]]
[[ ${lines[2]} =~ spec:\ [0-9]+\.[0-9]+\.[0-9]+ ]] [[ ${lines[2]} =~ spec:\ [0-9]+\.[0-9]+\.[0-9]+ ]]
} }