mirror of https://github.com/containers/podman.git
				
				
				
			
		
			
				
	
	
		
			136 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
| #!/bin/bash
 | |
| #
 | |
| # build-testimage - script for producing a test image for podman CI
 | |
| #
 | |
| # The idea is to have a small multi-purpose image that can be pulled once
 | |
| # by system tests and used for as many tests as possible. This image
 | |
| # should live on quay.io, should be small in size, and should include
 | |
| # as many components as needed by system tests so they don't have to
 | |
| # pull other images.
 | |
| #
 | |
| # Unfortunately, "small" is incompatible with "systemd" so tests
 | |
| # still need a fedora image for that.
 | |
| #
 | |
| 
 | |
| # Buildah binary
 | |
| BUILDAH=${BUILDAH:-buildah}
 | |
| 
 | |
| # Tag for this new image
 | |
| YMD=$(date +%Y%m%d)
 | |
| 
 | |
| # git-relative path to this script
 | |
| create_script=$(cd $(dirname $0) && git ls-files --full-name $(basename $0))
 | |
| if [ -z "$create_script" ]; then
 | |
|     create_script=$0
 | |
| fi
 | |
| 
 | |
| # Creation timestamp, Zulu time
 | |
| create_time_z=$(env TZ=UTC date +'%Y-%m-%dT%H:%M:%SZ')
 | |
| 
 | |
| set -ex
 | |
| 
 | |
| # We'll need to create a Containerfile plus various other files to add in
 | |
| #
 | |
| # Please document the reason for all flags, apk's, and anything non-obvious
 | |
| tmpdir=$(mktemp -t -d $(basename $0).tmp.XXXXXXX)
 | |
| cd $tmpdir
 | |
| 
 | |
| # 'image mount' test will confirm that this file exists and has our YMD tag
 | |
| echo $YMD >testimage-id
 | |
| 
 | |
| # ...but set the timestamp on the file itself to a constant well-known
 | |
| # value, for use by the 'run --tz' test. Date value chosen for nerdiness
 | |
| # and because it's in the past. (Much as I'd love FFFFFFFF, we can't
 | |
| # use any future date because of unpredictable leap second adjustments).
 | |
| touch --date=@1600000000 testimage-id
 | |
| 
 | |
| # 'pod' test will use this for --infra-command
 | |
| cat >pause <<EOF
 | |
| #!/bin/sh
 | |
| #
 | |
| # Trivial little pause script, used in one of the pod tests
 | |
| #
 | |
| echo Confirmed: testimage pause invoked as \$0
 | |
| while :; do
 | |
|     sleep 0.1
 | |
| done
 | |
| EOF
 | |
| chmod 755 pause
 | |
| 
 | |
| # alpine because it's small and light and reliable
 | |
| #    - check for updates @ https://hub.docker.com/_/alpine
 | |
| # busybox-extras provides httpd needed in 500-networking.bats
 | |
| cat >Containerfile <<EOF
 | |
| ARG REPO=please-override-repo
 | |
| FROM docker.io/\${REPO}/alpine:3.13.5
 | |
| RUN apk add busybox-extras
 | |
| ADD testimage-id pause /home/podman/
 | |
| LABEL created_by=$create_script
 | |
| LABEL created_at=$create_time_z
 | |
| WORKDIR /home/podman
 | |
| CMD ["/bin/echo", "This container is intended for podman CI testing"]
 | |
| EOF
 | |
| 
 | |
| # --squash-all    : needed by 'tree' test in 070-build.bats
 | |
| podman rmi -f testimage &> /dev/null || true
 | |
| 
 | |
| # There should always be a testimage tagged ':0000000<X>' (eight digits,
 | |
| # zero-padded sequence ID) in the same location; this is used by tests
 | |
| # which need to pull a non-locally-cached image. This image will rarely
 | |
| # if ever need to change, nor in fact does it even have to be a copy of
 | |
| # this testimage since all we use it for is 'true'.
 | |
| # However, it does need to be multiarch :-(
 | |
| zerotag_latest=$(skopeo list-tags docker://quay.io/libpod/testimage |\
 | |
|                      jq -r '.Tags[]' |\
 | |
|                      sort --version-sort |\
 | |
|                      grep '^000' |\
 | |
|                      tail -n 1)
 | |
| zerotag_next=$(printf "%08d" $((zerotag_latest + 1)))
 | |
| 
 | |
| # We don't always need to push the :00xx image, but build it anyway.
 | |
| zeroimg=quay.io/libpod/testimage:${zerotag_next}
 | |
| buildah manifest create $zeroimg
 | |
| 
 | |
| # We need to use buildah because (as of 2021-02-23) only buildah has --manifest
 | |
| # and because Dan says arch emulation is not currently working on podman
 | |
| # (no further details).
 | |
| # Arch emulation on Fedora requires the qemu-user-static package.
 | |
| for arch in amd64 arm64 ppc64le s390x;do
 | |
|     # docker.io repo is usually the same name as the desired arch; except
 | |
|     # for arm64, where podman needs to have the arch be 'arm64' but the
 | |
|     # image lives in 'arm64v8'.
 | |
|     repo=$arch
 | |
|     if [[ $repo = "arm64" ]]; then
 | |
|         repo="${repo}v8"
 | |
|     fi
 | |
| 
 | |
|     ${BUILDAH} bud \
 | |
|                --arch=$arch \
 | |
|                --build-arg REPO=$repo \
 | |
|                --manifest=testimage \
 | |
|                --squash \
 | |
|                .
 | |
| 
 | |
|     # The zero-tag image
 | |
|     ${BUILDAH} pull --arch $arch     docker.io/$repo/busybox:1.33.1
 | |
|     ${BUILDAH} manifest add $zeroimg docker.io/$repo/busybox:1.33.1
 | |
| done
 | |
| 
 | |
| # Clean up
 | |
| cd /tmp
 | |
| rm -rf $tmpdir
 | |
| 
 | |
| # Tag image and push (all arches) to quay.
 | |
| remote_tag=quay.io/libpod/testimage:$YMD
 | |
| podman tag testimage ${remote_tag}
 | |
| cat <<EOF
 | |
| 
 | |
| If you're happy with these images, run:
 | |
| 
 | |
|    ${BUILDAH} manifest push --all  ${remote_tag} docker://${remote_tag}
 | |
|    ${BUILDAH} manifest push --all  ${zeroimg} docker://${zeroimg}
 | |
| 
 | |
| (You do not always need to push the :0000 image)
 | |
| 
 | |
| EOF
 |