From 595f593c24c4b6217f1f2194eb912d493cae29fd Mon Sep 17 00:00:00 2001 From: Doug Davis Date: Thu, 11 Feb 2016 10:42:28 -0800 Subject: [PATCH] Add the most basic sniff tests of runc just so that we're not merging code into master w/o any tests at all. I expect this to be removed once we have a real testing infrastructure. Signed-off-by: Doug Davis --- Makefile | 5 ++- tests/sniffTest | 112 ++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 115 insertions(+), 2 deletions(-) create mode 100755 tests/sniffTest diff --git a/Makefile b/Makefile index 3b0e1148..8ac8bbe3 100644 --- a/Makefile +++ b/Makefile @@ -27,9 +27,10 @@ runctestimage: docker build -t $(RUNC_TEST_IMAGE) -f $(TEST_DOCKERFILE) . test: runctestimage - docker run -e TESTFLAGS --privileged --rm -v $(CURDIR):/go/src/$(PROJECT) $(RUNC_TEST_IMAGE) make localtest + docker run -e TESTFLAGS -ti --privileged --rm -v $(CURDIR):/go/src/$(PROJECT) $(RUNC_TEST_IMAGE) make localtest + tests/sniffTest -localtest: +localtest: all go test -tags "$(BUILDTAGS)" ${TESTFLAGS} -v ./... dbuild: runctestimage diff --git a/tests/sniffTest b/tests/sniffTest new file mode 100755 index 00000000..a25bd8ab --- /dev/null +++ b/tests/sniffTest @@ -0,0 +1,112 @@ +#!/bin/bash + +set -e + +RUNC=$PWD/runc +DIR=/tmp/runc_test + +rm -rf $DIR +mkdir -p $DIR/rootfs + +cd $DIR + +docker pull busybox +docker create --name tmpbusybox busybox +docker export tmpbusybox | tar -C $DIR/rootfs -xf- +docker rm -f tmpbusybox + +# Make sure we can generate a config.json file +################################################################ +rm -f config.json +$RUNC spec +if [ ! -e config.json ]; then + echo NO config.json file generated + exit 1 +fi +echo "PASS: runc spec" + +# Simple start test +################################################################ +rm -f config.json && $RUNC spec # reset things +sed -i 's/"sh"/"echo","-n","hi"/' config.json +set +e +$RUNC start c1 >out 2>err +rc=$? +if [[ $rc != 0 || -s err ]]; then + echo Error while running start + echo Exit code: $rc + echo Error: $(cat err) + echo Output: $(cat out) + exit 1 +fi +if [[ "$(cat out)" != "hi" ]]; then + echo -e Incorrect output: $(cat out)\nExpected: hi + exit 1 +fi +echo "PASS: runc start" + +# Test exec +################################################################ +set -ex +rm config.json && $RUNC spec # reset things +sed -i 's/"sh"/"sleep","6"/' config.json +$RUNC start -d --console /dev/ptmx c1 >out 2>&1 +rc=$? +if [[ $rc != 0 || -s out ]]; then + echo Error while running start + echo Exit code: $rc + echo Output: $(cat out) + exit 1 +fi +sleep 1 +$RUNC exec c1 echo from exec >out 2>err +rc=$? +if [[ $rc != 0 || -s err ]]; then + echo Error while running exec + echo Exit code: $rc + echo Error: $(cat err) + echo Output: $(cat out) + exit 1 +fi +$RUNC kill c1 +rm -rf /run/opencontainer/containers/c1 +echo "PASS: runc exec" + +# Test pause/resume +################################################################ +rm config.json && $RUNC spec # reset things +sed -i 's/"sh"/"sleep","6"/' config.json +$RUNC start -d --console /dev/ptmx c1 >out 2>&1 +rc=$? +if [[ $rc != 0 || -s out ]]; then + echo Error while running start + echo Exit code: $rc + echo Output: $(cat out) + exit 1 +fi +sleep 1 +$RUNC pause c1 >out 2>&1 +rc=$? +if [[ $rc != 0 || -s out ]]; then + echo Error while running pause + echo Exit code: $rc + echo Output: $(cat out) + exit 1 +fi +$RUNC resume c1 >out 2>&1 +rc=$? +if [[ $? != 0 || -s out ]]; then + echo Error while running pause + echo Exit code: $rc + echo Output: $(cat out) + exit 1 +fi + +$RUNC kill c1 +rm -rf /run/opencontainer/containers/c1 +echo "PASS: runc pause/resume" + +# give it a sec before we erase the dir +sleep 5 +cd .. +rm -rf $DIR