Skip to content

Commit

Permalink
Try a classic virtualenv approach.
Browse files Browse the repository at this point in the history
Signed-off-by: fruffy <[email protected]>
  • Loading branch information
fruffy committed Dec 24, 2024
1 parent 3fd067c commit da4212d
Show file tree
Hide file tree
Showing 14 changed files with 92 additions and 35 deletions.
18 changes: 11 additions & 7 deletions .github/workflows/ci-lint.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -35,16 +35,20 @@ jobs:
tools/ci-build.sh
- name: Run cpplint on C/C++ files.
run: poetry run cmake --build build --target cpplint
run: |
source venv/bin/activate
cmake --build build --target cpplint
- name: Run clang-format on C/C++ files.
run: |
poetry run clang-format --version
poetry run cmake --build build --target clang-format
source venv/bin/activate
clang-format --version
cmake --build build --target clang-format
- name: Run black and isort on Python files.
run: |
poetry run black --version
poetry run cmake --build build --target black
poetry run isort --version
poetry run cmake --build build --target isort
source venv/bin/activate
black --version
cmake --build build --target black
isort --version
cmake --build build --target isort
4 changes: 3 additions & 1 deletion .github/workflows/ci-p4tools.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,5 +40,7 @@ jobs:
- name: Run tests (Ubuntu 22.04)
# Need to use sudo for the eBPF kernel tests.
run: sudo -E env PATH="$PATH" poetry run ctest -R "testgen|smith" --output-on-failure --schedule-random
run: |
source venv/bin/activate
sudo -E env PATH="$PATH" ctest -R "testgen|smith" --output-on-failure --schedule-random
working-directory: ./build
2 changes: 1 addition & 1 deletion .github/workflows/ci-ptf-kernels-weekly.yml
Original file line number Diff line number Diff line change
Expand Up @@ -119,4 +119,4 @@ jobs:

- name: Install VM and run PTF tests for eBPF backend
run: |
sudo -E ./tools/ci-ptf/run_test.sh sudo docker run --privileged -v /sys/fs/bpf:/sys/fs/bpf -w /p4c/backends/ebpf/tests p4c poetry run ./test.sh
sudo -E ./tools/ci-ptf/run_test.sh sudo docker run --privileged -v /sys/fs/bpf:/sys/fs/bpf -w /p4c/backends/ebpf/tests p4c ./test.sh
5 changes: 3 additions & 2 deletions .github/workflows/ci-ptf.yml
Original file line number Diff line number Diff line change
Expand Up @@ -53,5 +53,6 @@ jobs:
tools/ci-build.sh
- name: Run PTF tests for eBPF backend (Ubuntu 20.04)
run: sudo -E env PATH="$PATH" poetry run ./test.sh
working-directory: ./backends/ebpf/tests
run: |
source build/venv/bin/activate
sudo -E env PATH="$PATH" poetry run backends/ebpf/test.sh
9 changes: 6 additions & 3 deletions .github/workflows/ci-test-debian.yml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,8 @@ jobs:
- name: Run tests (Ubuntu 24.04)
# Need to use sudo for the eBPF kernel tests.
run: |
sudo -E env PATH="$PATH" poetry run ctest --output-on-failure --schedule-random
source venv/bin/activate
sudo -E env PATH="$PATH" ctest --output-on-failure --schedule-random
working-directory: ./build

# Build with GCC and test P4C on Ubuntu 22.04.
Expand Down Expand Up @@ -70,7 +71,8 @@ jobs:
- name: Run tests (Ubuntu 22.04)
# Need to use sudo for the eBPF kernel tests.
run: |
sudo -E env PATH="$PATH" poetry run ctest --output-on-failure --schedule-random
source venv/bin/activate
sudo -E env PATH="$PATH" ctest --output-on-failure --schedule-random
working-directory: ./build

# Build with GCC and test Tofino backend on Ubuntu 22.04.
Expand Down Expand Up @@ -144,6 +146,7 @@ jobs:
- name: Run tests (Ubuntu 20.04)
# Need to use sudo for the eBPF kernel tests.
run: |
sudo -E env PATH="$PATH" poetry run ctest --output-on-failure --schedule-random
source venv/bin/activate
sudo -E env PATH="$PATH" ctest --output-on-failure --schedule-random
working-directory: ./build
if: matrix.unity == 'ON' && matrix.gtest == 'ON'
4 changes: 2 additions & 2 deletions .github/workflows/ci-test-fedora.yml
Original file line number Diff line number Diff line change
Expand Up @@ -47,12 +47,12 @@ jobs:

- name: Build p4c (Fedora Linux)
run: |
export PATH="$HOME/.local/bin:$PATH"
./bootstrap.sh -DCMAKE_BUILD_TYPE=Release -DCMAKE_UNITY_BUILD=ON --build-generator "Ninja"
source venv/bin/activate
cmake --build build -- -j $(nproc)
- name: Run p4c tests (Fedora Linux)
run: |
export PATH="$HOME/.local/bin:$PATH"
source venv/bin/activate
poetry run ctest --output-on-failure --schedule-random
working-directory: ./build
6 changes: 4 additions & 2 deletions .github/workflows/ci-test-mac.yml
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,8 @@ jobs:
- name: Run tests (MacOS)
run: |
source ~/.bash_profile
poetry run ctest --output-on-failure --schedule-random -E "bpf|ubpf|testgen|smith"
source venv/bin/activate
ctest --output-on-failure --schedule-random -E "bpf|ubpf|testgen|smith"
working-directory: ./build

# Build and test p4c on MacOS 13 on x86.
Expand Down Expand Up @@ -107,5 +108,6 @@ jobs:
- name: Run tests (MacOS)
run: |
source ~/.bash_profile
poetry run ctest --output-on-failure --schedule-random -E "bpf|ubpf|testgen|smith"
source venv/bin/activate
ctest --output-on-failure --schedule-random -E "bpf|ubpf|testgen|smith"
working-directory: ./build
2 changes: 1 addition & 1 deletion .github/workflows/ci-ubuntu-18-nightly.yml
Original file line number Diff line number Diff line change
Expand Up @@ -39,4 +39,4 @@ jobs:
# this is needed to create network namespaces for the ebpf tests.
- name: Run tests (Ubuntu 18.04)
run: |
sudo -E docker run --privileged -w /p4c/build -e $CTEST_PARALLEL_LEVEL p4c poetry run --output-on-failure --schedule-random
sudo -E docker run --privileged -w /p4c/build -e $CTEST_PARALLEL_LEVEL p4c ctest --output-on-failure --schedule-random
4 changes: 3 additions & 1 deletion .github/workflows/ci-ubuntu-20-sanitizer-nightly.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,5 +40,7 @@ jobs:
- name: Run tests (Ubuntu 20.04)
# Need to use sudo for the eBPF kernel tests.
run: sudo -E env PATH="$PATH" poetry run ctest --output-on-failure --schedule-random
run: |
source venv/bin/activate
sudo -E env PATH="$PATH" ctest --output-on-failure --schedule-random
working-directory: ./build
3 changes: 2 additions & 1 deletion .github/workflows/ci-validation-nightly.yml
Original file line number Diff line number Diff line change
Expand Up @@ -38,5 +38,6 @@ jobs:
- name: Validate
run: |
poetry run ctest -R toz3-validate-p4c --output-on-failure --schedule-random
source venv/bin/activate
ctest -R toz3-validate-p4c --output-on-failure --schedule-random
working-directory: ./build
32 changes: 32 additions & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
# General testing utilities.
pyroute2==0.7.3
ply==3.11
scapy==2.5.0

# Utilities for BMv2 and PTF tests.
ptf==0.10.0
googleapis-common-protos==1.53.0

# gRPC and protobuf dependencies.
grpcio==1.67.0; python_version > "3.6"
grpcio==1.48.2; python_version <= "3.6"
thrift==0.21.0
protobuf==3.20.2; python_version > "3.6"
protobuf==3.19.2; python_version <= "3.6"

# Linters and formatters.
clang-format==18.1.0
black==24.3.0; python_version > "3.6"
black==22.8.0; python_version <= "3.6"
isort==5.13.2; python_version > "3.6"
isort==5.10.1; python_version <= "3.6"

# P4Runtime from Git
# FIXME: We should figure out a way to synchronize P4Runtime versions across CMake and Poetry. This is the same commit hash as defined in the top-level CMakelists.txt
git+https://github.com/p4lang/p4runtime.git@ec4eb5ef70dbcbcbf2f8357a4b2b8c2f218845a5#subdirectory=py

# Tools for the Tofino back end.
# FIXME: The Tofino back end should vendor these tools or use them locally.
jsl==0.2.4
pyinstaller==6.11.0
jsonschema==4.23.0
15 changes: 8 additions & 7 deletions tools/ci-build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -97,6 +97,7 @@ P4C_DEPS="bison \
pkg-config \
python3 \
python3-pip \
python3-venv \
python3-setuptools \
tcpdump"

Expand All @@ -107,10 +108,7 @@ fi

sudo apt-get update
sudo apt-get install -y --no-install-recommends ${P4C_DEPS}
# Set up poetry.
sudo apt-get install -y python3-venv curl
curl -sSL https://install.python-poetry.org | python3 -
poetry install -C ${P4C_DIR}


if [ "${BUILD_GENERATOR,,}" == "ninja" ] && [ ! $(command -v ninja) ]
then
Expand Down Expand Up @@ -288,12 +286,15 @@ fi
if [ -e build ]; then /bin/rm -rf build; fi
mkdir -p ${P4C_DIR}/build
cd ${P4C_DIR}/build
poetry run cmake ${CMAKE_FLAGS} -G "${BUILD_GENERATOR}" ..
virtualenv venv
source venv/bin/activate
pip3 install -r ${P4C_DIR}/requirements.txt
cmake ${CMAKE_FLAGS} -G "${BUILD_GENERATOR}" ..

# If CMAKE_ONLY is active, only run CMake. Do not build.
if [ "$CMAKE_ONLY" == "OFF" ]; then
poetry run cmake --build . -- -j $(nproc)
sudo poetry run cmake --install .
cmake --build . -- -j $(nproc)
sudo -E env PATH="$PATH" cmake --install .
# Print ccache statistics after building
ccache -p -s
fi
Expand Down
11 changes: 7 additions & 4 deletions tools/install_fedora_deps.sh
Original file line number Diff line number Diff line change
Expand Up @@ -61,10 +61,6 @@ sudo dnf install -y -q \
zlib-devel \
ninja-build

# Set up poetry.
curl -sSL https://install.python-poetry.org | python3 -
poetry install

MAKEFLAGS="-j$(nproc)"
export MAKEFLAGS

Expand All @@ -91,3 +87,10 @@ make -j$((`nproc`+1)) install-strip
popd

rm -rf "${tmp_dir}"

mkdir -p ${P4C_DIR}/build
pushd ${P4C_DIR}/build
virtualenv venv
source venv/bin/activate
pip3 install -r ${P4C_DIR}/requirements.txt
popd
12 changes: 9 additions & 3 deletions tools/install_mac_deps.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@
set -e # Exit on error.
set -x # Make command execution verbose

THIS_DIR=$( cd -- "$( dirname -- "${0}" )" &> /dev/null && pwd )
P4C_DIR=$(readlink -f ${THIS_DIR}/..)

# Installation helper.
brew_install() {
echo "\nInstalling $1"
Expand Down Expand Up @@ -63,6 +66,9 @@ fi
echo 'export PATH="$HOME/.local/bin:$PATH"' >> ~/.bash_profile
source ~/.bash_profile

# Set up poetry.
curl -sSL https://install.python-poetry.org | python3 -
poetry install
mkdir -p ${P4C_DIR}/build
pushd ${P4C_DIR}/build
virtualenv venv
source venv/bin/activate
pip3 install -r ${P4C_DIR}/requirements.txt
popd

0 comments on commit da4212d

Please sign in to comment.