Skip to content

Commit

Permalink
APT-4788: Prebuilding (and then reusing) binaries for common targets …
Browse files Browse the repository at this point in the history
…to speed up builds
  • Loading branch information
iurii-provizio committed Oct 7, 2024
1 parent 70312f2 commit 2984a82
Show file tree
Hide file tree
Showing 12 changed files with 714 additions and 363 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

set -e

cd $(cd -P -- "$(dirname -- "$0")" && pwd -P)
cd "$(cd "$(dirname "$0")" && pwd -P)"

source ./python_venv.sh

Expand Down
124 changes: 124 additions & 0 deletions .github/workflows/build_cache.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
#!/bin/bash

# Copyright 2023 Provizio Ltd.
#
# 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.

# Use as:
# build_cache.sh [BUILD_TYPE=Release] [PYTHON=OFF|ON] [STATIC_ANALYSIS=OFF|ON]

set -eu
set -o pipefail

BUILD_TYPE=${1:-"Release"}
PYTHON=${2:-"ON"}
STATIC_ANALYSIS=${3:-"OFF"}

cd "$(cd "$(dirname "$0")" && pwd -P)"

source ./python_venv.sh

cd ../..

BIN_CACHE_CONFIG_NAME="$(./bin_cache_config_name.sh "${BUILD_TYPE}")"
BIN_CACHE_PATH="$(realpath ./cache)"
TARGET_PATH="${BIN_CACHE_PATH}/${BIN_CACHE_CONFIG_NAME}"
PYTHON_TARGET_PATH="${TARGET_PATH}/python"

PROVIZIO_DDS_CHECK_FILE="${TARGET_PATH}/lib/libprovizio_dds.so"
CACHED_PROVIZIO_DDS_PYTHON_TYPES_SO="${PYTHON_TARGET_PATH}/provizio_dds_python_types/_provizio_dds_python_types.so"

# Check if it's already built
ALREADY_BUILT="FALSE"
if [ -f "${TARGET_PATH}.zip" ]; then
ALREADY_BUILT="TRUE"
unzip -q "${TARGET_PATH}.zip" -d "${BIN_CACHE_PATH}"

if [ ! -f "${PROVIZIO_DDS_CHECK_FILE}" ]; then
ALREADY_BUILT="FALSE"
fi
if [ "${PYTHON}" == "ON" ] && [ ! -f "${CACHED_PROVIZIO_DDS_PYTHON_TYPES_SO}" ]; then
ALREADY_BUILT="FALSE"
fi

rm -rf "${TARGET_PATH}"
fi

if [ "${ALREADY_BUILT}" == "TRUE" ]; then
echo "The bin cache is already built for ${BIN_CACHE_CONFIG_NAME}"
else
echo "Building bin cache for ${BIN_CACHE_CONFIG_NAME}..."

# But first, let's delete any obsolete version there may be
# shellcheck disable=SC2046
rm -rf "${BIN_CACHE_PATH:?}"/$(./bin_cache_config_name.sh "${BUILD_TYPE}" WILDCARD)*

IGNORE_BIN_CACHE=TRUE .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${BUILD_TYPE}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${PYTHON}" -DENABLE_TESTS="OFF" -DENABLE_CHECK_FORMAT="OFF" -DCMAKE_INSTALL_PREFIX="${TARGET_PATH}" -DPYTHON_PACKAGES_INSTALL_DIR="${PYTHON_TARGET_PATH}"
cd ./build
cmake --install .

# Delete extra copy of python-specific libs produced by Fast-DDS Python wrapper (as it's already included in dedicated Python subfolder)
rm -rf "${TARGET_PATH}"/lib/python*
# Delete extra cmake files
rm -rf "${TARGET_PATH}/lib/cmake"

# Collect all the dependencies as well
collect_libs() {
local binary="$1"
local output_dir="$2"
local lib_basename

# Update RPATH to make it look for its dependencies in the same directory
# shellcheck disable=SC2016
patchelf --set-rpath '$ORIGIN' "${binary}"

# Use ldd to find shared libraries the binary depends on
ldd "${binary}" | awk '/=>/ { print $(NF-1) }' | while read -r lib; do
if [ -n "${lib}" ] && [ -f "${lib}" ]; then
# Exclude system libraries
lib_basename="$(basename "${lib}")"
if [[ "${lib_basename}" != libc.so* && "${lib_basename}" != libm.so* ]]; then
# Copy the library if it hasn't been copied yet
if [ ! -f "${output_dir}/${lib_basename}" ]; then
if [ -L "${lib}" ]; then
cp -a "$(realpath "${lib}")" "${output_dir}/"
fi
cp -a "${lib}" "${output_dir}/"

# Recursively collect dependencies of the copied library
collect_libs "${output_dir}/${lib_basename}" "${output_dir}"
fi
fi
fi
done
}
collect_all_libs() {
local dir_to_process="$1"
for file in "${dir_to_process}"/*; do
# Skip if the file is a soft link or not an executable/shared object
if [ ! -L "${file}" ] && [ -f "${file}" ] && { [[ -x "${file}" ]] || [[ "${file}" == *.so* ]]; }; then
collect_libs "${file}" "${dir_to_process}"
fi
done
}

collect_all_libs "${TARGET_PATH}/lib"
collect_all_libs "${TARGET_PATH}/python/fastdds"
collect_all_libs "${TARGET_PATH}/python/provizio_dds"
collect_all_libs "${TARGET_PATH}/python/provizio_dds_python_types"

# zip it now!
cd "${BIN_CACHE_PATH}"
zip -r -y "${BIN_CACHE_CONFIG_NAME}.zip" "${BIN_CACHE_CONFIG_NAME}"
rm -rf "${TARGET_PATH}"
fi
2 changes: 1 addition & 1 deletion .github/workflows/check_license_headers.sh
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ set -e
# List of all excluded files
EXCLUDED=("./python/gps_utils.py")

cd $(cd -P -- "$(dirname -- "$0")" && pwd -P)
cd "$(cd "$(dirname "$0")" && pwd -P)"
cd ../..

# Use as check_license_header file_to_check comment_mark
Expand Down
47 changes: 44 additions & 3 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,45 @@ on:
pull_request:

jobs:
build-cache:
name: Build bin cache for build speed-up
runs-on: ${{matrix.runner}}
strategy:
matrix:
runner: [ubuntu-20.04, linux_arm]
build_type: [Release]
fail-fast: true
env:
CC: gcc
STATIC_ANALYSIS: OFF
WITH_PYTHON: ON
steps:
- uses: actions/checkout@v3
- run: .github/workflows/sudo.sh ./install_dependencies.sh "${WITH_PYTHON}" "${STATIC_ANALYSIS}"
- run: .github/workflows/build_cache.sh "${{matrix.build_type}}" "${WITH_PYTHON}" "${STATIC_ANALYSIS}"
- run: echo "cache_artifact_name=$(./bin_cache_config_name.sh "${{matrix.build_type}}")" >> $GITHUB_ENV
- uses: actions/upload-artifact@v4
with:
name: ${{env.cache_artifact_name}}
path: cache/${{env.cache_artifact_name}}.zip
if-no-files-found: error
retention-days: 1

commit-cache:
name: Commit bin cache
needs: build-cache
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- run: rm -rf cache/*.zip
- uses: actions/download-artifact@v4
with:
merge-multiple: true
path: cache/
- uses: stefanzweifel/git-auto-commit-action@v4
with:
commit_message: Bin cache for common configurations

check-license-headers:
name: Check license headers
runs-on: ubuntu-latest
Expand Down Expand Up @@ -45,7 +84,7 @@ jobs:
steps:
- uses: actions/checkout@v3
- run: .github/workflows/sudo.sh ./install_dependencies.sh "${{matrix.with_python}}" "${STATIC_ANALYSIS}" ${ENABLE_ROS_TESTS}
- run: .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${{matrix.build_type}}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${{matrix.with_python}}" -DENABLE_ROS_TESTS=${ENABLE_ROS_TESTS}
- run: .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${{matrix.build_type}}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${{matrix.with_python}}" -DENABLE_TESTS=ON -DENABLE_ROS_TESTS=${ENABLE_ROS_TESTS}
- run: .github/workflows/test.sh

test-nix-pip-package:
Expand Down Expand Up @@ -76,10 +115,11 @@ jobs:
CC: ${{matrix.cc}}
STATIC_ANALYSIS: OFF
ENABLE_ROS_TESTS: OFF
IGNORE_BIN_CACHE: TRUE
steps:
- uses: actions/checkout@v3
- run: .github/workflows/sudo.sh ./install_dependencies.sh "ON" "${STATIC_ANALYSIS}" "${ENABLE_ROS_TESTS}" /usr/
- run: .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${{matrix.build_type}}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${{matrix.with_python}}" -DENABLE_ROS_TESTS="${ENABLE_ROS_TESTS}"
- run: .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${{matrix.build_type}}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${{matrix.with_python}}" -DENABLE_TESTS=ON -DENABLE_ROS_TESTS="${ENABLE_ROS_TESTS}"
- run: .github/workflows/test.sh

test-nix-pip-package-preinstalled-fastdds:
Expand All @@ -92,6 +132,7 @@ jobs:
env:
CC: ${{matrix.cc}}
STATIC_ANALYSIS: OFF
IGNORE_BIN_CACHE: TRUE
steps:
- uses: actions/checkout@v3
- run: .github/workflows/sudo.sh ./install_dependencies.sh "ON" "${STATIC_ANALYSIS}" OFF /usr/
Expand All @@ -112,7 +153,7 @@ jobs:
steps:
- uses: actions/checkout@v3
- run: .github/workflows/sudo.sh ./install_dependencies.sh "${{matrix.with_python}}" "${STATIC_ANALYSIS}" "${ENABLE_ROS_TESTS}"
- run: .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${{matrix.build_type}}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${{matrix.with_python}}" -DENABLE_ROS_TESTS=${ENABLE_ROS_TESTS}
- run: .github/workflows/build.sh -DCMAKE_BUILD_TYPE="${{matrix.build_type}}" -DSTATIC_ANALYSIS="${STATIC_ANALYSIS}" -DPYTHON_BINDINGS="${{matrix.with_python}}" -DENABLE_TESTS=ON -DENABLE_ROS_TESTS=${ENABLE_ROS_TESTS}
- run: .github/workflows/test.sh

# Memory and thread sanitiser are not tested due to known issues of both types inside Fast-DDS. May be added in the future when eProsima fixes the issues.
2 changes: 1 addition & 1 deletion .github/workflows/test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@

set -e

cd $(cd -P -- "$(dirname -- "$0")" && pwd -P)
cd "$(cd "$(dirname "$0")" && pwd -P)"

source ./python_venv.sh

Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/test_pip_package.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@

set -e

cd $(cd -P -- "$(dirname -- "$0")" && pwd -P)
cd "$(cd "$(dirname "$0")" && pwd -P)"

# Make (or re-make) and activate a test Python virtual environment
VENV=/tmp/provizio_dds_test_pip_package.venv
Expand Down
Loading

0 comments on commit 2984a82

Please sign in to comment.