| The release-task ***must*** always execute last, in order to guarantee a consistent cache of release archives from dependent tasks. It accomplishes this by verifying it's task-number matches one-less than the total number of tasks. Previous to this commit, a YAML anchor/alias was used to avoid duplication of the dependency list between 'success' and 'release' However, it's been observed that this opens the possibility for 'release' and 'success' tasks to race when running on a PR. Because YAML anchor/aliases cannot be used to modify lists, duplication is required to make 'release' actually depend upon 'success'. This duplication will introduce an additional maintenance burden. Though when adding a new task, it's already very easy to forget to update the 'depends_on' list. Assist both cases by the addition unit-tests to verify ``.cirrus.yml`` dependency contents and structure. Signed-off-by: Chris Evich <cevich@redhat.com> | ||
|---|---|---|
| .. | ||
| packer | ||
| README.md | ||
| build_vm_images.sh | ||
| cache_release_archive.sh | ||
| check_image.sh | ||
| cirrus_yaml_test.py | ||
| container_test.sh | ||
| integration_test.sh | ||
| lib.sh | ||
| lib.sh.t | ||
| logcollector.sh | ||
| notice_branch_failure.sh | ||
| ooe.sh | ||
| podbot.py | ||
| required_host_ports.txt | ||
| rootless_test.sh | ||
| setup_container_environment.sh | ||
| setup_environment.sh | ||
| success.sh | ||
| system_test.sh | ||
| timestamp.awk | ||
| uncache_release_archives.sh | ||
| unit_test.sh | ||
		
			
				
				README.md
			
		
		
			
			
		
	
	Cirrus-CI
Similar to other integrated github CI/CD services, Cirrus utilizes a simple
YAML-based configuration/description file: .cirrus.yml.  Ref: https://cirrus-ci.org/
Workflow
All tasks execute in parallel, unless there are conditions or dependencies which alter this behavior. Within each task, each script executes in sequence, so long as any previous script exited successfully. The overall state of each task (pass or fail) is set based on the exit status of the last script to execute.
gating Task
N/B: Steps below are performed by automation
- 
Launch a purpose-built container in Cirrus's community cluster. For container image details, please see the contributors guide. 
- 
validate: Perform standardmake validatesource verification, Should run for less than a minute or two.
- 
lint: Execute regularmake lintto check for any code cruft. Should also run for less than a few minutes.
- 
vendor: runsmake vendorfollowed by./hack/tree_status.shto check whether the git tree is clean. The reasoning for that is to make sure that the vendor.conf, the code and the vendored packages in ./vendor are in sync at all times.
meta Task
N/B: Steps below are performed by automation
- 
Launch a container built from definition in ./contrib/imgts.
- 
Update VM Image metadata to help track usage across all automation. 
- 
Always exits successfully unless there's a major problem. 
testing Task
N/B: Steps below are performed by automation
- 
After gatingpasses, spin up one VM permatrix: image_nameitem. Once accessible,sshinto each VM as therootuser.
- 
setup_environment.sh: Configure root's.bash_profilefor all subsequent scripts (each run in a new shell). Any distribution-specific environment variables are also defined here. For example, setting tags/flags to use compiling.
- 
integration_test.sh: Execute integration-testing. This is much more involved, and relies on access to external resources like container images and code from other repositories. Total execution time is capped at 2-hours (includes all the above) but this script normally completes in less than an hour.
special_testing_cross Task
Confirm that cross-compile of podman-remote functions for both windows
and darwin targets.
test_build_cache_images_task Task
Modifying the contents of cache-images is tested by making changes to
one or more of the ./contrib/cirrus/packer/*_setup.sh files.  Then
in the PR description, add the magic string:  ***CIRRUS: TEST IMAGES***
N/B: Steps below are performed by automation
- 
setup_environment.sh: Same as for other tasks.
- 
build_vm_images.sh: Utilize the packer tool to produce new VM images. Create a new VM from each base-image, connect to them withssh, and perform the steps as defined by the$PACKER_BASE/libpod_images.ymlfile:- On a base-image VM, as root, copy the current state of the repository
into /tmp/libpod.
- Execute distribution-specific scripts to prepare the image for
use.  For example, fedora_setup.sh.
- If successful, shut down each VM and record the names, and dates into a json manifest file.
- Move the manifest file, into a google storage bucket object. This is a retained as a secondary method for tracking/auditing creation of VM images, should it ever be needed.
 
- On a base-image VM, as root, copy the current state of the repository
into 
verify_test_built_images Task
Only runs following successful test_build_cache_images_task task.  Uses
images following the standard naming format; however, only runs a limited
sub-set of automated tests.  Validating newly built images fully, requires
updating .cirrus.yml.
N/B: Steps below are performed by automation
- 
Using the just build VM images, launch VMs and wait for them to boot. 
- 
Execute the setup_environment.shas in thetestingtask.
- 
Execute the integration_test.shas in thetestingtask.
Manual Steps:  Assuming the automated steps pass, then
you'll find the new image names displayed at the end of the
test_build_cache_images.  For example:
...cut...
==> Builds finished. The artifacts of successful builds are:
--> ubuntu-18: A disk image was created: ubuntu-18-libpod-5699523102900224
--> ubuntu-18:
--> fedora-29: A disk image was created: fedora-29-libpod-5699523102900224
--> fedora-29:
--> fedora-28: A disk image was created: fedora-28-libpod-5699523102900224
Now edit .cirrus.yml, updating the *_IMAGE_NAME lines to reflect the
images from above:
env:
    ...cut...
    ####
    #### Cache-image names to test with
    ###
    FEDORA_CACHE_IMAGE_NAME: "fedora-29-libpod-5699523102900224"
    PRIOR_FEDORA_CACHE_IMAGE_NAME: "fedora-28-libpod-5699523102900224"
    UBUNTU_CACHE_IMAGE_NAME: "ubuntu-18-libpod-5699523102900224"
    ...cut...
NOTE: If re-using the same PR with new images in .cirrus.yml,
take care to also update the PR description to remove
the magic ***CIRRUS: TEST IMAGES*** string.  Keeping it and
--force pushing would needlessly cause Cirrus-CI to build
and test images again.
release Task
Gathers up zip files uploaded by other tasks, from the local Cirrus-CI caching service. Depending on the execution context (a PR or a branch), this task uploads the files found to storage buckets at:
- https://storage.cloud.google.com/libpod-pr-releases
- https://storage.cloud.google.com/libpod-master-releases
Note: Repeated builds from the same PR or branch, will clobber previous archives by design. This is intended so that the "latest" archive is always available at a consistent URL. The precise details regarding a particular build is encoded within the zip-archive comment.
Base-images
Base-images are VM disk-images specially prepared for executing as GCE VMs. In particular, they run services on startup similar in purpose/function as the standard 'cloud-init' services.
- 
The google services are required for full support of ssh-key management and GCE OAuth capabilities. Google provides native images in GCE with services pre-installed, for many platforms. For example, RHEL, CentOS, and Ubuntu. 
- 
Google does not provide any images for Fedora (as of 5/2019), nor do they provide a base-image prepared to run packer for creating other images in the test_build_vm_imagesTask (above).
- 
Base images do not need to be produced often, but doing so completely manually would be time-consuming and error-prone. Therefor a special semi-automatic Makefile target is provided to assist with producing all the base-images: libpod_base_images
To produce new base-images, including an image-builder-image (used by
the cache_images Task) some input parameters are required:
- 
GCP_PROJECT_ID: The complete GCP project ID string e.g. foobar-12345 identifying where the images will be stored.
- 
GOOGLE_APPLICATION_CREDENTIALS: A JSON file containing credentials for a GCE service account. This can be a service account or end-user credentials
- 
Optionally, CSV's may be specified to PACKER_BUILDSto limit the base-images produced. For example,PACKER_BUILDS=fedora,image-builder-image.
If there is an existing 'image-builder-image' within GCE, it may be utilized to produce base-images (in addition to cache-images). However it must be created with support for nested-virtualization, and with elevated cloud privileges (to access GCE, from within the GCE VM). For example:
$ alias pgcloud='sudo podman run -it --rm -e AS_ID=$UID
    -e AS_USER=$USER -v $HOME:$HOME:z quay.io/cevich/gcloud_centos:latest'
$ URL=https://www.googleapis.com/auth
$ SCOPES=$URL/userinfo.email,$URL/compute,$URL/devstorage.full_control
# The --min-cpu-platform is critical for nested-virt.
$ pgcloud compute instances create $USER-making-images \
    --image-family image-builder-image \
    --boot-disk-size "200GB" \
    --min-cpu-platform "Intel Haswell" \
    --machine-type n1-standard-2 \
    --scopes $SCOPES
Alternatively, if there is no image-builder-image available yet, a bare-metal
CentOS 7 machine with network access to GCE is required.  Software dependencies
can be obtained from the packer/image-builder-image_base_setup.sh script.
In both cases, the following can be used to setup and build base-images.
$ IP_ADDRESS=1.2.3.4  # EXTERNAL_IP from command output above
$ rsync -av $PWD centos@$IP_ADDRESS:.
$ scp $GOOGLE_APPLICATION_CREDENTIALS centos@$IP_ADDRESS:.
$ ssh centos@$IP_ADDRESS
...
When ready, change to the packer sub-directory, and build the images:
$ cd libpod/contrib/cirrus/packer
$ make libpod_base_images GCP_PROJECT_ID=<VALUE> \
    GOOGLE_APPLICATION_CREDENTIALS=<VALUE> \
    PACKER_BUILDS=<OPTIONAL>
Assuming this is successful (hence the semi-automatic part), packer will
produce a packer-manifest.json output file.  This contains the base-image
names suitable for updating in .cirrus.yml, env keys *_BASE_IMAGE.
On failure, it should be possible to determine the problem from the packer
output.  Sometimes that means setting PACKER_LOG=1 and troubleshooting
the nested virt calls.  It's also possible to observe the (nested) qemu-kvm
console output.  Simply set the TTYDEV parameter, for example:
$ make libpod_base_images ... TTYDEV=$(tty)
  ...
$SPECIALMODE
Some tasks alter their behavior based on this value. A summary of supported values follows:
- none: Operate as normal, this is the default value if unspecified.
- rootless: Causes a random, ordinary user account to be created and utilized for testing.
- in_podman: Causes testing to occur within a container executed by podman on the host.
- windows: See darwin
- darwin: Signals the- special_testing_crosstask to cross-compile the remote client.