Prevent time catch up in real time mode (#1213) #1432
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: C/C++ build | |
on: | |
push: | |
branches-ignore: | |
- 'dependabot/**' | |
pull_request: | |
env: | |
release: ${{ github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/')) }} | |
jobs: | |
XML-validation: | |
if: ${{ !startsWith(github.event.head_commit.message, '[skip ci]') || github.event_name == 'pull_request' }} | |
name: XML validation | |
runs-on: ubuntu-latest | |
steps: | |
- name: Install Ubuntu packages | |
run: | | |
sudo apt-get update | |
sudo apt-get install libxml2-utils | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Validate scripts files | |
run: | | |
for filename in scripts/*.xml; do | |
[ -e "$filename" ] || continue | |
[ "$filename" != "scripts/kml_output.xml" ] || continue | |
[ "$filename" != "scripts/plotfile.xml" ] || continue | |
[ "$filename" != "scripts/unitconversions.xml" ] || continue | |
xmllint --noout --schema JSBSimScript.xsd $filename | |
done | |
- name: Validate systems files | |
run: | | |
for filename in systems/*.xml; do | |
[ -e "$filename" ] || continue | |
xmllint --noout --schema JSBSimSystem.xsd $filename | |
done | |
MSIS-validation: | |
name: MSIS code validation | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest, macos-latest] | |
runs-on: ${{matrix.os}} | |
steps: | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Configure the MSIS test program | |
run: | | |
mkdir build && cd build | |
cmake ../src/models/atmosphere/MSIS | |
- name: Build the JSBSim test program | |
working-directory: build | |
run: make --jobs=3 | |
- name: Run the NRLMSIS-00 C package | |
working-directory: src/models/atmosphere/MSIS | |
run: | | |
if [[ $(head -261 DOCUMENTATION | tail -104 | diff -urN <(../../../../build/nrlmsise-test) - | wc -c) -ne 0 ]]; then | |
echo "Failed." | |
exit 1 | |
fi | |
Linux: | |
name: C/C++ build (Linux) | |
needs: [XML-validation, MSIS-validation] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-22.04] | |
expat: [ON, OFF] | |
shared_libs: [ON, OFF] | |
build_julia: [OFF] | |
display_stack_trace: [ON] | |
include: | |
- os: ubuntu-20.04 | |
expat: OFF | |
shared_libs: OFF | |
build_julia: ON | |
display_stack_trace: OFF | |
env: | |
static_link: ${{ matrix.expat == 'OFF' && matrix.shared_libs == 'OFF' }} | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Install Ubuntu packages | |
run: | | |
sudo apt-get update | |
sudo apt-get install cxxtest valgrind binutils-dev | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Cache Python packages & CTest cost data | |
# CTestCostData.txt is used by CTest to optimize the distribution of the | |
# tests between the CPU cores and reduce execution time. | |
uses: actions/cache@v4 | |
with: | |
path: | | |
~/.cache/pip | |
build/Testing/Temporary/CTestCostData.txt | |
key: ${{ runner.os }}-3.8-${{ hashFiles('tests/CMakeLists.txt', 'python/requirements.txt') }} | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.8' | |
- name: Install Python packages | |
run: | | |
pip install -r python/requirements.txt | |
pip install valgrindci | |
- name: Configure Julia | |
if: matrix.build_julia == 'ON' | |
run: | | |
julia -e "import Pkg;Pkg.add(\"CxxWrap\")" | |
export CXXWRAP_PREFIX_PATH=`julia -e "using CxxWrap;print(CxxWrap.prefix_path())"` | |
echo "JSBSIM_PREFIX_PATH=$CXXWRAP_PREFIX_PATH" >> $GITHUB_ENV | |
- name: Checkout Backward-cpp | |
if: matrix.display_stack_trace == 'ON' | |
id: BackwardCppCheckout | |
uses: actions/checkout@v4 | |
with: | |
repository: bombela/backward-cpp | |
ref: 'v1.6' | |
path: backward-cpp | |
- name: Configure Backward-cpp | |
if: steps.BackwardCppCheckout.outcome == 'success' | |
run: echo "JSBSIM_PREFIX_PATH=$PWD/backward-cpp" >> $GITHUB_ENV | |
- name: Configure JSBSim | |
run: | | |
mkdir -p build && cd build | |
cmake -DCPACK_GENERATOR=DEB -DINSTALL_JSBSIM_PYTHON_MODULE=ON -DCMAKE_C_FLAGS_DEBUG="-g -O2" -DCMAKE_CXX_FLAGS_DEBUG="-g -O2" -DCMAKE_BUILD_TYPE=Debug -DSYSTEM_EXPAT=${{matrix.expat}} -DBUILD_SHARED_LIBS=${{matrix.shared_libs}} -DBUILD_JULIA_PACKAGE=${{matrix.build_julia}} -DFPECTL_DISPLAY_STACK_TRACE=${{matrix.display_stack_trace}} -DCMAKE_PREFIX_PATH=$JSBSIM_PREFIX_PATH -DCMAKE_INSTALL_PREFIX=/usr .. | |
- name: Build JSBSim | |
working-directory: build | |
run: make --jobs=$(nproc) | |
- name: Test with Valgrind | |
run: | | |
valgrind --tool=memcheck --leak-check=full --leak-resolution=high --track-origins=yes --xml=yes --xml-file=valgrind_Short_S23_3.xml build/src/JSBSim scripts/Short_S23_3.xml --end-time=5. | |
valgrind-ci valgrind_Short_S23_3.xml --abort-on-errors | |
- name: Test the Display of the Stack Trace when an FPE is raised | |
if: steps.BackwardCppCheckout.outcome == 'success' | |
working-directory: build | |
run: LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PWD/src ctest -R fpectl -V | |
- name: Test JSBSim | |
working-directory: build | |
run: LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PWD/src ctest --parallel $(nproc) --output-on-failure | |
- name: Build Ubuntu packages | |
if: env.static_link == 'true' | |
working-directory: build | |
run: cpack | |
# On failure, upload logs | |
- name: On failure - Upload logs | |
uses: actions/upload-artifact@v4 | |
if: failure() | |
with: | |
name: Linux-${{ matrix.os }}-system_expat_${{ matrix.expat }}-shared_libs_${{ matrix.shared_libs }}.logs | |
path: | | |
build/Testing/Temporary/*.log | |
build/tests/*-build.log | |
valgrind_Short_S23_3.xml | |
- name: On failure - Display a summary of valgrind errors. | |
if: failure() | |
run: valgrind-ci valgrind_Short_S23_3.xml --number-of-errors --summary --source=. | |
- name: Upload Files for Release | |
uses: actions/upload-artifact@v4 | |
if: env.release == 'true' && env.static_link == 'true' | |
with: | |
name: Linux-${{ matrix.os }}.binaries | |
path: build/*.deb | |
Matlab-SFunction: | |
name: Matlab S-Function | |
needs: [ Linux, MacOSX, Windows-MSVC ] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ macos-13, ubuntu-22.04, windows-latest ] | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Set up Matlab | |
uses: matlab-actions/setup-matlab@v2 | |
with: | |
release: R2022a | |
products: Simulink | |
- name: Configure JSBSim | |
run: | | |
mkdir build | |
cd build | |
cmake -DBUILD_MATLAB_SFUNCTION=ON .. | |
- name: Build JSBSim S-Function | |
working-directory: build | |
run: cmake --build . --config RelWithDebInfo --target JSBSim_SFunction --parallel 3 | |
- name: Prepare Tests | |
working-directory: matlab | |
# The script will be run from the directory 'matlab' so we need to copy | |
# the folders that will be used by JSBSim | |
run: | | |
cp -R ../aircraft . | |
cp -R ../engine . | |
cp -R ../systems . | |
cp -R ../scripts . | |
- name: Force Matlab using the system libstdc++ rather than its own (Linux) | |
# See https://stackoverflow.com/questions/37921139/error-version-glibcxx-3-4-21-not-found | |
if: runner.os == 'Linux' | |
run: echo "LD_PRELOAD=/lib/x86_64-linux-gnu/libstdc++.so.6" >> $GITHUB_ENV | |
- name: Run Tests (Linux & MacOSX) | |
if: runner.os != 'Windows' | |
id: tests-unix | |
uses: matlab-actions/run-command@v2 | |
with: | |
command: addpath('build/matlab'), run('matlab/TestJSBSim.m') | |
- name: Run Tests (Windows) | |
if: runner.os == 'Windows' | |
id: tests-windows | |
uses: matlab-actions/run-command@v2 | |
with: | |
command: addpath('build/matlab/RelWithDebInfo'), run('matlab/TestJSBSim.m') | |
- name: Upload Files for Release (Linux & MacOSX) | |
if: steps.tests-unix.outcome == 'success' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Matlab-SFunction-${{ runner.os }}.binaries | |
path: build/matlab/JSBSim_SFunction.mex* | |
- name: Upload Files for Release (Windows) | |
if: steps.tests-windows.outcome == 'success' | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Matlab-SFunction-${{ runner.os }}.binaries | |
path: | | |
build/JSBSim.iss | |
build/matlab/JSBSimSimulinkCompile.m | |
build/matlab/RelWithDebInfo/JSBSim_SFunction.mex* | |
Windows-MinGW: | |
name: C/C++ build (MinGW) | |
needs: XML-validation | |
runs-on: windows-2019 | |
strategy: | |
fail-fast: false | |
matrix: | |
shared_libs: [ON, OFF] | |
steps: | |
- name: Set up Python 3.10 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.10' | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Checkout CxxTest | |
uses: actions/checkout@v4 | |
with: | |
repository: CxxTest/cxxtest | |
ref: '4.4' | |
path: cxxtest | |
- name : Configure CxxTest | |
working-directory: cxxtest | |
run: | | |
cp python/python3/cxxtest/*.py cxxtest/. | |
cp python/python3/scripts/cxxtestgen . | |
- name: Configure JSBSim | |
run: | | |
mkdir build && cd build | |
julia -e 'import Pkg;Pkg.add(\"CxxWrap\")' | |
$CXXWRAP_PREFIX_PATH=julia -e 'using CxxWrap;print(CxxWrap.prefix_path())' | |
cmake -G "MinGW Makefiles" -DBUILD_SHARED_LIBS=${{matrix.shared_libs}} -DBUILD_JULIA_PACKAGE=ON -DCMAKE_INCLUDE_PATH="$(get-location)\..\cxxtest" -DBUILD_PYTHON_MODULE=OFF -DBUILD_DOCS=OFF -DCMAKE_PREFIX_PATH="$CXXWRAP_PREFIX_PATH" .. | |
- name: Build JSBSim | |
working-directory: build | |
run: mingw32-make --jobs=$Env:NUMBER_OF_PROCESSORS | |
- name: Test executable | |
run: build/src/JSBSim.exe scripts/c1721.xml | |
- name: Run JSBSim tests | |
working-directory: build | |
run: | | |
cp src/libJSBSim.* julia/. | |
ctest --parallel $Env:NUMBER_OF_PROCESSORS --output-on-failure | |
# Upload files | |
- name: On failure - Upload logs | |
uses: actions/upload-artifact@v4 | |
if: failure() | |
with: | |
name: Windows_MinGW.logs | |
path: build/Testing/Temporary | |
Windows-MSVC: | |
name: C/C++ build (MSVC) | |
needs: XML-validation | |
runs-on: windows-2019 | |
strategy: | |
fail-fast: false | |
matrix: | |
shared_libs: [ON, OFF] | |
steps: | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Cache Python packages & CTest cost data | |
# CTestCostData.txt is used by CTest to optimize the distribution of the | |
# tests between the CPU cores and reduce execution time. | |
uses: actions/cache@v4 | |
with: | |
path: | | |
~\AppData\Local\pip\Cache | |
build\Testing\Temporary\CTestCostData.txt | |
key: ${{ runner.os }}-3.8-${{ hashFiles('tests\CMakeLists.txt', 'python\requirements.txt') }} | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.8' | |
- name: Install Python packages | |
run: pip install -r python/requirements.txt | |
- name: Checkout CxxTest | |
uses: actions/checkout@v4 | |
with: | |
repository: CxxTest/cxxtest | |
ref: '4.4' | |
path: cxxtest | |
- name : Configure CxxTest | |
working-directory: cxxtest | |
run: | | |
cp python/python3/cxxtest/*.py cxxtest/. | |
cp python/python3/scripts/cxxtestgen . | |
- name: Checkout Backward-cpp | |
uses: actions/checkout@v4 | |
with: | |
repository: bombela/backward-cpp | |
ref: 'v1.6' | |
path: backward-cpp | |
- name: MSVC version | |
run: | | |
$MSVC_name = vswhere -property displayName | |
$MSVC_build = vswhere -property catalog_buildVersion | |
Out-File -InputObject $MSVC_name" (build "$MSVC_build")" -NoNewLine MSVC_version.txt | |
- name: Configure JSBSim | |
run: | | |
New-Item -Path .\build -ItemType Directory -Force | |
cd build | |
cmake -DCMAKE_INCLUDE_PATH="$(get-location)\..\cxxtest" -DCMAKE_PREFIX_PATH="$(get-location)\..\backward-cpp" -DBUILD_SHARED_LIBS=${{matrix.shared_libs}} -DFPECTL_DISPLAY_STACK_TRACE=ON -DSTACK_DETAILS_AUTO_DETECT=FALSE .. | |
- name: Build JSBSim | |
working-directory: build | |
run: cmake --build . --config RelWithDebInfo --parallel $Env:NUMBER_OF_PROCESSORS | |
- name: Test the Display of the Stack Trace when an FPE is raised | |
working-directory: build | |
run: ctest -R fpectl --build-config RelWithDebInfo -V | |
- name: Test JSBSim | |
working-directory: build | |
run: ctest --parallel $Env:NUMBER_OF_PROCESSORS --build-config RelWithDebInfo --output-on-failure | |
# On failure, upload logs | |
- name: On failure - Upload logs | |
uses: actions/upload-artifact@v4 | |
if: failure() | |
with: | |
name: Windows_MSVC.logs | |
path: | | |
build/Testing/Temporary/*.log | |
build/tests/*-build.log | |
- name: Upload Files for Release | |
uses: actions/upload-artifact@v4 | |
if: env.release == 'true' && matrix.shared_libs == 'OFF' | |
with: | |
name: ${{ runner.os }}.binaries | |
path: | | |
build/src/RelWithDebInfo/JSBSim.lib | |
build/src/RelWithDebInfo/JSBSim.exe | |
build/utils/aeromatic++/RelWithDebInfo/aeromatic.exe | |
build/python/setup.py | |
MSVC_version.txt | |
Windows-installer: | |
if: github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/')) | |
name: Build Windows installer | |
needs: Matlab-SFunction | |
runs-on: windows-2019 | |
steps: | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Checkout JSBSim logos | |
uses: actions/checkout@v4 | |
with: | |
repository: JSBSim-Team/jsbsim-logo | |
path: jsbsim-logo | |
- name: Download binary file for JSBSim.iss | |
uses: actions/download-artifact@v4 | |
with: | |
name: Matlab-SFunction-Windows.binaries | |
path: build | |
- name: Download JSBSim library and executable | |
uses: actions/download-artifact@v4 | |
with: | |
name: Windows.binaries | |
- name: Update the version of JSBSim in matlab/README.md | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | |
run: | | |
$JSBSim_version = ((.\build\src\RelWithDebInfo\JSBSim.exe --version) -split '\s+')[4] | |
$prev_version = ((Get-Content README.md | Select-String -Pattern 'JSBSim-([0-9]+\.)+[0-9]+-setup.exe') -split '-')[1] | |
(Get-Content -Path matlab\README.md) -Replace "$prev_version", "$JSBSim_version" | Set-Content -Path matlab\README.md | |
- name: Build JSBSim installer for Windows | |
working-directory: build | |
run: | | |
# Relocate the logos for the wizard installer | |
mkdir logos | |
cp ..\jsbsim-logo\wizard_installer\*.bmp logos\. | |
mkdir small | |
cp ..\jsbsim-logo\wizard_installer\small\*.bmp small\. | |
# Update the version of MSVC in matlab/README.md | |
$MSVC_version = Get-Content -Path ..\MSVC_version.txt | |
(Get-Content -Path ..\matlab\README.md) -Replace 'Visual Studio\s[A-Za-z0-9 ]+\s\(build\s[0-9.]+\)', "$MSVC_Version" | Set-Content -Path ..\matlab\README.md | |
# Relocate the executables for the installer | |
cp src\RelWithDebInfo\JSBSim.exe src\. | |
cp src\RelWithDebInfo\JSBSim.lib src\. | |
cp utils\aeromatic++\RelWithDebInfo\aeromatic.exe utils\aeromatic++\. | |
# Get the MSVC C++ DLL | |
$Paths = $Env:PATH+';'+[System.Environment]::SystemDirectory | |
foreach($path in $Paths -split ';') { | |
if (Test-Path $path) { | |
$File = Get-ChildItem -Path $path | Where-Object {$_.Name -eq 'msvcp140.dll'} | |
if ($File) { | |
cp $File.FullName . | |
break; | |
} | |
} | |
} | |
# Compile the installer with Inno Setup | |
iscc JSBSim.iss | |
- name: Upload the installer for Release | |
uses: actions/upload-artifact@v4 | |
with: | |
name: Windows-installer.binaries | |
path: | | |
build\Output\*.exe | |
MacOSX: | |
name: C/C++ build (MacOSX) | |
needs: [XML-validation, MSIS-validation] | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [macos-13] | |
python-version: [3.8] | |
include: | |
- os: macos-14 | |
python-version: '3.10' | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Cache Python packages & CTest cost data | |
# CTestCostData.txt is used by CTest to optimize the distribution of the | |
# tests between the CPU cores and reduce execution time. | |
uses: actions/cache@v4 | |
with: | |
path: | | |
~/Library/Caches/pip | |
build/Testing/Temporary/CTestCostData.txt | |
key: ${{ matrix.os }}-${{ matrix.python-version }}-${{ hashFiles('tests/CMakeLists.txt', 'python/requirements.txt') }} | |
- name: Set up Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install Python packages | |
run: | | |
pip install -r python/requirements.txt | |
pip install build mypy | |
- name: Set up Julia | |
uses: julia-actions/setup-julia@v2 | |
- name: Install & Configure Doxygen | |
if: env.release == 'true' && matrix.os == 'macos-13' | |
run: | | |
brew install doxygen | |
# We don't want Doxygen to generate the HTML docs in this job (saves time) | |
# Set GENERATE_HTML and HAVE_DOT to NO | |
perl -i -pe 's/^(GENERATE_HTML\s*=\s*)YES/\1NO/g' doc/JSBSim.dox.in | |
perl -i -pe 's/^(HAVE_DOT\s*=\s*)YES/\1NO/g' doc/JSBSim.dox.in | |
- name: Checkout CxxTest | |
uses: actions/checkout@v4 | |
with: | |
repository: CxxTest/cxxtest | |
ref: '4.4' | |
path: cxxtest | |
- name: Configure CxxTest | |
working-directory: cxxtest/python | |
run: python setup.py install | |
- name: Configure JSBSim | |
run: | | |
mkdir -p build && cd build | |
julia -e "import Pkg;Pkg.add(\"CxxWrap\")" | |
export CXXWRAP_PREFIX_PATH=`julia -e "using CxxWrap;print(CxxWrap.prefix_path())"` | |
cmake -DCMAKE_INCLUDE_PATH=$PWD/../cxxtest -DBUILD_JULIA_PACKAGE=ON -DCYTHON_FLAGS="-X embedsignature=True" -DCMAKE_PREFIX_PATH=$CXXWRAP_PREFIX_PATH -DCMAKE_C_FLAGS_DEBUG="-g -O2 -fno-fast-math" -DCMAKE_CXX_FLAGS_DEBUG="-g -O2 -fno-fast-math" -DCMAKE_BUILD_TYPE=Debug .. | |
- name: Build JSBSim | |
working-directory: build | |
run: make --jobs=$(sysctl -n hw.logicalcpu) | |
- name: Test JSBSim | |
working-directory: build | |
run: ctest --parallel $(sysctl -n hw.logicalcpu) --output-on-failure | |
- name: Build the source package for Python | |
if: env.release == 'true' && matrix.os == 'macos-13' | |
working-directory: build/tests | |
run: | | |
echo "::group::Build the type hints stubs" | |
stubgen -p jsbsim -o ../python | |
echo "::endgroup::" | |
echo "::group::Build the source package" | |
cd ../python | |
touch jsbsim/py.typed | |
rm -f _jsbsim.cxx # Make sure that jsbsim.cxx is not stored in the source distribution | |
python -m build --sdist | |
echo "::endgroup::" | |
- name: Check reset for real time execution | |
if: matrix.os == 'macos-14' | |
run: | | |
start_time=$(date +%s) | |
./build/src/JSBSim scripts/c172_cruise_8K.xml --realtime --nice | |
end_time=$(date +%s) | |
elapsed_time=$((end_time - start_time)) | |
if [ $elapsed_time -lt 90 ]; then | |
echo "Failed - Program finished in less than 90 seconds" | |
exit 1 | |
fi | |
# On failure, upload logs | |
- name: On failure - Upload logs | |
uses: actions/upload-artifact@v4 | |
if: failure() | |
with: | |
name: MacOSX.logs | |
path: | | |
build/Testing/Temporary/*.log | |
build/tests/*-build.log | |
- name: Upload Files for Release | |
uses: actions/upload-artifact@v4 | |
if: env.release == 'true' && matrix.os == 'macos-13' | |
with: | |
name: ${{ runner.os }}.binaries | |
path: | | |
build/src/libJSBSim.a | |
build/python/setup.py | |
build/python/dist/*.tar.gz | |
Test-Build-PyPackage-From-Source: | |
if: github.event_name == 'push' && (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/tags/')) | |
name: Build Python Module from Source | |
needs: MacOSX | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest, macos-latest, windows-latest] | |
python-version: [3.8] | |
include: | |
- python-version: 3.9 | |
os: windows-latest | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Set up Python | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install Python packages | |
run: pip install -U cython 'numpy>=1.20' mypy | |
- name: Download source package | |
uses: actions/download-artifact@v4 | |
with: | |
name: macOS.binaries | |
- name: Build Python module from sources (Linux & MacOSX) | |
if: runner.os != 'Windows' | |
run: pip install python/dist/*.tar.gz -vv | |
- name: Build Python module from sources (Windows) | |
if: runner.os == 'Windows' | |
run: | | |
$PyPackage = Get-ChildItem -Path python\dist -Filter *.tar.gz | Select-Object -First 1 | |
pip install $PyPackage.FullName -vv | |
- name: Test Python module | |
shell: python | |
run: | | |
import jsbsim | |
print(jsbsim.FGAircraft.__doc__) | |
fdm=jsbsim.FGFDMExec(None) | |
fdm.load_script('scripts/Short_S23_1.xml') | |
fdm.run_ic() | |
while fdm.get_sim_time() < 10: | |
fdm.run() | |
- name: Test type hints | |
run: | | |
echo "import jsbsim" > test.py | |
mypy test.py | |
Python-Wheels: | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | |
name: Build Python wheels | |
needs: [Linux, Windows-MSVC, MacOSX] | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest, macos-13, windows-2019] | |
steps: | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.8' | |
- name: Install Python packages | |
run: pip install -U cython 'numpy>=1.20' mypy | |
- name: Install Doxygen (Linux) | |
if: matrix.os == 'ubuntu-latest' | |
run: | | |
sudo apt-get update | |
sudo apt-get install doxygen | |
- name: Install Doxygen (MacOSX) | |
if: matrix.os == 'macos-13' | |
run: brew install doxygen | |
- name: Install Doxygen (Windows) | |
if: runner.os == 'Windows' | |
run: choco install doxygen.install | |
- name: Configure Doxygen | |
run: | | |
# We don't want Doxygen to generate the HTML docs in this job (saves time) | |
# Set GENERATE_HTML and HAVE_DOT to NO | |
perl -i -pe 's/^(GENERATE_HTML\s*=\s*)YES/\1NO/g' doc/JSBSim.dox.in | |
perl -i -pe 's/^(HAVE_DOT\s*=\s*)YES/\1NO/g' doc/JSBSim.dox.in | |
- name: Download source package | |
uses: actions/download-artifact@v4 | |
with: | |
name: macOS.binaries | |
- name: Configure JSBSim (BSD/Unix) | |
if: runner.os != 'Windows' | |
run: | | |
echo "::group::Run CMake" | |
mkdir build && cd build | |
cmake .. | |
echo "::endgroup::" | |
echo "::group::Get Python package sources" | |
touch python/jsbsim/py.typed | |
cd ../python/dist | |
tar zxvf *.tar.gz | |
cp -R jsbsim-*/jsbsim/*.pyi ../../build/python/jsbsim/. | |
echo "::endgroup::" | |
- name: Configure JSBSim (Windows) | |
if: runner.os == 'Windows' | |
run: | | |
echo "::group::Run CMake" | |
New-Item -Path .\build -ItemType Directory -Force | |
cd build | |
cmake .. | |
cmake --build . --target libJSBSim --config RelWithDebInfo --parallel $Env:NUMBER_OF_PROCESSORS | |
echo "::endgroup::" | |
echo "::group::Get Python package sources" | |
New-Item python\jsbsim\py.typed | |
cd ..\python\dist | |
$PyPackage = Get-ChildItem .\*.tar.gz -Name | |
tar zxvf $PyPackage | |
Copy-Item -Path .\JSBSim-*\jsbsim\*.pyi -Destination ..\..\build\python\jsbsim | |
echo "::endgroup::" | |
- name: Build wheels | |
uses: pypa/cibuildwheel@v2.19 | |
env: | |
CIBW_BEFORE_ALL_LINUX: | | |
cd build | |
rm -f CMakeCache.txt | |
cmake -DCMAKE_C_FLAGS_RELEASE="-g -O2 -DNDEBUG -fno-math-errno" -DCMAKE_CXX_FLAGS_RELEASE="-g -O2 -DNDEBUG -fno-math-errno" -DCMAKE_BUILD_TYPE=Release .. | |
cmake --build . --target libJSBSim --parallel $(nproc) | |
CIBW_BEFORE_ALL_MACOS: | | |
cd build | |
rm -f CMakeCache.txt | |
cmake -DCMAKE_OSX_ARCHITECTURES="arm64;x86_64" -DCMAKE_C_FLAGS_RELEASE="-g -O2 -DNDEBUG -fno-math-errno -fno-fast-math" -DCMAKE_CXX_FLAGS_RELEASE="-g -O2 -DNDEBUG -fno-math-errno -fno-fast-math" -DCMAKE_BUILD_TYPE=Release .. | |
cmake --build . --target libJSBSim --parallel $(sysctl -n hw.logicalcpu) | |
CIBW_ARCHS_MACOS: universal2 | |
CIBW_SKIP: cp*-musllinux_* | |
CIBW_ARCHS_WINDOWS: native | |
JSBSIM_BUILD_CONFIG: RelWithDebInfo | |
with: | |
package-dir: build/python | |
- name: Test wheel package | |
run: | | |
echo "::group::Test module execution" | |
pip install jsbsim --no-index -f wheelhouse | |
python -c "import jsbsim;print(jsbsim.FGAircraft.__doc__);fdm=jsbsim.FGFDMExec(None);fdm.load_script('scripts/Short_S23_1.xml');fdm.run_ic()" | |
echo "::endgroup::" | |
echo "::group::Test type hints" | |
echo "import jsbsim" > test.py | |
mypy test.py | |
echo "::endgroup::" | |
- name: Test default root package detection (global & --user) | |
run: | | |
# Test global installation | |
python -c "import jsbsim;print(jsbsim.get_default_root_dir())" | |
pip uninstall jsbsim -y | |
# Test --user installation | |
pip install --user jsbsim --no-index -f wheelhouse | |
python -c "import jsbsim;print(jsbsim.get_default_root_dir())" | |
pip uninstall jsbsim -y | |
- name: Test default root package detection (virtual env - Windows) | |
if: runner.os == 'Windows' | |
run: | | |
# Test virtual environment installation | |
python -m venv test_venv | |
test_venv\Scripts\activate.ps1 | |
pip install 'numpy>=1.20' | |
pip install jsbsim --no-index -f wheelhouse | |
python -c "import jsbsim;print(jsbsim.get_default_root_dir())" | |
pip uninstall jsbsim -y | |
deactivate | |
- name: Test default root package detection (virtual env - BSD/Unix) | |
if: runner.os != 'Windows' | |
run: | | |
# Test virtual environment installation | |
python -m venv test_venv | |
source test_venv/bin/activate | |
pip install 'numpy>=1.20' | |
pip install jsbsim --no-index -f wheelhouse | |
python -c "import jsbsim;print(jsbsim.get_default_root_dir())" | |
pip uninstall jsbsim -y | |
deactivate | |
- name: Upload Files for Release | |
uses: actions/upload-artifact@v4 | |
with: | |
name: ${{ matrix.os }}-Wheels.binaries | |
path: ./wheelhouse/*.whl | |
Codecov: | |
name: Code coverage | |
needs: Linux | |
if: ${{ !startsWith(github.ref, 'refs/tags/') }} | |
runs-on: ubuntu-latest | |
steps: | |
- name: Install Ubuntu packages | |
run: | | |
sudo apt-get update | |
sudo apt-get install cxxtest lcov | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Configure JSBSim | |
run: | | |
mkdir build && cd build | |
cmake -DENABLE_COVERAGE=ON -DBUILD_PYTHON_MODULE=OFF -DBUILD_DOCS=OFF .. | |
- name: Build JSBSim | |
working-directory: build | |
run: make --jobs=$(nproc) | |
- name: Run JSBSim tests | |
working-directory: build | |
run: ctest -R Test1 --output-on-failure | |
- name: Generate coverage report | |
working-directory: build | |
run: make lcov | |
- name: Upload to Codecov | |
uses: codecov/codecov-action@v5 | |
with: | |
files: ./build/lcov/data/capture/all_targets.info | |
token: ${{ secrets.CODECOV_TOKEN }} | |
disable_search: true | |
fail_ci_if_error: true | |
Rolling-Release: | |
needs: [Test-Build-PyPackage-From-Source, Windows-MinGW, Windows-installer] | |
name: Deploy Rolling Release | |
runs-on: ubuntu-latest | |
if: github.event_name == 'push' && github.ref == 'refs/heads/master' | |
steps: | |
- name: Download files | |
uses: actions/download-artifact@v4 | |
- name: Prepare files | |
run: | | |
mkdir dist | |
find . -type f -name *.exe -exec cp {} dist/. \; | |
find . -type f -name *.whl -exec cp {} dist/. \; | |
find . -type f -name *.deb -exec cp {} dist/. \; | |
- name: Rolling release | |
uses: softprops/action-gh-release@v2 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
name: Rolling release | |
tag_name: Linux | |
prerelease: true | |
body: | | |
Contains the packages built from the bleeding edge code | |
(branch ${{ github.ref }} commit ${{ github.sha}}) | |
files: | | |
dist/*.exe | |
dist/*.whl | |
dist/*.deb | |
Stable-Release: | |
name: Deploy Stable Release | |
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/') | |
needs: [Python-Wheels, Test-Build-PyPackage-From-Source, Windows-MinGW, Windows-installer] | |
runs-on: ubuntu-latest | |
environment: release | |
permissions: | |
contents: write # Needed for the GitHub release | |
id-token: write # Mandatory for PyPI trusted publishing | |
steps: | |
- name: Download files | |
uses: actions/download-artifact@v4 | |
- name: Prepare files for deployment | |
run: | | |
find . -type f -name MSVC_version.txt -exec cp {} . \; | |
mkdir dist | |
find . -type f -name *.whl -exec cp {} dist/. \; | |
find . -type f -name *.tar.gz -exec cp {} dist/. \; | |
mkdir GH_release | |
find . -type f -name *.exe -exec cp {} GH_release/. \; | |
find . -type f -name *.deb -exec cp {} GH_release/. \; | |
# PyPI deployment | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.8' | |
- name: PyPI deployment | |
uses: pypa/gh-action-pypi-publish@release/v1 | |
# Deploy stable release to GitHub | |
- name: Get JSBSim version | |
run: | | |
pip install -U 'numpy>=1.20' | |
pip install jsbsim --no-index -f dist | |
export VERSION=`pip show jsbsim | grep -i version | awk '{ print $2 }'` | |
echo "VERSION=$VERSION" >> $GITHUB_ENV | |
- name: Get MSVC version | |
run : | | |
export MSVC_VERSION=`cat MSVC_version.txt` | |
echo "MSVC_VERSION=$MSVC_VERSION" >> $GITHUB_ENV | |
- name: GitHub release | |
uses: softprops/action-gh-release@v2 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
name: v${{ env.VERSION }} | |
body: | | |
JSBSim version ${{ env.VERSION }} | |
## Release files | |
- Windows 64 bits | |
- `JSBSim-${{ env.VERSION }}-setup.exe` (Windows installer compiled with Microsoft ${{ env.MSVC_VERSION }}) | |
- Ubuntu Focal 20.04 and Jammy 22.04 - amd64 | |
- `*.deb` (Debian packages) | |
- Python wheel packages can be installed from [PyPI](https://pypi.org/project/JSBSim/) with the command `pip install jsbsim` or `pip install --upgrade jsbsim` when JSBSim is already installed on your system. | |
- Conda packages are available from [conda-forge](https://anaconda.org/conda-forge/jsbsim). To install this package with conda run: `conda install -c conda-forge jsbsim` | |
## Changelog | |
prerelease: false | |
draft: false | |
files: | | |
GH_release/*.exe | |
GH_release/*.deb | |
# Bump version | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 0 | |
- name: Bump version | |
run: | | |
# Increment the value of PROJECT_VERSION_PATCH | |
sed -ri 's/(set\(PROJECT_VERSION_PATCH\s\")([0-9]+)(.*)/echo "\1\\"$((\2+1))\\"\3"/ge' CMakeLists.txt | |
# Extract from CMake the project version number at the next release. | |
echo "message(STATUS \"JSBSIM_VERSION:\${PROJECT_VERSION}\")" >> src/CMakeLists.txt | |
export FUTURE_VERSION=`cmake . | grep JSBSIM_VERSION | awk -F':' '{print $2}'` | |
echo "FUTURE_VERSION=$FUTURE_VERSION" >> $GITHUB_ENV | |
# Extract the project old version number | |
export OLD_VERSION=`egrep 'JSBSim-([0-9]+\.)+[0-9]+-setup.exe' README.md | awk -F'JSBSim-' '{ print $2}' | awk -F'-setup.exe' '{ print $1}' | sed 's/\./\\\\./g'` | |
echo "OLD_VERSION=$OLD_VERSION" >> $GITHUB_ENV | |
# Update references to the current stable version in README.md | |
sed -ri 's/_'"$OLD_VERSION"'-[0-9]+.amd64.deb/_'"$VERSION"'-'"$GITHUB_RUN_NUMBER"'.amd64.deb/g' README.md | |
sed -ri 's/'"$OLD_VERSION"'/'"$VERSION"'/g' README.md | |
sed -ri 's/'"$OLD_VERSION"'/'"$VERSION"'/g' matlab/README.md | |
# Update the MSVC project files. | |
sed -ri 's/JSBSIM_VERSION=".*"/JSBSIM_VERSION="'$FUTURE_VERSION'"/g' JSBSim.vcxproj | |
sed -ri 's/JSBSIM_VERSION=".*"/JSBSIM_VERSION="'$FUTURE_VERSION'"/g' JSBSimForUnreal.vcxproj | |
# Update the MSVC version | |
sed -ri 's/Visual Studio\s[A-Za-z0-9 ]+\s\(build\s[0-9.]+\)/'"$MSVC_VERSION"'/g' matlab/README.md | |
# Determine the branch name | |
export BRANCH_NAME=`git branch -a --contains HEAD | awk -F'/' 'NR==2 { s=$3;for(i=4;i<=NF;i++){ s=s"/"$i };print s }'` | |
# Commit the change to CMakeLists.txt | |
git config --global user.name "github-actions[bot]" | |
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com" | |
git checkout $BRANCH_NAME | |
git commit -m "Bump stable release version" CMakeLists.txt README.md matlab/README.md JSBSim.vcxproj JSBSimForUnreal.vcxproj | |
git push origin $BRANCH_NAME | |
# Bump stable version of the `master` branch | |
- name: Checkout JSBSim master branch | |
uses: actions/checkout@v4 | |
with: | |
ref: master | |
path: _master | |
- name: Bump stable version in README.md | |
working-directory: _master | |
run: | | |
# Increment the value of PROJECT_VERSION_PATCH | |
sed -ri 's/(set\(PROJECT_VERSION_PATCH\s\")([0-9]+).*/echo "\1\\"$((\2+1))\.dev1\\"\\)/ge' CMakeLists.txt | |
# Update references to the current stable version in README.md | |
sed -ri 's/_'"$OLD_VERSION"'-[0-9]+.amd64.deb/_'"$VERSION"'-'"$GITHUB_RUN_NUMBER"'.amd64.deb/g' README.md | |
sed -ri 's/'"$OLD_VERSION"'/'"$VERSION"'/g' README.md | |
sed -ri 's/'"$OLD_VERSION"'/'"$VERSION"'/g' matlab/README.md | |
# Update the MSVC project files. | |
sed -ri 's/JSBSIM_VERSION=".*"/JSBSIM_VERSION="'$FUTURE_VERSION'.dev1"/g' JSBSim.vcxproj | |
sed -ri 's/JSBSIM_VERSION=".*"/JSBSIM_VERSION="'$FUTURE_VERSION'.dev1"/g' JSBSimForUnreal.vcxproj | |
# Update the MSVC version | |
sed -ri 's/Visual Studio\s[A-Za-z0-9 ]+\s\(build\s[0-9.]+\)/'"$MSVC_VERSION"'/g' matlab/README.md | |
git commit -m "Bump version" CMakeLists.txt README.md matlab/README.md JSBSim.vcxproj JSBSimForUnreal.vcxproj | |
git push origin master | |
Documentation: | |
needs: Stable-Release | |
name: Deploy Documentation | |
runs-on: ubuntu-latest | |
environment: | |
name: github-pages | |
url: ${{ steps.deployment.outputs.pages_url }} | |
permissions: | |
contents: read | |
pages: write | |
id-token: write | |
steps: | |
- name: Install Ubuntu packages | |
run: | | |
sudo apt-get update | |
sudo apt-get install doxygen graphviz | |
- name: Set up Python 3.8 | |
uses: actions/setup-python@v5 | |
with: | |
python-version: '3.8' | |
- name: Install Python packages | |
run: pip install -U 'numpy>=1.20' sphinx cython | |
- name: Checkout JSBSim | |
uses: actions/checkout@v4 | |
- name: Configure JSBSim | |
run: | | |
mkdir build && cd build | |
cmake .. | |
- name: Download Python wheels | |
uses: actions/download-artifact@v4 | |
with: | |
name: ubuntu-latest-Wheels.binaries | |
path: build | |
- name: Build Python docs | |
working-directory: build | |
run: | | |
pip install jsbsim --no-index -f . | |
touch documentation/html/.nojekyll | |
sphinx-build -b html documentation documentation/html/python | |
- name: Setup Pages | |
uses: actions/configure-pages@v5 | |
- name: Upload Pages Artifact | |
uses: actions/upload-pages-artifact@v3 | |
with: | |
# upload entire directory | |
path: 'build/documentation/html' | |
- name: Deploy to GitHub Pages | |
id: deployment | |
uses: actions/deploy-pages@v4 |