mirror of
https://github.com/netblue30/firejail.git
synced 2026-05-15 06:06:02 -06:00
Some checks failed
Build-extra / build-gcc (push) Has been cancelled
Build-extra / build-clang (push) Has been cancelled
Build / build (push) Has been cancelled
Check-C / scan-build (push) Has been cancelled
Check-C / cppcheck (push) Has been cancelled
Check-C / codeql-cpp (push) Has been cancelled
Check-Profiles / profile-checks (push) Has been cancelled
Codespell / codespell (push) Has been cancelled
Test / test-main (push) Has been cancelled
Test / test-fs (push) Has been cancelled
Test / test-environment (push) Has been cancelled
Test / test-utils (push) Has been cancelled
Test / test-network (push) Has been cancelled
Changes:
* Use `scan-build make` instead of running `scan-build` inside of `make`
(this appears to be necessary for the output synchronization to work)
* Use `-j "$(nproc)"` and `-Orecurse` for the main `make` step in all
jobs (including where this step is currently not parallel)
The main drawback of using parallel make (`-j`) is that the output of
different jobs may be printed interspersed, which makes the output
harder to read and less stable across multiple executions.
Example:
job1: line1
job1: line2
job2: line1
job3: line1
job1: line3
Using `-Orecurse` should fix this by ensuring that the output of all
jobs is still printed sequentially in the order that the jobs were
executed (that is, as if `-j` was not used), even if the jobs themselves
are executed in parallel.
This should ensure that the main `make` step in each job runs its
targets in parallel and has a stable output at the same time, making it
easier to compare the logs of the same job across different CI runs.
Note: The `-O` flag is specific to GNU make and was added in version 4.0
(2013-10-09).
Related commits:
* 500d8f2d6 ("ci: run make in parallel where applicable", 2023-08-14) /
PR #5960
* 1f6400bd8 ("build: sync scan-build target with CI", 2024-02-24) /
PR #6222
269 lines
7.5 KiB
YAML
269 lines
7.5 KiB
YAML
# Checks that the tests are passing.
|
|
|
|
name: Test
|
|
|
|
on:
|
|
workflow_dispatch:
|
|
push:
|
|
branches-ignore:
|
|
- 'dependabot/**'
|
|
paths:
|
|
- 'm4/**'
|
|
- 'src/**.c'
|
|
- 'src/**.h'
|
|
- 'src/**.mk'
|
|
- 'src/**Makefile'
|
|
- 'test/**'
|
|
- .github/workflows/test.yml
|
|
- Makefile
|
|
- config.mk.in
|
|
- config.sh.in
|
|
- configure
|
|
- configure.ac
|
|
- etc/profile-a-l/default.profile
|
|
- src/firecfg/firecfg.config
|
|
pull_request:
|
|
paths:
|
|
- 'm4/**'
|
|
- 'src/**.c'
|
|
- 'src/**.h'
|
|
- 'src/**.mk'
|
|
- 'src/**Makefile'
|
|
- 'test/**'
|
|
- .github/workflows/test.yml
|
|
- Makefile
|
|
- config.mk.in
|
|
- config.sh.in
|
|
- configure
|
|
- configure.ac
|
|
- etc/profile-a-l/default.profile
|
|
- src/firecfg/firecfg.config
|
|
|
|
permissions: # added using https://github.com/step-security/secure-workflows
|
|
contents: read
|
|
|
|
#
|
|
# Faster tests
|
|
#
|
|
|
|
jobs:
|
|
test-main:
|
|
runs-on: ubuntu-22.04
|
|
timeout-minutes: 10
|
|
env:
|
|
SHELL: /bin/bash
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@8d3c67de8e2fe68ef647c8db1e6a09f647780f40
|
|
with:
|
|
egress-policy: block
|
|
allowed-endpoints: >
|
|
azure.archive.ubuntu.com:80
|
|
github.com:443
|
|
packages.microsoft.com:443
|
|
ppa.launchpadcontent.net:443
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd
|
|
- name: update package information
|
|
run: sudo apt-get update -qy
|
|
- name: install dependencies
|
|
run: >
|
|
sudo apt-get install -qy
|
|
gcc-12 libapparmor-dev libselinux1-dev expect xzdec bridge-utils bubblewrap
|
|
- name: print env
|
|
run: ./ci/printenv.sh
|
|
- name: configure
|
|
run: >
|
|
./configure CC=gcc-12
|
|
--prefix=/usr --enable-fatal-warnings --enable-analyzer
|
|
--enable-apparmor --enable-selinux
|
|
|| (cat config.log; exit 1)
|
|
- name: make
|
|
run: make -j "$(nproc)" -Orecurse
|
|
- name: make install
|
|
run: sudo make install
|
|
- name: make installcheck
|
|
run: make installcheck
|
|
- run: make lab-setup
|
|
- run: make test-seccomp-extra
|
|
- run: make test-firecfg
|
|
- run: make test-capabilities
|
|
- run: make test-apparmor
|
|
- run: make test-appimage
|
|
- run: make test-chroot
|
|
- run: make test-fcopy
|
|
|
|
#
|
|
# Slower tests
|
|
#
|
|
|
|
test-fs:
|
|
runs-on: ubuntu-22.04
|
|
timeout-minutes: 10
|
|
env:
|
|
SHELL: /bin/bash
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@8d3c67de8e2fe68ef647c8db1e6a09f647780f40
|
|
with:
|
|
egress-policy: block
|
|
allowed-endpoints: >
|
|
azure.archive.ubuntu.com:80
|
|
github.com:443
|
|
packages.microsoft.com:443
|
|
ppa.launchpadcontent.net:443
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd
|
|
- name: update package information
|
|
run: sudo apt-get update -qy
|
|
- name: install dependencies
|
|
run: >
|
|
sudo apt-get install -qy
|
|
gcc-12 libapparmor-dev libselinux1-dev expect xzdec bridge-utils bubblewrap
|
|
- name: print env
|
|
run: ./ci/printenv.sh
|
|
- name: configure
|
|
run: >
|
|
./configure CC=gcc-12
|
|
--prefix=/usr --enable-fatal-warnings --enable-analyzer
|
|
--enable-apparmor --enable-selinux
|
|
|| (cat config.log; exit 1)
|
|
- name: make
|
|
run: make -j "$(nproc)" -Orecurse
|
|
- name: make install
|
|
run: sudo make install
|
|
- name: make installcheck
|
|
run: make installcheck
|
|
- run: make lab-setup
|
|
- run: make test-private-etc
|
|
- run: make test-fs
|
|
- run: make test-filters
|
|
|
|
test-environment:
|
|
runs-on: ubuntu-22.04
|
|
timeout-minutes: 10
|
|
env:
|
|
SHELL: /bin/bash
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@8d3c67de8e2fe68ef647c8db1e6a09f647780f40
|
|
with:
|
|
egress-policy: block
|
|
allowed-endpoints: >
|
|
azure.archive.ubuntu.com:80
|
|
github.com:443
|
|
packages.microsoft.com:443
|
|
ppa.launchpadcontent.net:443
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd
|
|
- name: update package information
|
|
run: sudo apt-get update -qy
|
|
- name: install dependencies
|
|
run: >
|
|
sudo apt-get install -qy
|
|
gcc-12 libapparmor-dev libselinux1-dev expect xzdec bridge-utils bubblewrap
|
|
- name: print env
|
|
run: ./ci/printenv.sh
|
|
- name: configure
|
|
run: >
|
|
./configure CC=gcc-12
|
|
--prefix=/usr --enable-fatal-warnings --enable-analyzer
|
|
--enable-apparmor --enable-selinux
|
|
|| (cat config.log; exit 1)
|
|
- name: make
|
|
run: make -j "$(nproc)" -Orecurse
|
|
- name: make install
|
|
run: sudo make install
|
|
- name: make installcheck
|
|
run: make installcheck
|
|
- run: make lab-setup
|
|
- run: make test-environment
|
|
- run: make test-profiles
|
|
|
|
test-utils:
|
|
runs-on: ubuntu-22.04
|
|
timeout-minutes: 10
|
|
env:
|
|
SHELL: /bin/bash
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@8d3c67de8e2fe68ef647c8db1e6a09f647780f40
|
|
with:
|
|
egress-policy: block
|
|
allowed-endpoints: >
|
|
azure.archive.ubuntu.com:80
|
|
debian.org:80
|
|
github.com:443
|
|
packages.microsoft.com:443
|
|
ppa.launchpadcontent.net:443
|
|
www.debian.org:443
|
|
www.debian.org:80
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd
|
|
- name: update package information
|
|
run: sudo apt-get update -qy
|
|
- name: install dependencies
|
|
run: >
|
|
sudo apt-get install -qy
|
|
gcc-12 libapparmor-dev libselinux1-dev expect xzdec bridge-utils bubblewrap
|
|
- name: print env
|
|
run: ./ci/printenv.sh
|
|
- name: configure
|
|
run: >
|
|
./configure CC=gcc-12
|
|
--prefix=/usr --enable-fatal-warnings --enable-analyzer
|
|
--enable-apparmor --enable-selinux
|
|
|| (cat config.log; exit 1)
|
|
- name: make
|
|
run: make -j "$(nproc)" -Orecurse
|
|
- name: make install
|
|
run: sudo make install
|
|
- name: make installcheck
|
|
run: make installcheck
|
|
- run: make lab-setup
|
|
- run: make test-utils
|
|
|
|
test-network:
|
|
runs-on: ubuntu-22.04
|
|
timeout-minutes: 10
|
|
env:
|
|
SHELL: /bin/bash
|
|
steps:
|
|
- name: Harden Runner
|
|
uses: step-security/harden-runner@8d3c67de8e2fe68ef647c8db1e6a09f647780f40
|
|
with:
|
|
egress-policy: block
|
|
allowed-endpoints: >
|
|
1.1.1.1:1025
|
|
azure.archive.ubuntu.com:80
|
|
debian.org:80
|
|
dns.quad9.net:53
|
|
github.com:443
|
|
packages.microsoft.com:443
|
|
ppa.launchpadcontent.net:443
|
|
whois.pir.org:43
|
|
www.debian.org:443
|
|
www.debian.org:80
|
|
yahoo.com:1025
|
|
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd
|
|
- name: update package information
|
|
run: sudo apt-get update -qy
|
|
- name: install dependencies
|
|
run: >
|
|
sudo apt-get install -qy
|
|
gcc-12 libapparmor-dev libselinux1-dev expect xzdec whois bubblewrap
|
|
bridge-utils
|
|
- name: print env
|
|
run: ./ci/printenv.sh
|
|
- name: configure
|
|
run: >
|
|
./configure CC=gcc-12
|
|
--prefix=/usr --enable-fatal-warnings --enable-analyzer
|
|
--enable-apparmor --enable-selinux
|
|
|| (cat config.log; exit 1)
|
|
- name: make
|
|
run: make -j "$(nproc)" -Orecurse
|
|
- name: make install
|
|
run: sudo make install
|
|
- name: make installcheck
|
|
run: make installcheck
|
|
- run: make lab-setup
|
|
- run: make test-fnetfilter
|
|
- run: make test-fnettrace
|
|
- run: make test-network
|