zeek/ci
Tim Wojtulewicz 269fdcdcfc Force Windows CI to use OpenSSL 3.1.1
There's something wrong with chocolatey's OpenSSL 3.2.0 package that
causes cmake to not be able to find libcrypto even though it's clearly
in the directory. Pinning to 3.1.1 fixes the build issue.

(cherry picked from commit 5a7c482a0f)
2024-05-14 10:56:59 -07:00
..
alpine CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
centos-7 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
centos-stream-8 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
centos-stream-9 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
debian-10 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
debian-11 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
debian-12 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
fedora-38 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
fedora-39 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
freebsd Use ensurepip to install pip on FreeBSD 2023-02-22 13:27:20 -07:00
macos CI: Fix python installations on alpine 2024-05-14 10:17:24 -07:00
opensuse-leap-15.5 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
opensuse-tumbleweed CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
ubuntu-18.04 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
ubuntu-20.04 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
ubuntu-22.04 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
ubuntu-23.10 CI: Force rebuilds of all of the VMs 2024-05-14 10:17:24 -07:00
windows Force Windows CI to use OpenSSL 3.1.1 2024-05-14 10:56:59 -07:00
benchmark.sh ci/benchmark: Send more Cirrus, GitHub and Zeek version information 2023-09-19 19:57:51 +02:00
build.sh Remove comment about osx-sysroot [nomail] [skip ci] 2023-01-30 15:41:37 -07:00
collect-repo-info.py Tweak format of zkg information in build info. 2023-05-16 10:21:21 +02:00
common.sh Rework .cirrus.yml a bit to commonize some parts 2022-05-19 09:21:55 -07:00
container-images-tag-and-push.sh cirrus/container: Polish, fix and automated pushing of images 2023-02-13 12:08:53 +01:00
find-current-version.sh cirrus/container: Polish, fix and automated pushing of images 2023-02-13 12:08:53 +01:00
init-external-repos.sh CI: Use other base64 options on macOS Sonoma too 2024-01-18 14:09:51 -08:00
public-ecr-cleanup.sh ci: Add public-ecr-vacuum.sh 2023-05-05 12:11:09 +02:00
README spelling: organization 2022-11-15 17:47:49 -05:00
test-fuzzers.sh Move fuzzer corpus files to another directory 2022-08-26 13:51:30 -07:00
test.sh ci: Remove ZEEK_CI_DISABLE_SCRIPT_PROFILING logic 2024-01-18 14:09:51 -08:00
tsan_suppressions.txt Merge remote-tracking branch 'origin/topic/timw/tsan-upgrade' 2023-08-09 15:57:39 -07:00
update-zeekygen-docs.sh Format shell scripts with shfmt. 2021-11-24 23:13:02 +01:00
upload-coverage.sh Prevent non-master builds, add cirrus information to upload 2020-10-22 00:56:20 +00:00

=========================================
Continuous Integration Configuration Info
=========================================

The following pointers are aimed at maintainers to help describe a few points
about the Cirrus CI setup that may not be obvious/intuitive.

Private Test Suite
------------------

Access to the private test suite is available in CI tasks except in Pull
Requests from people that do not otherwise have write access to the zeek
repository on GitHub.  To configure this access for the
``zeek-testing-private`` repository, it uses a "deploy key" which is a single
purpose SSH key with read-only permissions.  Here's how it can be set up:

1. ``ssh-keygen -f cirrus-key``

2. Add contents of ``cirrus-key.pub`` as a new key on GitHub:
   https://github.com/zeek/zeek-testing-private/settings/keys

3. Generate a new Organization-Level Secured Variable in Cirrus CI settings at
   https://cirrus-ci.com/settings/github/zeek.  The value of the secured
   variable is the base64-encoded private key, and can be obtained from the
   output of the command: ``base64 cirrus-key``.

4. Take the ``ENCRYPTED[...]``` string generated by Cirrus and use that as the
   value of ``ZEEK_TESTING_PRIVATE_SSH_KEY`` in ``.cirrus.yml``

5. Delete the local key: ``rm cirrus-key*``

6. Commit/push the changes.

Email Notifications
-------------------

Cirrus CI doesn't feature any way to perform email notifications on failures,
so that is instead handled by a separate GitHub Action:

  https://github.com/zeek/ci-email-action

The configuration of that GitHub Action is typical: it's the
``.github/workflows/ci-notification.yml`` file, which sets SMTP/mail info
via secrets stored in GitHub for the Zeek organization:

  https://github.com/organizations/zeek/settings/secrets

The particular values used for those are currently from the Zeek project's AWS
Simple Email Service configuration.