Skip to content

Commit

Permalink
Refactor cmake related to python packaging
Browse files Browse the repository at this point in the history
* Bump required `everest-cmake` version to `0.3`
* Add cmake variables to configure python wheels (install prefix)
* Run custom python commands in venv located in build dir
* Setup `ev-cli` automatically by installing it from source in to venv

Refactor CI
* Split into multiple jobs: `Lint`, `Build and Test` and `Run Integration Tests`
* Upload dist directory as artifact
* Upload wheel files as artifact
* Upload result.xml and report.html as artifact
* Render result summary
  • Loading branch information
andistorm committed May 31, 2024
1 parent 54ea32b commit 838784d
Show file tree
Hide file tree
Showing 12 changed files with 170 additions and 39 deletions.
9 changes: 6 additions & 3 deletions .ci/build-kit/compile.sh
Original file line number Diff line number Diff line change
@@ -1,12 +1,15 @@
#!/bin/sh

set -e

cmake \
-B build \
-B "$EXT_MOUNT/build" \
-S "$EXT_MOUNT/source" \
-G Ninja \
-DEVC_ENABLE_CCACHE=1 \
-DISO15118_2_GENERATE_AND_INSTALL_CERTIFICATES=OFF \
-DCMAKE_INSTALL_PREFIX="$WORKSPACE_PATH/dist" \
-DCMAKE_INSTALL_PREFIX="$EXT_MOUNT/dist" \
-DWHEEL_INSTALL_PREFIX="$EXT_MOUNT/dist-wheels" \
-DBUILD_TESTING=ON

ninja -j$(nproc) -C build
ninja -j$(nproc) -C "$EXT_MOUNT/build"
8 changes: 8 additions & 0 deletions .ci/build-kit/install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
#!/bin/sh

set -e

ninja -C "$EXT_MOUNT/build" install
ninja -C "$EXT_MOUNT/build" everestpy_install_wheel
ninja -C "$EXT_MOUNT/build" everest-testing_install_wheel
ninja -C "$EXT_MOUNT/build" iso15118_install_wheel
10 changes: 4 additions & 6 deletions .ci/build-kit/prepare_integration_tests.sh
Original file line number Diff line number Diff line change
@@ -1,11 +1,9 @@
#!/bin/sh

# ninja -j$(nproc) -C build tests
ninja -j$(nproc) -C build install

# install everest testing by cmake target to make sure using the version defined in dependencies.yaml
ninja -C build install_everest_testing
set -e

rsync -a "$EXT_MOUNT/source/tests" ./

rm -rf build
pip install $EXT_MOUNT/wheels/everestpy-*.whl

Check warning on line 7 in .ci/build-kit/prepare_integration_tests.sh

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

.ci/build-kit/prepare_integration_tests.sh#L7

Double quote to prevent globbing and word splitting.
pip install $EXT_MOUNT/wheels/everest_testing-*.whl

Check warning on line 8 in .ci/build-kit/prepare_integration_tests.sh

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

.ci/build-kit/prepare_integration_tests.sh#L8

Double quote to prevent globbing and word splitting.
pip install pytest-html
4 changes: 3 additions & 1 deletion .ci/build-kit/run_unit_tests.sh
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#!/bin/sh

ninja -j$(nproc) -C build test
set -e

ninja -C "$EXT_MOUNT/build" test
5 changes: 4 additions & 1 deletion .ci/e2e/docker-compose.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,10 @@ services:
- MQTT_SERVER_ADDRESS=mqtt-server
volumes:
- type: bind
source: ./scripts
source: ${GITHUB_WORKSPACE}
target: /ext
- type: bind
source: ${GITHUB_WORKSPACE}/source/.ci/e2e/scripts
target: /ext/scripts
sysctls:
- net.ipv6.conf.all.disable_ipv6=0
11 changes: 10 additions & 1 deletion .ci/e2e/scripts/run_integration_tests.sh
Original file line number Diff line number Diff line change
@@ -1,4 +1,13 @@
#!/bin/sh

set -e

cd tests
pytest --everest-prefix ../dist core_tests/*.py framework_tests/*.py
pytest \
-rA \
--junitxml="$EXT_MOUNT/result.xml" \
--html="$EXT_MOUNT/report.html" \
--self-contained-html \
core_tests/*.py \
framework_tests/*.py \
--everest-prefix "$EXT_MOUNT/dist"
102 changes: 88 additions & 14 deletions .github/workflows/build_and_test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,24 @@ on:
- cron: '37 13,1 * * *'

env:
BUILD_KIT_IMAGE: ghcr.io/everest/build-kit-alpine:v1.1.2

BUILD_KIT_IMAGE: ghcr.io/everest/build-kit-alpine:add-pip-install-build
jobs:
lint:
name: Lint
runs-on: ${{ inputs.runner || 'ubuntu-22.04' }}
steps:
- name: Checkout everest-core
uses: actions/[email protected]
with:
path: source
- name: Run clang-format
uses: everest/everest-ci/github-actions/[email protected]
with:
source-dir: source
extensions: hpp,cpp
exclude: cache
build:
name: Build, Lint and Test
name: Build and Unit Tests
runs-on: ${{ inputs.runner || 'ubuntu-22.04' }}
steps:
- name: Format branch name for cache key
Expand All @@ -35,15 +48,9 @@ jobs:
compile-${{ env.branch_name_for_cache }}-
compile-
- name: Checkout everest-core
uses: actions/checkout@v3
uses: actions/checkout@v4.1.6
with:
path: source
- name: Run clang-format
uses: everest/everest-ci/github-actions/[email protected]
with:
source-dir: source
extensions: hpp,cpp
exclude: cache
- name: Setup run scripts
run: |
mkdir scripts
Expand All @@ -67,14 +74,81 @@ jobs:
--volume "$(pwd):/ext" \
--name unit-tests-container \
build-image run-script run_unit_tests
- name: Create dist
run: |
docker run \
--volume "$(pwd):/ext" \
--name install-container \
build-image run-script install
- name: Tar dist dir and keep permissions
run: |
tar -czf dist.tar.gz dist
- name: Upload dist artifact
uses: actions/[email protected]
with:
path: dist.tar.gz
name: dist
- name: Upload wheels artifact
uses: actions/[email protected]
with:
path: dist-wheels
name: wheels
integration-tests:
name: Integration Tests
needs: build
runs-on: ${{ inputs.runner || 'ubuntu-22.04' }}
steps:
- name: Download dist dir
uses: actions/[email protected]
with:
name: dist
- name: Extract dist.tar.gz
run: |
tar -xzf ${{ github.workspace }}/dist.tar.gz -C ${{ github.workspace }}
- name: Download wheels
uses: actions/[email protected]
with:
name: wheels
path: wheels
- name: Checkout everest-core
uses: actions/[email protected]
with:
path: source
- name: Setup run scripts
run: |
mkdir scripts
rsync -a source/.ci/build-kit/ scripts
- name: Pull build-kit image
run: |
docker pull --quiet ${{ env.BUILD_KIT_IMAGE }}
docker image tag ${{ env.BUILD_KIT_IMAGE }} build-kit
- name: Create integration-image
run: |
docker run \
--volume "$(pwd):/ext" \
--name test-container \
build-image run-script prepare_integration_tests
docker commit test-container integration-image
--name prepare-container \
build-kit run-script prepare_integration_tests
docker commit prepare-container integration-image
- name: Run integration tests
run: |
pushd source/.ci/e2e
docker-compose run e2e-test-server run-script run_integration_tests
docker-compose run \
e2e-test-server \
run-script run_integration_tests
- name: Upload result & report as artifact
if: always()
uses: actions/[email protected]
with:
path: |
${{ github.workspace }}/result.xml
${{ github.workspace }}/report.html
name: pytest-results
- name: Render result
if: always()
uses: pmeier/[email protected]
with:
path: ${{ github.workspace }}/result.xml
summary: True
display-options: fEX
fail-on-empty: True
title: Test results
12 changes: 10 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ project(everest-core
LANGUAGES CXX C
)

find_package(everest-cmake 0.1
find_package(everest-cmake 0.3
COMPONENTS bundling
PATHS ../everest-cmake
)
Expand All @@ -17,7 +17,7 @@ if (NOT everest-cmake_FOUND)
FetchContent_Declare(
everest-cmake
GIT_REPOSITORY https://github.com/EVerest/everest-cmake.git
GIT_TAG main
GIT_TAG feature/add-python-cmake-utils
)
FetchContent_MakeAvailable(everest-cmake)
set(everest-cmake_DIR "${everest-cmake_SOURCE_DIR}")
Expand Down Expand Up @@ -48,6 +48,14 @@ endif()
# This is a flag for building development tests, but not necessarily to run them, for expample in case
# tests requires hardware.
option(BUILD_DEV_TESTS "Build dev tests" OFF)
ev_setup_cmake_variables_python_wheel()
option(${PROJECT_NAME}_INSTALL_EV_CLI_IN_PYTHON_VENV "Install ev-cli in python venv instead of using system" ON)
set(${PROJECT_NAME}_PYTHON_VENV_PATH "${CMAKE_BINARY_DIR}/venv" CACHE PATH "Path to python venv")

ev_setup_python_executable(
USE_PYTHON_VENV ${${PROJECT_NAME}_USE_PYTHON_VENV}
PYTHON_VENV_PATH ${${PROJECT_NAME}_PYTHON_VENV_PATH}
)

# Already include CTest here to allow it to find tests defined in subdirectories like lib and modules
if(EVEREST_CORE_BUILD_TESTING)
Expand Down
25 changes: 21 additions & 4 deletions cmake/ev-cli.cmake
Original file line number Diff line number Diff line change
@@ -1,7 +1,24 @@

# check ev-cli version

find_program(EV_CLI ev-cli REQUIRED)
macro(setup_ev_cli)
add_custom_target(ev-cli)
if(${EV_CLI})
message(FATAL_ERROR "EV_CLI is already defined.")
return()
endif()
if(NOT ${${PROJECT_NAME}_USE_PYTHON_VENV})
find_program(EV_CLI ev-cli REQUIRED)
return()
endif()
ev_is_python_venv_active(
RESULT_VAR IS_PYTHON_VENV_ACTIVE
)
if(NOT ${IS_PYTHON_VENV_ACTIVE})
message(FATAL_ERROR "Python venv is not active. Please activate the python venv before running this command.")
endif()
set(EV_CLI "${${PROJECT_NAME}_PYTHON_VENV_PATH}/bin/ev-cli")
add_dependencies(ev-cli
ev-dev-tools_pip_install_dist
)
endmacro()

function(require_ev_cli_version EV_CLI_VERSION_REQUIRED)
execute_process(
Expand Down
5 changes: 4 additions & 1 deletion cmake/ev-project-bootstrap.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ include(${CMAKE_CURRENT_LIST_DIR}/config-run-script.cmake)
include(${CMAKE_CURRENT_LIST_DIR}/config-run-nodered-script.cmake)

# dependencies
require_ev_cli_version("0.1.0")
setup_ev_cli()
if(NOT ${${PROJECT_NAME}_INSTALL_EV_CLI_IN_PYTHON_VENV})
require_ev_cli_version("0.1.0")
endif()

# source generate scripts / setup
include(${CMAKE_CURRENT_LIST_DIR}/everest-generate.cmake)
3 changes: 3 additions & 0 deletions cmake/everest-generate.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -277,6 +277,7 @@ function (_ev_add_interfaces)
"${CHECK_DONE_FILE}"
DEPENDS
${ARGV}
ev-cli
COMMENT
"Generating/updating interface files ..."
VERBATIM
Expand Down Expand Up @@ -315,6 +316,7 @@ function (_ev_add_types)
"${CHECK_DONE_FILE}"
DEPENDS
${ARGV}
ev-cli
COMMENT
"Generating/updating type files ..."
VERBATIM
Expand Down Expand Up @@ -458,6 +460,7 @@ function (ev_add_cpp_module MODULE_NAME)
${RELATIVE_MODULE_DIR}
DEPENDS
${MODULE_PATH}/manifest.yaml
ev-cli
WORKING_DIRECTORY
${PROJECT_SOURCE_DIR}
COMMENT
Expand Down
15 changes: 9 additions & 6 deletions dependencies.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,12 @@
---
everest-framework:
git: https://github.com/EVerest/everest-framework.git
git_tag: v0.14.0
options: ["BUILD_TESTING OFF"]
git_tag: feature/use-cmake-python-functions
options: [
"BUILD_TESTING OFF",
"everest-framework_USE_PYTHON_VENV ${PROJECT_NAME}_USE_PYTHON_VENV",
"everest-framework_USE_PYTHON_VENV_PATH ${PROJECT_NAME}_USE_PYTHON_VENV_PATH",
]
sigslot:
git: https://github.com/palacaze/sigslot
git_tag: v1.2.0
Expand Down Expand Up @@ -61,7 +65,7 @@ libocpp:
# Josev
Josev:
git: https://github.com/EVerest/ext-switchev-iso15118.git
git_tag: 2024.2.1
git_tag: feature/use-everest-cmake
cmake_condition: "EVEREST_ENABLE_PY_SUPPORT AND EVEREST_DEPENDENCY_ENABLED_JOSEV"
# OpenV2G
ext-openv2g:
Expand All @@ -77,11 +81,10 @@ ext-mbedtls:
- ENABLE_PROGRAMS OFF
- ENABLE_TESTING OFF
- MBEDTLS_FATAL_WARNINGS OFF # disables setting warnings as errors FIXME: workaround until upstream-fixes are included
# everest-testing
# everest-testing and ev-dev-tools
everest-utils:
git: https://github.com/EVerest/everest-utils.git
git_tag: v0.2.3
cmake_condition: "EVEREST_CORE_BUILD_TESTING"
git_tag: feature/add-cmake

# unit testing
gtest:
Expand Down

0 comments on commit 838784d

Please sign in to comment.