Skip to content

Latest commit

 

History

History
73 lines (50 loc) · 2.9 KB

README.md

File metadata and controls

73 lines (50 loc) · 2.9 KB

buildstrap

Bootstrap generation of CircleCI config.yml for RPM builds of the latest OS releases. Creates generated_config.yml that builds and deploys RPM against supported OS versions.

Benefits

This allows for a more centralized and unified config.yml across many spec repositories. Furthermore, the config.yml itself becomes more dynamic and auto-maintained to have builds against recent operating systems.

Setup

The buildstrap automatically updates generated_config.yml by running ~/buildstrap/cron.sh on the GetPageSpeed build server daily.

The list of operating systems supported can be updated in matrix.yml. The rpmbuilder images are tagged based on expected RPM dist tag of an operating system, e.g. getpagespeed/rpmbuilder:amzn2.

So matrix.yml file simply specifies the operating system label as understood by lastversion and their corresponding dist tag in order to build against the correct rpmbuilder image.

The matrix.json file contains all distros and their versions, used in various workflows.

As a special case, we also create generated_config_nginx.yml which creates workflows bound to the many branches of NGINX we build against: master (aka stable), mainline and plesk.

Example of implementation can be found in nginx-module-pagespeed-rpm.

Project setup

cd /rpm/project/dir
mkdir -p .circleci
curl https://raw.githubusercontent.com/GetPageSpeed/buildstrap/main/config.yml -o .circleci/config.yml

For memory/CPU intensive builds, run this instead:

cd /rpm/project/dir
mkdir -p .circleci
curl https://raw.githubusercontent.com/GetPageSpeed/buildstrap/main/config_large.yml -o .circleci/config.yml

In other words, copy config.yml (single branch project) or config_nginx.yml (NGINX module project) into .circleci/config.yml' of a spec project. Use config_large.yml` for "heavy" binaries which likely to exceed RAM on the small default CircleCi resource class.

In CircleCi, navigate to Project settings > Advanced -> Dynamic config using setup workflows.

Usage in a spec project repository

Refer to wrk example. In the static config.yml we use setup: true and fetch the recent generated_config.yml.

In this way, whenever the software is updated (GitHub repo is changed), we build it against desired set of operating systems.

However, when a new operating system is released, there is no automatic rebuild of the package. This can be implemented by triggering CircleCi workflows for individual spec projects using API.

For a software that is regularly updated, triggering workflows isn't required...

Anyway, triggering the build is possible via API like the following, e.g.:

curl --request POST \
  --url https://circleci.com/api/v2/project/github/GetPageSpeed/guetzli-rpm/pipeline \
  --header 'Circle-Token: xxx' \
  --header 'content-type: application/json'