diff --git a/Makefile b/Makefile index 2fe13612..e37d0c50 100644 --- a/Makefile +++ b/Makefile @@ -31,6 +31,8 @@ HACK_D := $(TOP_LEVEL)/hack TOOLS_D := $(HACK_D)/tools REGCLIENT := $(TOOLS_D)/bin/regctl REGCLIENT_VERSION := v0.5.1 +export SKOPEO = $(TOOLS_D)/bin/skopeo +export SKOPEO_VERSION = v1.9.3 # OCI registry ZOT := $(TOOLS_D)/bin/zot ZOT_VERSION := v2.0.0-rc6 @@ -99,6 +101,18 @@ $(REGCLIENT): $(ZOT): $(call dlbin,$@,https://github.com/project-zot/zot/releases/download/$(ZOT_VERSION)/zot-linux-amd64-minimal) +$(SKOPEO): + tmpdir=$$(mktemp -d); \ + cd $$tmpdir; \ + git clone https://github.com/containers/skopeo.git; \ + cd skopeo; \ + git fetch --all --tags --prune; \ + git clone tags/$(SKOPEO_VERSION) -b tag-$(SKOPEO_VERSION); \ + make bin/skopeo; \ + cp bin/skopeo $(SKOPEO); \ + cd $(TOP_LEVEL); \ + rm -rf $$tmpdir; + TEST?=$(patsubst test/%.bats,%,$(wildcard test/*.bats)) PRIVILEGE_LEVEL?= @@ -108,7 +122,7 @@ PRIVILEGE_LEVEL?= check: lint test go-test .PHONY: test -test: stacker $(REGCLIENT) $(ZOT) +test: stacker $(REGCLIENT) $(SKOPEO) $(ZOT) sudo -E PATH="$$PATH" \ LXC_BRANCH=$(LXC_BRANCH) \ LXC_CLONE_URL=$(LXC_CLONE_URL) \ diff --git a/install-build-deps.sh b/install-build-deps.sh index 2fe30028..4004ee1c 100755 --- a/install-build-deps.sh +++ b/install-build-deps.sh @@ -3,12 +3,18 @@ set -o pipefail set -o errexit installdeps_fedora() { - sudo dnf install \ - bats \ - jq \ - lxc-devel \ - libcap-devel \ - libacl-devel + sudo dnf install \ + bats \ + jq \ + lxc-devel \ + libcap-devel \ + libacl-devel + # skopeo deps + sudo dnf install \ + gpgme-devel \ + libassuan-devel \ + btrfs-progs-devel \ + device-mapper-devel if ! command -v go 2>/dev/null; then sudo dnf install golang go version @@ -38,6 +44,13 @@ installdeps_ubuntu() { skopeo \ squashfs-tools \ squashfuse + # skopeo deps + sudo apt -yy install \ + libgpgme-dev \ + libassuan-dev \ + libbtrfs-dev \ + libdevmapper-dev \ + pkg-config if ! command -v go 2>/dev/null; then sudo apt -yy install golang-go go version diff --git a/test/gzip.bats b/test/gzip.bats new file mode 100644 index 00000000..445594bf --- /dev/null +++ b/test/gzip.bats @@ -0,0 +1,129 @@ +load helpers + +function setup() { + stacker_setup +} + +function teardown() { + cleanup +} + +@test "import tar < 1M" { + mkdir -p folder1 + truncate -s 512k folder1/file1 + tar cvf test.tar folder1 + cat > stacker.yaml < 1M" { + mkdir -p folder1 + truncate -s 2m folder1/file1 + tar cvf test.tar folder1 + cat > stacker.yaml < stacker.yaml < 1M" { + mkdir -p folder1 + truncate -s 2m folder1/file1 + tar cvzf test.tar.gz folder1 + cat > stacker.yaml <