The machine that is used to upload QEMU builds to Coverity is used daily
as a development machine by Emanuele and myself, and as a result sometimes
its podman/docker setup gets messed up. When this happens, Coverity
uploads might stop for extended periods of time.
In the interest of tightening this and of depending less on infrastructure
maintained by specific people, replace the manually-managed crontab
entry with a new job in GitLab's CI; this is also what Libvirt does.
The rules to trigger it are a bit different compared to other jobs:
* on mainline, it only runs for the default (master) branch and only
as part of scheduled pipeline runs. A rule is added to remove all
other jobs when running from a scheduled pipeline.
* on forks, it is always manual (and only appears if QEMU_CI=1 or 2,
like other build jobs)
For now I implemented these rules directly in the buildtest.yml file,
but it is also possible to add a QEMU_JOB_SCHEDULE variable.
Example of a working run: https://gitlab.com/bonzini/qemu/-/jobs/6312777493
Example of a run that is over quota: https://gitlab.com/bonzini/qemu/-/jobs/6315895373
This run shows an attempt to cancel the job if the quota is exceeded, but
it does not work (it worked on GitLab <17.0) so I removed it from the patch.
Paolo
Paolo Bonzini (2):
run-coverity-scan: add --check-upload-only option
gitlab-ci: add manual job to run Coverity
.gitlab-ci.d/base.yml | 4 ++
.gitlab-ci.d/buildtest.yml | 36 +++++++++++++++++
scripts/coverity-scan/run-coverity-scan | 51 ++++++++++++++++++-------
3 files changed, 78 insertions(+), 13 deletions(-)
--
2.39.1