From 8c48d5c1bbc58e043f0209e0309ec841b48195ad Mon Sep 17 00:00:00 2001 From: Georgi Sabev Date: Tue, 6 Aug 2019 15:13:30 +0100 Subject: [PATCH 1/2] Make bind mount tests more stable Use `/bin` which should be accessible for all users, rather then `.` which is not well defined and might be inaccessible to container root on some deployments --- test/create.bats | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/test/create.bats b/test/create.bats index 1e2dff1..6c8e174 100755 --- a/test/create.bats +++ b/test/create.bats @@ -24,7 +24,7 @@ load test_helper } @test "a created container bind mount is read-write by default" { - handle=$(gaol create -m .:/tmp/cmnt) + handle=$(gaol create -m /bin:/tmp/cmnt) assert_success run gaol run -a -c "/bin/sh -c 'cat /proc/self/mounts | grep /tmp/cmnt'" $handle @@ -34,7 +34,7 @@ load test_helper } @test "a created container can have read-only bind mounts" { - handle=$(gaol create -m .:/tmp/cmnt:ro) + handle=$(gaol create -m /bin:/tmp/cmnt:ro) assert_success run gaol run -a -c "/bin/sh -c 'cat /proc/self/mounts | grep /tmp/cmnt'" $handle @@ -45,7 +45,7 @@ load test_helper @test "a created container can have explicit read-write bind mounts" { - handle=$(gaol create -m .:/tmp/cmnt:rw) + handle=$(gaol create -m /bin:/tmp/cmnt:rw) assert_success run gaol run -a -c "/bin/sh -c 'cat /proc/self/mounts | grep /tmp/cmnt'" $handle From 0795019bfc7a25502c9aa660908ccd851541e18d Mon Sep 17 00:00:00 2001 From: Georgi Sabev Date: Tue, 6 Aug 2019 15:32:40 +0100 Subject: [PATCH 2/2] return exit status from attach command --- commands/attach.go | 3 ++- test/attach.bats | 14 ++++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) create mode 100755 test/attach.bats diff --git a/commands/attach.go b/commands/attach.go index 3cb503e..8313f21 100644 --- a/commands/attach.go +++ b/commands/attach.go @@ -22,8 +22,9 @@ func (command *Attach) Execute(maybeHandle []string) error { }) failIf(err) - _, err = process.Wait() + status, err := process.Wait() failIf(err) + os.Exit(status) return nil } diff --git a/test/attach.bats b/test/attach.bats new file mode 100755 index 0000000..367d2ae --- /dev/null +++ b/test/attach.bats @@ -0,0 +1,14 @@ +#!/usr/bin/env bats + +load test_helper + +@test "it returns exit code from attach" { + handle=$(gaol create) + assert_success + + process_id=$(gaol run -c 'sh -c "sleep 1; exit 42"' $handle) + assert_success + + run gaol attach $handle -p $process_id + assert_equal $status 42 +}