-
Notifications
You must be signed in to change notification settings - Fork 684
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
support ubuntu 24 in CI #1486
support ubuntu 24 in CI #1486
Changes from 30 commits
1ee855f
f3edb1a
ed212f4
ed73da0
65dc067
800d192
4600133
8054c90
a7603f0
ab07076
2868ccf
ce005bd
7d3d143
4a7f697
4f4147f
e39de2b
5f80c36
8541ce1
2241be8
84245b7
6d31da5
a5f2dac
7b18e8b
5ea9c4f
9963098
bd3ce12
a853f08
10b4866
5828da4
04a2216
167664d
4f3dc32
2b4ac4e
f3ed6b2
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -32,6 +32,7 @@ jobs: | |
apk update && apk add cppcheck python3-dev | ||
python3 -m pip install cmake-format clang-format==18.1.6 | ||
|
||
# TODO: investigate how to run pre-commit with `venv` | ||
- uses: pre-commit/action@2c7b3805fd2a0fd8c1884dcaebf91fc102a13ecd # v3.0.1 | ||
tigercosmos marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
- name: CMake format | ||
|
@@ -53,28 +54,23 @@ jobs: | |
strategy: | ||
matrix: | ||
include: | ||
- image: ubuntu2404 | ||
config-zstd: OFF | ||
- image: ubuntu2204 | ||
python: python3 | ||
config-zstd: OFF | ||
- image: ubuntu2204-icpx | ||
python: python3 | ||
config-zstd: OFF | ||
additional-flags: -DCMAKE_C_COMPILER=icx -DCMAKE_CXX_COMPILER=icpx | ||
additional-gcov-flags: --gcov-executable "llvm-cov gcov" | ||
- image: ubuntu2004 | ||
python: python3 | ||
config-zstd: OFF | ||
- image: rhel94 | ||
python: python3 | ||
config-zstd: OFF | ||
- image: ubuntu2004-zstd | ||
python: python3 | ||
config-zstd: ON | ||
- image: fedora39 | ||
python: python3 | ||
config-zstd: OFF | ||
- image: alpine317 | ||
python: python3 | ||
config-zstd: OFF | ||
|
||
steps: | ||
|
@@ -111,16 +107,17 @@ jobs: | |
|
||
- name: Test PcapPlusPlus | ||
run: | | ||
${{ matrix.python }} -m pip install -U pip | ||
${{ matrix.python }} -m pip install -r ci/run_tests/requirements.txt | ||
${{ matrix.python }} ci/run_tests/run_tests.py --interface eth0 ${{ matrix.test-flags }} | ||
python3 -m venv ./venv | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nit: Maybe move this line to it's own step? It looks weird to me that the venv is created inside the 'Test PCPP' step but the following steps also depend on it. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sure. Moved it to a step. |
||
. ./venv/bin/activate | ||
python3 -m pip install -r ci/run_tests/requirements.txt | ||
python3 ci/run_tests/run_tests.py --interface eth0 ${{ matrix.test-flags }} | ||
|
||
- name: Test Examples | ||
run: | | ||
. ./venv/bin/activate | ||
cd Tests/ExamplesTest | ||
${{ matrix.python }} -m pip install -U pip | ||
${{ matrix.python }} -m pip install -r requirements.txt | ||
${{ matrix.python }} -m pytest --interface eth0 --root-path=../../Dist/examples_bin | ||
python3 -m pip install -r requirements.txt | ||
python3 -m pytest --interface eth0 --root-path=../../Dist/examples_bin | ||
|
||
- name: Check installation | ||
run: | | ||
|
@@ -138,7 +135,8 @@ jobs: | |
|
||
- name: Create Cobertura Report | ||
run: | | ||
${{ matrix.python }} -m pip install gcovr | ||
. ./venv/bin/activate | ||
python3 -m pip install gcovr | ||
gcovr -v -r . ${{ matrix.additional-gcov-flags }} $GCOVR_FLAGS -o coverage.xml | ||
|
||
- name: Upload Coverage Results | ||
|
@@ -347,15 +345,15 @@ jobs: | |
# We can't run cross compiled binaries | ||
if: ${{ matrix.host-arch == matrix.arch }} | ||
run: | | ||
python -m pip install -U pip | ||
python -m venv ./venv | ||
source ./venv/bin/activate | ||
python -m pip install -r ci/run_tests/requirements.txt | ||
python ci/run_tests/run_tests.py --interface en0 | ||
|
||
- name: Test Examples | ||
if: ${{ matrix.host-arch == matrix.arch }} | ||
run: | | ||
cd Tests/ExamplesTest | ||
python -m pip install -U pip | ||
python -m pip install -r requirements.txt | ||
python -m pytest --interface en0 --use-sudo --root-path=../../Dist/examples_bin | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why does the first step use 'venv' and the second doesn't? |
||
|
||
|
@@ -605,7 +603,6 @@ jobs: | |
|
||
echo "Testing PcapPlusPlus examples" | ||
cd Tests/ExamplesTest | ||
python3 -m ensurepip | ||
python3 -m pip install -r requirements.txt | ||
python3 -m pytest --interface "$interface_name" --root-path=../../Dist/examples_bin | ||
|
||
|
@@ -711,7 +708,8 @@ jobs: | |
|
||
- name: Test PcapPlusPlus | ||
run: | | ||
python -m pip install -U pip | ||
python -m venv ./venv | ||
source ./venv/bin/activate | ||
python -m pip install -r ci/run_tests/requirements.txt | ||
python ci/run_tests/run_tests.py --interface eth0 --use-sudo --pcap-test-args="-t xdp" | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not related with this PR directly but, it is possible to use pre-commit.ci but we should remove cppcheck and clang-format from pre-commit since they require pre-installed binaries.