-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Ramkumar Chinchani <[email protected]>
- Loading branch information
Showing
5 changed files
with
179 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,164 @@ | ||
load helpers | ||
|
||
function setup() { | ||
stacker_setup | ||
} | ||
|
||
function teardown() { | ||
cleanup | ||
} | ||
|
||
function verity_checkusedloops() { | ||
# search for loopdevices which have backing files with the current | ||
# BATS_TEST_DIRNAME value and complain if they're present. | ||
local usedloops="" found="" x="" | ||
for ((x=0; x<5; x++)); do | ||
usedloops=$(losetup -a | grep $BATS_TEST_DIRNAME || echo) | ||
if [ -n "$usedloops" ]; then | ||
found=1 | ||
udevadm settle | ||
else | ||
return 0 | ||
fi | ||
done | ||
echo "found used loops in testdir=$BATS_TEST_DIRNAME :$usedloops" >&3 | ||
[ $found = 1 ] | ||
} | ||
|
||
function basic_test() { | ||
require_privilege priv | ||
local verity_arg=$1 | ||
|
||
cat > stacker.yaml <<"EOF" | ||
test: | ||
from: | ||
type: oci | ||
url: ${{BUSYBOX_OCI}} | ||
run: | | ||
touch /hello | ||
EOF | ||
stacker build --layer-type=erofs $verity_arg --substitute BUSYBOX_OCI=${BUSYBOX_OCI} | ||
mkdir mountpoint | ||
stacker internal-go atomfs mount test-erofs mountpoint | ||
|
||
[ -f mountpoint/hello ] | ||
stacker internal-go atomfs umount mountpoint | ||
} | ||
|
||
@test "--no-verity works" { | ||
basic_test --no-verity | ||
verity_checkusedloops | ||
} | ||
|
||
@test "mount + umount works" { | ||
basic_test | ||
|
||
# last layer shouldn't exist any more, since it is unique | ||
manifest=$(cat oci/index.json | jq -r .manifests[0].digest | cut -f2 -d:) | ||
last_layer_num=$(($(cat oci/blobs/sha256/$manifest | jq -r '.layers | length')-1)) | ||
last_layer_hash=$(cat oci/blobs/sha256/$manifest | jq -r .layers[$last_layer].digest | cut -f2 -d:) | ||
[ ! -b "/dev/mapper/$last_layer_hash-verity" ] | ||
verity_checkusedloops | ||
} | ||
|
||
@test "mount + umount + mount a tree of images works" { | ||
require_privilege priv | ||
cat > stacker.yaml <<"EOF" | ||
base: | ||
from: | ||
type: oci | ||
url: ${{BUSYBOX_OCI}} | ||
run: touch /base | ||
a: | ||
from: | ||
type: built | ||
tag: base | ||
run: touch /a | ||
b: | ||
from: | ||
type: built | ||
tag: base | ||
run: touch /b | ||
c: | ||
from: | ||
type: built | ||
tag: base | ||
run: touch /c | ||
EOF | ||
stacker build --layer-type=erofs --substitute BUSYBOX_OCI=${BUSYBOX_OCI} | ||
|
||
mkdir a | ||
stacker internal-go atomfs mount a-erofs a | ||
[ -f a/a ] | ||
|
||
mkdir b | ||
stacker internal-go atomfs mount b-erofs b | ||
[ -f b/b ] | ||
|
||
cat /proc/self/mountinfo | ||
echo "mountinfo after b^" | ||
|
||
stacker internal-go atomfs umount b | ||
|
||
# first layer should still exist since a is still mounted | ||
manifest=$(cat oci/index.json | jq -r .manifests[0].digest | cut -f2 -d:) | ||
first_layer_hash=$(cat oci/blobs/sha256/$manifest | jq -r .layers[0].digest | cut -f2 -d:) | ||
[ ! -b "/dev/mapper/$last_layer_hash-verity" ] | ||
|
||
mkdir c | ||
stacker internal-go atomfs mount c-erofs c | ||
[ -f c/c ] | ||
|
||
cat /proc/self/mountinfo | ||
echo "mountinfo after c^" | ||
|
||
stacker internal-go atomfs umount a | ||
|
||
cat /proc/self/mountinfo | ||
echo "mountinfo after umount a^" | ||
|
||
# first layer should still exist since c is still mounted | ||
manifest=$(cat oci/index.json | jq -r .manifests[0].digest | cut -f2 -d:) | ||
first_layer_hash=$(cat oci/blobs/sha256/$manifest | jq -r .layers[0].digest | cut -f2 -d:) | ||
[ ! -b "/dev/mapper/$last_layer_hash-verity" ] | ||
|
||
# c should still be ok | ||
[ -f c/c ] | ||
[ -f c/bin/sh ] | ||
stacker internal-go atomfs umount c | ||
|
||
# c's last layer shouldn't exist any more, since it is unique | ||
manifest=$(cat oci/index.json | jq -r .manifests[0].digest | cut -f2 -d:) | ||
last_layer_num=$(($(cat oci/blobs/sha256/$manifest | jq -r '.layers | length')-1)) | ||
last_layer_hash=$(cat oci/blobs/sha256/$manifest | jq -r .layers[$last_layer].digest | cut -f2 -d:) | ||
[ ! -b "/dev/mapper/$last_layer_hash-verity" ] | ||
verity_checkusedloops | ||
} | ||
|
||
@test "bad existing verity device is rejected" { | ||
require_privilege priv | ||
cat > stacker.yaml <<"EOF" | ||
test: | ||
from: | ||
type: oci | ||
url: ${{BUSYBOX_OCI}} | ||
run: | | ||
touch /hello | ||
EOF | ||
stacker build --layer-type=erofs --substitute BUSYBOX_OCI=${BUSYBOX_OCI} | ||
|
||
manifest=$(cat oci/index.json | jq -r .manifests[0].digest | cut -f2 -d:) | ||
first_layer_hash=$(cat oci/blobs/sha256/$manifest | jq -r .layers[0].digest | cut -f2 -d:) | ||
devname="$first_layer_hash-verity" | ||
|
||
# make an evil device and fake it as an existing verity device | ||
dd if=/dev/random of=mydev bs=50K count=1 | ||
root_hash=$(veritysetup format mydev mydev.hash | grep "Root hash:" | awk '{print $NF}') | ||
echo "root hash $root_hash" | ||
veritysetup open mydev "$devname" mydev.hash "$root_hash" | ||
|
||
mkdir mountpoint | ||
bad_stacker internal-go atomfs mount test-erofs mountpoint | grep "invalid root hash" | ||
veritysetup close "$devname" | ||
verity_checkusedloops | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters