Refactoring of CI configurations and build scripts

Now, CI builds for macOS involve three separate builds for a range of macOS versions, and a final Universal macOS Binary made on Big Sur. It should work with the M1 chip and x86_64 Intel Macs.

I have also renamed osx_environment->macOS_environment.sh to reflect the new name change of Apple's desktop OS.

In terms of the clean_builds.sh script, this has also been refactored to be more resilient, and efficient (marginally).

Signed-off-by: Dom Rodriguez <shymega@shymega.org.uk>
This commit is contained in:
Dom Rodriguez 2021-11-04 21:48:48 +00:00
parent 4ed0141389
commit f5c759a910
No known key found for this signature in database
GPG Key ID: 72DCF1231E54BD43
4 changed files with 143 additions and 29 deletions

View File

@ -79,22 +79,22 @@ jobs:
- script: sh -x ./clean_build.sh - script: sh -x ./clean_build.sh
displayName: Clean Build displayName: Clean Build
- job: MacBuild - job: macOStests
displayName: Mac Build displayName: macOS Tests
strategy: strategy:
matrix: matrix:
big-sur-Release: big-sur:
imageName: "macOS-11" imageName: "macOS-11"
B_BUILD_TYPE: Release B_BUILD_TYPE: Debug
BARRIER_VERSION_STAGE: Release BARRIER_VERSION_STAGE: Debug
catalina-Release: catalina-Release:
imageName: "macOS-10.15" imageName: "macOS-10.15"
B_BUILD_TYPE: Release B_BUILD_TYPE: Debug
BARRIER_VERSION_STAGE: Release BARRIER_VERSION_STAGE: Debug
mojave-Release: mojave-Release:
imageName: "macOS-10.14" imageName: "macOS-10.14"
B_BUILD_TYPE: Release B_BUILD_TYPE: Debug
BARRIER_VERSION_STAGE: Release BARRIER_VERSION_STAGE: Debug
pool: pool:
vmImage: $(imageName) vmImage: $(imageName)
variables: variables:
@ -109,9 +109,28 @@ jobs:
displayName: Install Qt5 and pkg-config prereqs displayName: Install Qt5 and pkg-config prereqs
- script: sh -x ./clean_build.sh - script: sh -x ./clean_build.sh
displayName: Clean Build displayName: Clean Build
- job: macOSRelease
displayName: macOS Universal Binary Release Builds
pool:
vmImage: "macOS-11"
variables:
VERBOSE: 1
TERM: xterm-256color
B_BUILD_TYPE: Release
BARRIER_VERSION_STAGE: Release
steps:
- script: rm -rf /usr/local/opt/openssl
displayName: Remove incompatible OpenSSL 1.0.2t from macOS-10.14 vmImage
- script: brew reinstall openssl
displayName: Installed newer OpenSSL 1.1.x
- script: brew install pkg-config qt5
displayName: Install Qt5 and pkg-config prereqs
- script: sh -x ./clean_build.sh
displayName: Clean Build
- task: PublishBuildArtifacts@1 - task: PublishBuildArtifacts@1
displayName: Publish Release DMG displayName: Publish Release DMG
condition: eq(variables['B_BUILD_TYPE'], 'Release') condition: eq(variables['B_BUILD_TYPE'], 'Release')
inputs: inputs:
pathtoPublish: build/bundle pathtoPublish: build/bundle
artifactName: Mac Release Disk Image and App $(imageName) artifactName: Universal Binary for macOS

View File

@ -1,32 +1,77 @@
#!/bin/sh #!/bin/sh
cd "$(dirname "$0")" || exit 1 cd "$(dirname "$0")" || exit 1
# some environments have cmake v2 as 'cmake' and v3 as 'cmake3' # some environments have cmake v2 as 'cmake' and v3 as 'cmake3'
# check for cmake3 first then fallback to just cmake # check for cmake3 first then fallback to just cmake
B_CMAKE=`type cmake3 2>/dev/null`
if [ $? -eq 0 ]; then B_CMAKE=$(command -v cmake3 2>/dev/null)
B_CMAKE=`echo "$B_CMAKE" | cut -d' ' -f3` if [ "$?" -eq 0 ]; then
# Continue, cmake3 exists in $PATH.
continue
else else
B_CMAKE=cmake # OK, so cmake3 isn't in path, so let's test to see if `cmake` itself exists, before proceeding.
if command -v cmake 2>/dev/null; then
B_CMAKE=$(command -v cmake)
# We have a cmake executable available, now let's proceed!
else
# As self-explanatory, the cmake executable isn't available, so we should fail here.
echo "ERROR: CMake not in $PATH, cannot build! Please install CMake, or if this persists, file a bug report."
exit 1
fi fi
# default build configuration fi
# Set default build type, but in CI, this is set to Release.
# For downstream distributions, our recommendation is to set this type in your build scripts to Release, and supply Debug build types in your debug packages.
B_BUILD_TYPE=${B_BUILD_TYPE:-Debug} B_BUILD_TYPE=${B_BUILD_TYPE:-Debug}
if [ "$(uname)" = "Darwin" ]; then if [ "$(uname)" = "Darwin" ]; then
# OSX needs a lot of extra help, poor thing # macOS needs a little help, so we source this environment script to fix paths.
# run the osx_environment.sh script to fix paths if [ ! -e "./macOS_environment.sh" ]; then
. ./osx_environment.sh echo "macOS environment script not found, this isn't meant to happen!"
B_CMAKE_FLAGS="-DCMAKE_OSX_SYSROOT=$(xcode-select --print-path)/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk -DCMAKE_OSX_DEPLOYMENT_TARGET=10.9 $B_CMAKE_FLAGS" exit 1
else
. ./macOS_environment.sh
fi
# We build a Universal macOS Binary, which supports M1 and Intel processors (64-bit)
CMAKE_OSX_ARCHITECTURES="arm64;x86_64"
B_CMAKE_FLAGS="-DCMAKE_OSX_SYSROOT=$(xcode-select --print-path)/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk -DCMAKE_OSX_DEPLOYMENT_TARGET=10.9 ${B_CMAKE_FLAGS:-}"
fi
# Source local build variables to the environment, if available.
# If not, continue as normal, and silently.
if [ -e "./build_env.sh" ]; then
. "./build_env.sh"
fi fi
# allow local customizations to build environment
[ -r ./build_env.sh ] && . ./build_env.sh
# Initialise Git submodules # Initialise Git submodules
git submodule update --init --recursive git submodule update --init --recursive
B_CMAKE_FLAGS="-DCMAKE_BUILD_TYPE=$B_BUILD_TYPE $B_CMAKE_FLAGS" B_CMAKE_FLAGS="-DCMAKE_BUILD_TYPE=${B_BUILD_TYPE} ${B_CMAKE_FLAGS:-}"
rm -rf build
mkdir build || exit 1 # Clear build directory, but do a conditional first!
cd build || exit 1
echo "Starting Barrier $B_BUILD_TYPE build..." if [ -d "./build" ]; then
$B_CMAKE $B_CMAKE_FLAGS .. || exit 1 rm -rf ./build
make || exit 1 fi
echo "Build completed successfully"
# Previous versions of this script created the build directory, and CD'd into it - CMake allows us to do this another way...
# Note: If you use Ninja (i.e, cmake -GNinja -B build), run Ninja like: "ninja -C build", just like you would with Meson.
$B_CMAKE "$B_CMAKE_FLAGS" -B build || exit 1
echo "INFO: Now commencing Barrier build process..."
echo "INFO: We're building an $B_BUILD_TYPE output type."
$(command -v make) -C build || exit 1
# Implictly, we assume the build was successful due to no exits.
# Later revisions of this script should do conditionals. TODO.
echo "INFO: Success! The build completed successfully!"
exit

View File

@ -0,0 +1 @@
Refactor CI builds, and build scripts to be more resilient, and effective

49
macOS_environment.sh Normal file
View File

@ -0,0 +1,49 @@
#!/bin/bash
# Checks if directory exists, otherwise asks to install package.
check_dir_exists() {
local path=$1
local package=$2
if [ ! -d "$path" ]; then
echo "Please install $package"
exit 1
fi
}
if [ -z "$BARRIER_BUILD_ENV" ]; then
check_dir_exists '/Applications/Xcode.app' 'Xcode'
printf "Modifying environment for Barrier build...\n"
if command -v port; then
printf "Detected Macports\n"
check_dir_exists '/opt/local/lib/cmake/Qt5' 'qt5-qtbase port'
export BARRIER_BUILD_MACPORTS=1
export CMAKE_PREFIX_PATH="/opt/local/lib/cmake/Qt5:$CMAKE_PREFIX_PATH"
export LD_LIBRARY_PATH="/opt/local/lib:$LD_LIBRARY_PATH"
export CPATH="/opt/local/include:$CPATH"
export PKG_CONFIG_PATH="/opt/local/libexec/qt5/lib/pkgconfig:$PKG_CONFIG_PATH"
elif command -v brew; then
printf "Detected Homebrew\n"
QT_PATH=$(brew --prefix qt@5)
check_dir_exists "$QT_PATH" 'qt5'
export BARRIER_BUILD_BREW=1
export CMAKE_PREFIX_PATH="/opt/procursus:$QT_PATH:$CMAKE_PREFIX_PATH"
export LD_LIBRARY_PATH="/opt/procursus/lib:$LD_LIBRARY_PATH"
export CPATH="/opt/procursus/include:$CPATH"
export PKG_CONFIG_PATH="/opt/procursus/lib/pkgconfig:$PKG_CONFIG_PATH"
else
printf "Neither Homebrew nor Macports is installed. Can't get dependency paths\n"
exit 1
fi
export BARRIER_BUILD_ENV=1
printf "done\n"
fi