From 173b49ef33bcb84cf257c931a34fa0e6690a0f5c Mon Sep 17 00:00:00 2001 From: Jason Marechal Date: Tue, 10 Oct 2023 13:32:47 +0200 Subject: [PATCH] Revert "yml" This reverts commit 511be688bfb4033494500bb1f22cb5a51cbbe88c. --- .github/workflows/build_centos7.yml | 154 ++++++++++ .github/workflows/build_ubuntu.yml | 123 ++++++++ .github/workflows/build_windows.yml | 145 +++++++++ .github/workflows/centos-release.yml | 285 ++++++++++++++++++ .github/workflows/release.yml | 17 ++ .github/workflows/sonarcloud.yml | 116 +++++++ .github/workflows/test-env.yml | 23 ++ .github/workflows/ubuntu-release.yml | 226 ++++++++++++++ .../workflows/ubuntu-system-deps-build.yml | 93 ++++++ .../workflows/windows-vcpkg-deps-build.yml | 116 +++++++ .github/workflows/windows-vcpkg.yml | 275 +++++++++++++++++ 11 files changed, 1573 insertions(+) create mode 100644 .github/workflows/build_centos7.yml create mode 100644 .github/workflows/build_ubuntu.yml create mode 100644 .github/workflows/build_windows.yml create mode 100644 .github/workflows/centos-release.yml create mode 100644 .github/workflows/release.yml create mode 100644 .github/workflows/sonarcloud.yml create mode 100644 .github/workflows/test-env.yml create mode 100644 .github/workflows/ubuntu-release.yml create mode 100644 .github/workflows/ubuntu-system-deps-build.yml create mode 100644 .github/workflows/windows-vcpkg-deps-build.yml create mode 100644 .github/workflows/windows-vcpkg.yml diff --git a/.github/workflows/build_centos7.yml b/.github/workflows/build_centos7.yml new file mode 100644 index 0000000000..e8a937fdb4 --- /dev/null +++ b/.github/workflows/build_centos7.yml @@ -0,0 +1,154 @@ +name: Centos7 Build + +on: + merge_group: + push: + branches: + - main + - develop + pull_request: + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + docker_publish: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@master + with: + fetch-depth: 0 + - name: Get changed files + id: changed-files + uses: tj-actions/changed-files@v32 + with: + files: | + docker/centos7-system-deps + + - name: Docker file push + id: docker_push + if: steps.changed-files.outputs.any_changed == 'true' + uses: elgohr/Publish-Docker-Github-Action@main + with: + name: antaresrte/rte-antares + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_PASSWORD }} + workdir: docker + dockerfile: centos7-system-deps + cache: false + tags: centos7-system-deps + + versions: + runs-on: ubuntu-latest + outputs: + antares-version: ${{steps.antares-version.outputs.result}} + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + steps: + - uses: actions/checkout@v3 + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + build: + runs-on: ubuntu-latest + needs: [ docker_publish, versions ] + container: 'antaresrte/rte-antares:centos7-system-deps' + strategy: + matrix: + xprs: [ XPRESS-ON, XPRESS-OFF ] + env: + XPRESSDIR: ${{ github.workspace }}/xpress + XPRESS: ${{ github.workspace }}/xpress/bin + XPRS_LIB_Path: ${{ github.workspace }}/xpress/lib + XPRESSDIR_CONTAINER: ${GITHUB_WORKSPACE}/xpress + XPRESS_CONTAINER: ${GITHUB_WORKSPACE}/xpress/bin + XPRS_LIB_Path_CONTAINER: ${GITHUB_WORKSPACE}/xpress/lib + + steps: + - name: Get release + if: github.event_name == 'release' && github.event.action == 'created' + id: get_release + uses: bruceadams/get-release@v1.2.3 + - uses: actions/checkout@v3 + with: + submodules: true + + - name: Checkout xpressmp linux + uses: actions/checkout@v3 + with: + token: ${{ secrets.AS_TOKEN }} + repository: rte-france/xpress-mp + path: ${{ env.XPRESSDIR }} + github-server-url: https://github.com + ref: 8.13a + if: matrix.xprs == 'XPRESS-ON' + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-tgz + with: + antares-deps-version: ${{needs.versions.outputs.antares-deps-version}} + antares-version: ${{needs.versions.outputs.antares-version}} + os: centos7 + os-full-name: CentOS-7.9.2009 + #variant: -ortools-xpress + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + - name: Install dependencies + run: | + pip3 install -r requirements-tests.txt + pip3 install -r requirements-ui.txt + - name: Configure + run: | + [[ ${{ matrix.xprs }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" + source /opt/rh/devtoolset-9/enable + export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH + export PATH=/usr/lib64/openmpi/bin:$PATH + cmake3 -B _build -S . \ + -DDEPS_INSTALL_DIR=rte-antares-deps-Release \ + -DBUILD_TESTING=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX=_install \ + -DBUILD_UI=ON \ + -DXPRESS=${{ env.XPRESS_VALUE }} \ + -DXPRESS_ROOT=${{ env.XPRESSDIR }} \ + -DALLOW_RUN_AS_ROOT=ON + - name: Build + run: | + source /opt/rh/devtoolset-9/enable + export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH + export PATH=/usr/lib64/openmpi/bin:$PATH + cmake3 --build _build --config Release -j8 --target install + - name: Running unit tests + timeout-minutes: 120 + shell: bash + run: | + source /etc/profile.d/modules.sh + module load mpi + export LD_LIBRARY_PATH=LD_LIBRARY_PATH:${{ env.XPRS_LIB_Path_CONTAINER }} + export XPRESS=${{ env.XPRESS_CONTAINER }} + cd _build + ctest3 -C Release --output-on-failure -L "unit|benders|lpnamer|medium" \ No newline at end of file diff --git a/.github/workflows/build_ubuntu.yml b/.github/workflows/build_ubuntu.yml new file mode 100644 index 0000000000..f6b31f2759 --- /dev/null +++ b/.github/workflows/build_ubuntu.yml @@ -0,0 +1,123 @@ +name: Ubuntu build + +on: + merge_group: + push: + branches: + - main + - develop + pull_request: + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + build: + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ ubuntu-20.04 ] + xprs: [ XPRESS-ON, XPRESS-OFF ] + env: + XPRESSDIR: ${{ github.workspace }}/xpress + XPRESS: ${{ github.workspace }}/xpress/bin + XPRS_LIB_Path: ${{ github.workspace }}/xpress/lib + + steps: + - run: | + apt update + + - uses: actions/checkout@v3 + with: + submodules: true + + - name: Checkout xpressmp linux + if: matrix.xprs == 'XPRESS-ON' + uses: actions/checkout@v3 + with: + repository: rte-france/xpress-mp + path: ${{ env.XPRESSDIR }} + ref: 8.13 + token: ${{ secrets.AS_TOKEN }} #reniew token periodically + + - name: Set up Python + uses: actions/setup-python@v4 + with: + cache: 'pip' + python-version: 3.8 + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install -r requirements-tests.txt + pip install -r requirements-ui.txt + + - name: Install mandatory system libraries + run: | + sudo apt-get update --fix-missing + sudo apt-get install libjsoncpp-dev libgtest-dev libboost-mpi-dev libboost-program-options-dev libtbb-dev + cd /usr/src/googletest/ + sudo cmake . + sudo cmake --build . + + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-tgz + with: + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + antares-version: ${{steps.antares-version.outputs.result}} + os: ${{matrix.os}} + os-full-name: Ubuntu-20.04 + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + - name: Configure + shell: bash + #XPRESS_VALUE = ${{ matrix.xprs }} == "XPRESS-ON" ? "ON" : "OFF" + run: | + [[ ${{ matrix.xprs }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" + cmake -B _build -S . \ + -DCMAKE_C_COMPILER_LAUNCHER=ccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \ + -DDEPS_INSTALL_DIR=rte-antares-deps-Release \ + -DBUILD_TESTING=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX=_install \ + -DBUILD_UI=ON \ + -DXPRESS=${{ env.XPRESS_VALUE }} \ + -DXPRESS_ROOT=${{ env.XPRESSDIR }} + + - name: Build + run: | + cmake --build _build --config Release -j8 + + - name: Test + run: | + cd _build + ctest -C Release --output-on-failure -L "medium|unit|benders|lpnamer" diff --git a/.github/workflows/build_windows.yml b/.github/workflows/build_windows.yml new file mode 100644 index 0000000000..5f8c594074 --- /dev/null +++ b/.github/workflows/build_windows.yml @@ -0,0 +1,145 @@ +name: Windows build + +on: + merge_group: + push: + branches: + - main + - develop + pull_request: + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + windows: + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ windows-latest ] + triplet: [ x64-windows ] + xprs: [ XPRESS-ON, XPRESS-OFF ] + env: + XPRESSDIR: ${{ github.workspace }}\xpress + XPRESS: ${{ github.workspace }}\xpress\bin + XPRS_LIB_Path: ${{ github.workspace }}\xpress\lib + # Indicates the location of the vcpkg as a Git submodule of the project repository. + VCPKG_ROOT: ${{ github.workspace }}/vcpkg + + steps: + - uses: actions/checkout@v3 + with: + submodules: true + + - name: Checkout xpressmp linux + if: matrix.xprs == 'XPRESS-ON' + uses: actions/checkout@v3 + with: + repository: rte-france/xpress-mp-temp + path: ${{ env.XPRESSDIR }} + ref: 8.13a + token: ${{ secrets.AS_TOKEN }} + + - name: Get release + if: github.event_name == 'release' && github.event.action == 'created' + id: get_release + uses: + bruceadams/get-release@v1.2.3 + + - name: Set up Python + uses: actions/setup-python@v3 + with: + python-version: '3.x' + cache: 'pip' + cache-dependency-path: requirements*.txt + + # Restore both vcpkg and its artifacts from the GitHub cache service. + - name: Restore vcpkg and its artifacts. + uses: actions/cache@v3 + with: + # The first path is the location of vcpkg (it contains the vcpkg executable and data files). + # The other paths starting with '!' are exclusions: they contain termporary files generated during the build of the installed packages. + path: | + ${{ env.VCPKG_ROOT }} + !${{ env.VCPKG_ROOT }}/buildtrees + !${{ env.VCPKG_ROOT }}/packages + !${{ env.VCPKG_ROOT }}/downloads + # The key is composed in a way that it gets properly invalidated: this must happen whenever vcpkg's Git commit id changes, or the list of packages changes. In this case a cache miss must happen and a new entry with a new key with be pushed to GitHub the cache service. + # The key includes: hash of the vcpkg.json file, the hash of the vcpkg Git commit id, and the used vcpkg's triplet. The vcpkg's commit id would suffice, but computing an hash out it does not harm. + # Note: given a key, the cache content is immutable. If a cache entry has been created improperly, in order the recreate the right content the key must be changed as well, and it must be brand new (i.e. not existing already). + key: | + ${{ hashFiles( 'vcpkg.json' ) }}-${{ hashFiles( '.git/modules/vcpkg/HEAD' )}}-${{ matrix.triplet }} + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install -r requirements-tests.txt + pip install -r requirements-ui.txt + + - name: Pre-requisites + shell: cmd + run: | + choco install wget zip unzip --no-progress + wget -nv https://github.com/microsoft/Microsoft-MPI/releases/download/v10.1.1/msmpisetup.exe + msmpisetup.exe -unattend + + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + - name: Install deps with VCPKG + run: | + cd vcpkg + ./bootstrap-vcpkg.sh + vcpkg install --triplet ${{matrix.triplet}} + rm -rf buildtrees + rm -rf packages + rm -rf downloads + shell: bash + + - name: Compile tbb + uses: ./.github/workflows/compile-tbb + with: + cmake: 'cmake' + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-zip + with: + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + antares-version: ${{steps.antares-version.outputs.result}} + os: ${{matrix.os}} + + - name: Expand xpress value in env + #I can't seem to expand the variable in the cmake command line so export it in env + shell: bash + run: | + [[ ${{ matrix.xprs }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" + echo "XPRESS_VALUE=$XPRESS_VALUE" >> $GITHUB_ENV + + - name: Configure + run: | + $pwd=Get-Location + cmake -B _build -S . -DDEPS_INSTALL_DIR=rte-antares-deps-Release -DCMAKE_PREFIX_PATH="$pwd\rte-antares-${{steps.antares-version.outputs.result}}-installer-64bits" -DBUILD_TESTING=ON -DCMAKE_BUILD_TYPE=Release -DCMAKE_TOOLCHAIN_FILE="${{env.VCPKG_ROOT}}/scripts/buildsystems/vcpkg.cmake" -DVCPKG_TARGET_TRIPLET=${{ matrix.triplet }} -DCMAKE_INSTALL_PREFIX=_install -DBUILD_UI=ON -DXPRESS=${{ env.XPRESS_VALUE }} -DXPRESS_ROOT="${{ env.XPRESSDIR }}" + - name: Build + run: | + cmake --build _build --config Release -j2 --target install + - name: Running unit tests + timeout-minutes: 120 + shell: cmd + run: | + set PATH=%PATH%;C:\Program Files\Microsoft MPI\Bin + set PATH=%PATH%;${{ env.XPRESS }} + cd _build + ctest -C Release --output-on-failure -L "medium|unit|benders|lpnamer" \ No newline at end of file diff --git a/.github/workflows/centos-release.yml b/.github/workflows/centos-release.yml new file mode 100644 index 0000000000..efe0bc2c6c --- /dev/null +++ b/.github/workflows/centos-release.yml @@ -0,0 +1,285 @@ +name: Centos7 release + +on: + push: + branches: + - main + - develop + - ci/* + workflow_dispatch: + workflow_run: + workflows: [ "Publish Release" ] + types: + - completed + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + + docker_publish: + runs-on: ubuntu-latest + steps: + + - uses: actions/checkout@master + with: + fetch-depth: 0 + + - name: Get changed files + id: changed-files + uses: tj-actions/changed-files@v32 + with: + files: | + docker/centos7-system-deps + + - name: Docker file push + id: docker_push + if: steps.changed-files.outputs.any_changed == 'true' + uses: elgohr/Publish-Docker-Github-Action@main + with: + name: antaresrte/rte-antares + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_PASSWORD }} + workdir: docker + dockerfile: centos7-system-deps + cache: false + tags: centos7-system-deps + + userguide: + runs-on: ubuntu-latest + outputs: + pdf-name: ${{ steps.create-user-guide.outputs.pdf-name }} + + steps: + - uses: actions/checkout@v3 + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - id: create-user-guide + name: user guide pdf creation + uses: ./.github/workflows/generate-userguide-pdf + with: + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + + - name: user guide upload + id: userguide_upload + uses: actions/upload-artifact@v3 + with: + name: user-guide + path: ${{ steps.create-user-guide.outputs.pdf-path }} + + versions: + runs-on: ubuntu-latest + outputs: + antares-version: ${{steps.antares-version.outputs.result}} + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + steps: + - uses: actions/checkout@v3 + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + build: + runs-on: ubuntu-latest + needs: [ docker_publish, userguide, versions ] + container: 'antaresrte/rte-antares:centos7-system-deps' + strategy: + matrix: + xprs: [ XPRESS-ON, XPRESS-OFF ] + env: + XPRESSDIR: ${{ github.workspace }}/xpress + XPRESS: ${{ github.workspace }}/xpress/bin + XPRS_LIB_Path: ${{ github.workspace }}/xpress/lib + XPRESSDIR_CONTAINER: ${GITHUB_WORKSPACE}/xpress + XPRESS_CONTAINER: ${GITHUB_WORKSPACE}/xpress/bin + XPRS_LIB_Path_CONTAINER: ${GITHUB_WORKSPACE}/xpress/lib + outputs: + zip_name: ${{ steps.zip_name.outputs.zip_name }} + singlefile_name: ${{ steps.zip_name.outputs.singlefile_name }} + steps: + - id: branch-name + uses: tj-actions/branch-names@v6 + + - name: Checkout + uses: actions/checkout@v3 + with: + submodules: true + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-tgz + with: + antares-deps-version: ${{needs.versions.outputs.antares-deps-version}} + antares-version: ${{needs.versions.outputs.antares-version}} + os: centos7 + os-full-name: CentOS-7.9.2009 + #variant: -ortools-xpress + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + - name: Install dependencies + run: | + pip3 install -r requirements-tests.txt + pip3 install -r requirements-ui.txt + + - name: Download userguide + uses: actions/download-artifact@v3 + with: + name: user-guide + path: docs/ + + - name: Checkout xpressmp linux + uses: actions/checkout@v3 + with: + token: ${{ secrets.AS_TOKEN }} + repository: rte-france/xpress-mp + path: ${{ env.XPRESSDIR }} + github-server-url: https://github.com + ref: 8.13a + if: matrix.xprs == 'XPRESS-ON' + + - name: Configure + shell: bash + run: | + if [ ${{ matrix.xprs }} == "XPRESS-ON" ]; then + export XPRESS_VALUE="ON" + else + export XPRESS_VALUE="OFF" + fi + source /opt/rh/devtoolset-9/enable + export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH + export PATH=/usr/lib64/openmpi/bin:$PATH + cmake3 -B _build -S . \ + -DDEPS_INSTALL_DIR=rte-antares-deps-Release \ + -DBUILD_TESTING=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX=_install \ + -DBUILD_UI=ON \ + -DUSER_GUIDE_PATH="docs/${{ needs.userguide.outputs.pdf-name }}" \ + -DXPRESS=${XPRESS_VALUE} \ + -DXPRESS_ROOT=${XPRESSDIR} \ + -DALLOW_RUN_AS_ROOT=ON + + - name: Build + shell: bash + run: | + source /opt/rh/devtoolset-9/enable + export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH + export PATH=/usr/lib64/openmpi/bin:$PATH + cmake3 --build _build --config Release -j2 --target install + + - name: Running unit tests + timeout-minutes: 120 + shell: bash + run: | + source /etc/profile.d/modules.sh + module load mpi + export LD_LIBRARY_PATH=LD_LIBRARY_PATH:${{ env.XPRS_LIB_Path_CONTAINER }} + export XPRESS=${{ env.XPRESS_CONTAINER }} + cd _build + ctest3 -C Release --output-on-failure -L "unit|benders|lpnamer|medium" + + - name: set name variables + id: single_file_name + shell: bash + run: | + if [ ${{ matrix.xprs }} == "XPRESS-ON" ]; then + WITH_XPRS="-xpress" + else + WITH_XPRS="" + fi + VERSION=${{needs.versions.outputs.antares-xpansion-version}}${WITH_XPRS} + echo "VERSION_WITH_XPRESS=$VERSION" >> $GITHUB_ENV + + - name: .tar.gz creation + run: | + cd _build + export FILE_NAME="antaresXpansion-${{env.VERSION_WITH_XPRESS}}-CentOS-7.9.2009" + cpack3 -G TGZ -D CPACK_PACKAGE_FILE_NAME=$FILE_NAME + echo "TGZ_NAME=$FILE_NAME.tar.gz" >> $GITHUB_ENV + + - name: Upload .tar.gz + uses: actions/upload-artifact@v3 + with: + name: ${{env.TGZ_NAME}} + path: _build/${{env.TGZ_NAME}} + + - id: create-single-file + name: Single file .tar.gz creation + uses: ./.github/workflows/single-file-creation-tgz + with: + antares-xpansion-version: ${{env.VERSION_WITH_XPRESS}} + + - name: Upload single file + uses: actions/upload-artifact@v3 + with: + name: ${{ steps.create-single-file.outputs.archive-name }} + path: ${{ steps.create-single-file.outputs.archive-path }} + + - id: zip_name + run: | + echo "singlefile_name=${{steps.create-single-file.outputs.archive-name}}" >> "$GITHUB_OUTPUT" + echo "zip_name=${{env.TGZ_NAME}}" >> "$GITHUB_OUTPUT" + ####################### + + upload_asset_to_release: + if: github.event_name == 'release' && github.event.action == 'created' + runs-on: ubuntu-latest + needs: build + env: + ZIP_NAME: ${{needs.build.outputs.zip_name}} + SINGLEFILE_NAME: ${{needs.build.outputs.singlefile_name}} + steps: + - name: Get release + if: github.event_name == 'release' && github.event.action == 'created' + id: get_release + uses: bruceadams/get-release@main + + - name: Download Artifact + uses: actions/download-artifact@v3 + with: + name: $ZIP_NAME + path: . + + - name: Download Artifact + uses: actions/download-artifact@v3 + with: + name: $SINGLEFILE_NAME + path: . + + - name: Upload Release Asset + env: + GH_REPO: ${{ github.repository }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + run: | + gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} $ZIP_NAME + gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} $SINGLEFILE_NAME + + ######################## \ No newline at end of file diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000000..2eb5241971 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,17 @@ +name: Publish Release + +on: + push: + tags: + - "v*.*.*" + +jobs: + build: + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v3 + - name: Release + uses: softprops/action-gh-release@v1 + with: + prerelease: ${{ contains(github.ref, '-rc') }} \ No newline at end of file diff --git a/.github/workflows/sonarcloud.yml b/.github/workflows/sonarcloud.yml new file mode 100644 index 0000000000..63e30b3116 --- /dev/null +++ b/.github/workflows/sonarcloud.yml @@ -0,0 +1,116 @@ +name: SonarCloud + +on: + push: + branches: + - main + - develop + - release/* + pull_request: + +jobs: + sonarcloud: + name: SonarCloud + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ ubuntu-20.04 ] + + env: + SONAR_SCANNER_VERSION: 4.7.0.2747 # Find the latest version in the "Linux" link on this page: + # https://sonarcloud.io/documentation/analysis/scan/sonarscanner/ + SONAR_SERVER_URL: "https://sonarcloud.io" + + steps: + + - uses: actions/checkout@v3 + with: + fetch-depth: 0 + + - name: Install sonar-scanner and build-wrapper + uses: SonarSource/sonarcloud-github-c-cpp@v2 + + - name: Set up Python + uses: actions/setup-python@v4 + with: + python-version: 3.8 + + - name: Install gcovr + run: sudo pip install gcovr==5.0 #5.1 generate issues with sonarcloud report parsing + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip3 install -r requirements-tests.txt + + - name: Install libraries + run: | + sudo apt-get update --fix-missing + sudo apt-get install libjsoncpp-dev libgtest-dev libboost-mpi-dev libboost-program-options-dev libtbb-dev + cd /usr/src/googletest/ + sudo cmake . + sudo cmake --build . --target install + + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-tgz + with: + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + antares-version: ${{steps.antares-version.outputs.result}} + os: ${{matrix.os}} + os-full-name: Ubuntu-20.04 + buildtype: Debug + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + + - name: Init submodule + run: | + git submodule update --init --recursive . + + - name: Configure + run: | + cmake -B _build -S . -DDEPS_INSTALL_DIR=rte-antares-deps-Debug -DCODE_COVERAGE=ON -DBUILD_TESTING=ON -DBUILD_antares_solver=OFF -DCMAKE_BUILD_TYPE=Debug -DCMAKE_INSTALL_PREFIX=_install + + - name: Build + run: build-wrapper-linux-x86-64 --out-dir $GITHUB_WORKSPACE/_build/output cmake --build _build --config Debug -j2 + + - name: Test and generate coverage + continue-on-error: true + run: | + cd $GITHUB_WORKSPACE/_build + ctest -C Release --output-on-failure -L "unit" + + - name: Compile coverage reports + run: | + cmake --build $GITHUB_WORKSPACE/_build --target code-coverage + + - name: Run sonar-scanner + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN_2022 }} + run: sonar-scanner --define sonar.host.url="${{ env.SONAR_SERVER_URL }}" \ No newline at end of file diff --git a/.github/workflows/test-env.yml b/.github/workflows/test-env.yml new file mode 100644 index 0000000000..2e98246a84 --- /dev/null +++ b/.github/workflows/test-env.yml @@ -0,0 +1,23 @@ +name: Test env + +on: + push: + branches: + - main + - develop + - release/* + - ci/* +jobs: + + build: + + runs-on: ubuntu-latest + container: 'centos:7' + + steps: + - uses: actions/checkout@v3 + - run: | + echo `uname -a` + + - uses: ./.github/actions/test + diff --git a/.github/workflows/ubuntu-release.yml b/.github/workflows/ubuntu-release.yml new file mode 100644 index 0000000000..49002094a0 --- /dev/null +++ b/.github/workflows/ubuntu-release.yml @@ -0,0 +1,226 @@ +name: Ubuntu Release + +on: + push: + branches: + - main + - develop + - ci/* + workflow_dispatch: + workflow_run: + workflows: [ "Publish Release" ] + types: + - completed + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + + userguide: + runs-on: ubuntu-latest + outputs: + pdf-name: ${{ steps.create-user-guide.outputs.pdf-name }} + + steps: + - uses: actions/checkout@v3 + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - id: create-user-guide + name: user guide pdf creation + uses: ./.github/workflows/generate-userguide-pdf + with: + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + + - name: user guide upload + id: userguide_upload + uses: actions/upload-artifact@v3 + with: + name: user-guide + path: ${{ steps.create-user-guide.outputs.pdf-path }} + + build: + + needs: userguide + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ ubuntu-20.04 ] + xprs: [ XPRESS-ON, XPRESS-OFF ] + env: + XPRESSDIR: ${{ github.workspace }}/xpress + XPRESS: ${{ github.workspace }}/xpress/bin + XPRS_LIB_Path: ${{ github.workspace }}/xpress/lib + + steps: + - uses: actions/checkout@v3 + with: + submodules: true + + - name: Checkout xpressmp linux + if: matrix.xprs == 'XPRESS-ON' + uses: actions/checkout@v3 + with: + repository: rte-france/xpress-mp + path: ${{ env.XPRESSDIR }} + ref: 8.13a + token: ${{ secrets.AS_TOKEN }} #reniew token periodically + + - name: ccache + uses: hendrikmuhs/ccache-action@v1.2.3 + with: + key: ${{ matrix.os }}-${{ matrix.xprs }} + + - name: Set up Python + uses: actions/setup-python@v4 + with: + python-version: 3.8 + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install -r requirements-tests.txt + pip install -r requirements-ui.txt + + - name: Install mandatory system libraries + run: | + sudo apt-get update --fix-missing + sudo apt-get install libjsoncpp-dev libgtest-dev libboost-mpi-dev libboost-program-options-dev libtbb-dev + cd /usr/src/googletest/ + sudo cmake . + sudo cmake --build . --target install + + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-tgz + with: + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + antares-version: ${{steps.antares-version.outputs.result}} + os: ${{matrix.os}} + os-full-name: Ubuntu-20.04 + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + - name: Download userguide + uses: actions/download-artifact@v3 + with: + name: user-guide + path: docs/ + + - name: Configure + shell: bash + run: | + if [ ${{ matrix.xprs }} == "XPRESS-ON" ]; then + XPRESS_VALUE="ON" + else + XPRESS_VALUE="OFF" + fi + cmake -B _build -S . \ + -DCMAKE_C_COMPILER_LAUNCHER=ccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \ + -DDEPS_INSTALL_DIR=rte-antares-deps-Release \ + -DBUILD_TESTING=ON \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX=_install \ + -DBUILD_UI=ON \ + -DUSER_GUIDE_PATH="docs/${{ needs.userguide.outputs.pdf-name }}" \ + -DXPRESS=${{ env.XPRESS_VALUE }} \ + -DXPRESS_ROOT=${{ env.XPRESSDIR }} + + - name: Build + run: | + cmake --build _build --config Release -j8 --target install + + - name: set name variables + id: single_file_name + shell: bash + run: | + if [ ${{ matrix.xprs }} == "XPRESS-ON" ]; then + WITH_XPRS="-xpress" + else + WITH_XPRS="" + fi + VERSION=${{steps.antares-xpansion-version.outputs.result}}${WITH_XPRS} + echo "VERSION_WITH_XPRESS=$VERSION" >> $GITHUB_ENV + + - id: create-single-file + name: Single file .tar.gz creation + uses: ./.github/workflows/single-file-creation-tgz + with: + antares-xpansion-version: ${{env.VERSION_WITH_XPRESS}} + + - name: Installer .tar.gz creation + run: | + cd _build + export FILE_NAME="antaresXpansion-${{env.VERSION_WITH_XPRESS}}-${{ matrix.os }}" + cpack -G TGZ -D CPACK_PACKAGE_FILE_NAME=$FILE_NAME + #Need to differentiate between xpress/no_xpress files + #Cpack command line doesn't seem to care about -P or -R options + echo "TGZ_NAME=$FILE_NAME.tar.gz" >> $GITHUB_ENV + + - name: Running unit tests + run: | + cd _build + ctest -C Release --output-on-failure -L "medium|unit|benders|lpnamer" + + #Uploads are not necessary for release but useful in other cases + - name: Upload .tar.gz + uses: actions/upload-artifact@v3 + with: + name: ${{env.TGZ_NAME}} + path: _build/${{env.TGZ_NAME}} + + - name: Upload single file + uses: actions/upload-artifact@v3 + with: + name: ${{ steps.create-single-file.outputs.archive-name }} + path: ${{ steps.create-single-file.outputs.archive-path }} + + ####################### + + - name: Get release + if: github.event_name == 'release' && github.event.action == 'created' + id: get_release + uses: bruceadams/get-release@main + + - name: Upload Release Asset + if: github.event_name == 'release' && github.event.action == 'created' + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + run: | + gh release upload ${{ steps.get_release.outputs.tag_name }} _build/${{env.TGZ_NAME}} + gh release upload ${{ steps.get_release.outputs.tag_name }} _build/${{env.TGZ_NAME}} + + ######################## \ No newline at end of file diff --git a/.github/workflows/ubuntu-system-deps-build.yml b/.github/workflows/ubuntu-system-deps-build.yml new file mode 100644 index 0000000000..3985ce4d02 --- /dev/null +++ b/.github/workflows/ubuntu-system-deps-build.yml @@ -0,0 +1,93 @@ +name: Ubuntu CI full build + +on: + push: + branches: + - main + - develop + - release/* + - ci/* +jobs: + + build: + + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ ubuntu-20.04 ] + + steps: + - uses: actions/checkout@v3 + with: + submodules: true + + - name: ccache + uses: hendrikmuhs/ccache-action@v1.2.3 + + - name: Set up Python + uses: actions/setup-python@v4 + with: + python-version: 3.8 + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install -r requirements-tests.txt + pip install -r requirements-ui.txt + + - name: Install mandatory system libraries + run: | + sudo apt-get update --fix-missing + sudo apt-get install libjsoncpp-dev libgtest-dev libboost-mpi-dev libboost-program-options-dev libtbb-dev + cd /usr/src/googletest/ + sudo cmake . + sudo cmake --build . --target install + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Configure + run: | + cmake -B _build -S . \ + -DCMAKE_C_COMPILER_LAUNCHER=ccache \ + -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \ + -DBUILD_TESTING=ON -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX=_install \ + -DBUILD_UI=ON + + - name: Build + run: | + cmake --build _build --config Release -j2 --target install + + - name: Running unit tests + run: | + cd _build + ctest -C Release --output-on-failure -L "medium|unit|benders|lpnamer" + + - id: create-single-file + name: Single file .tar.gz creation + uses: ./.github/workflows/single-file-creation-tgz + with: + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + + - name: Installer .tar.gz creation + run: | + cd _build + cpack -G TGZ + + - name: Installer .deb creation + run: | + cd _build + cpack -G DEB + diff --git a/.github/workflows/windows-vcpkg-deps-build.yml b/.github/workflows/windows-vcpkg-deps-build.yml new file mode 100644 index 0000000000..0b832b1c2d --- /dev/null +++ b/.github/workflows/windows-vcpkg-deps-build.yml @@ -0,0 +1,116 @@ +name: Windows CI full build + +on: + push: + branches: + - main + - develop + - release/* + - ci/* +jobs: + + windows: + + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ windows-latest ] + triplet: [ x64-windows ] + + env: + # Indicates the location of the vcpkg as a Git submodule of the project repository. + VCPKG_ROOT: ${{ github.workspace }}/vcpkg + + steps: + - uses: actions/checkout@v3 + with: + submodules: true + + - name: Enable git longpaths + run: git config --system core.longpaths true + + - name: Set up Python + uses: actions/setup-python@v4 + with: + python-version: '3.x' + + # Restore both vcpkg and its artifacts from the GitHub cache service. + - name: Restore vcpkg and its artifacts. + uses: actions/cache@v3 + with: + # The first path is the location of vcpkg (it contains the vcpkg executable and data files). + # The other paths starting with '!' are exclusions: they contain termporary files generated during the build of the installed packages. + path: | + ${{ env.VCPKG_ROOT }} + !${{ env.VCPKG_ROOT }}/buildtrees + !${{ env.VCPKG_ROOT }}/packages + !${{ env.VCPKG_ROOT }}/downloads + # The key is composed in a way that it gets properly invalidated: this must happen whenever vcpkg's Git commit id changes, or the list of packages changes. In this case a cache miss must happen and a new entry with a new key with be pushed to GitHub the cache service. + # The key includes: hash of the vcpkg.json file, the hash of the vcpkg Git commit id, and the used vcpkg's triplet. The vcpkg's commit id would suffice, but computing an hash out it does not harm. + # Note: given a key, the cache content is immutable. If a cache entry has been created improperly, in order the recreate the right content the key must be changed as well, and it must be brand new (i.e. not existing already). + key: | + ${{ hashFiles( 'vcpkg.json' ) }}-${{ hashFiles( '.git/modules/vcpkg/HEAD' )}}-${{ matrix.triplet }}-invalidate + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install -r requirements-tests.txt + pip install -r requirements-ui.txt + + - name: Pre-requisites + shell: cmd + run: | + choco install wget zip unzip --no-progress + wget -nv https://github.com/microsoft/Microsoft-MPI/releases/download/v10.1.1/msmpisetup.exe + msmpisetup.exe -unattend + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Install deps with VCPKG + run: | + cd vcpkg + ./bootstrap-vcpkg.sh + vcpkg install --triplet ${{matrix.triplet}} + rm -rf buildtrees + rm -rf packages + rm -rf downloads + shell: bash + + - name: Compile tbb + uses: ./.github/workflows/compile-tbb + with: + cmake: 'cmake' + + - name: Configure + run: | + $pwd=Get-Location + cmake -B _build -S . -DBUILD_TESTING=ON -DCMAKE_BUILD_TYPE=Release -DCMAKE_TOOLCHAIN_FILE="vcpkg/scripts/buildsystems/vcpkg.cmake" -DVCPKG_TARGET_TRIPLET=${{ matrix.triplet }} -DCMAKE_INSTALL_PREFIX=_install -DBUILD_UI=ON + + - name: Build + run: | + cmake --build _build --config Release -j2 --target install + + - name: Running unit tests + shell: cmd + run: | + set PATH=%PATH%;C:\Program Files\Microsoft MPI\Bin\ + cd _build + ctest -C Release --output-on-failure -L "medium|unit|benders|lpnamer" + + - name: Installer .zip creation + run: | + cd _build + cpack -G ZIP + + - id: create-single-file + name: Single file .zip creation + uses: ./.github/workflows/single-file-creation-zip + with: + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + diff --git a/.github/workflows/windows-vcpkg.yml b/.github/workflows/windows-vcpkg.yml new file mode 100644 index 0000000000..063bdab22f --- /dev/null +++ b/.github/workflows/windows-vcpkg.yml @@ -0,0 +1,275 @@ +name: Windows release + +on: + push: + branches: + - main + - develop + - ci/* + workflow_dispatch: + workflow_run: + workflows: [ "Publish Release" ] + types: + - completed + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + + userguide: + runs-on: ubuntu-latest + outputs: + pdf-name: ${{ steps.create-user-guide.outputs.pdf-name }} + + steps: + - uses: actions/checkout@v3 + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - id: create-user-guide + name: user guide pdf creation + uses: ./.github/workflows/generate-userguide-pdf + with: + antares-xpansion-version: ${{steps.antares-xpansion-version.outputs.result}} + + - name: user guide upload + id: userguide_upload + uses: actions/upload-artifact@v3 + with: + name: user-guide + path: ${{ steps.create-user-guide.outputs.pdf-path }} + + build: + needs: userguide + runs-on: ${{ matrix.os }} + if: "!contains(github.event.head_commit.message, '[skip ci]')" + strategy: + matrix: + os: [ windows-latest ] + triplet: [ x64-windows ] + xprs: [ XPRESS-ON, XPRESS-OFF ] + env: + XPRESSDIR: ${{ github.workspace }}\xpress + XPRESS: ${{ github.workspace }}\xpress\bin + XPRS_LIB_Path: ${{ github.workspace }}\xpress\lib + # Indicates the location of the vcpkg as a Git submodule of the project repository. + VCPKG_ROOT: ${{ github.workspace }}/vcpkg + outputs: + zip_name: ${{ steps.zip_name.outputs.zip_name }} + steps: + - uses: actions/checkout@v3 + with: + submodules: true + + - name: Enable git longpaths + run: git config --system core.longpaths true + + - name: Checkout xpressmp linux + if: matrix.xprs == 'XPRESS-ON' + uses: actions/checkout@v3 + with: + repository: rte-france/xpress-mp-temp + path: ${{ env.XPRESSDIR }} + ref: 8.13a + token: ${{ secrets.AS_TOKEN }} + + - name: Get release + if: github.event_name == 'release' && github.event.action == 'created' + id: get_release + uses: + bruceadams/get-release@main + + - name: Set up Python + uses: actions/setup-python@v4 + with: + python-version: '3.x' + + # Restore both vcpkg and its artifacts from the GitHub cache service. + - name: Restore vcpkg and its artifacts. + uses: actions/cache@v3 + with: + # The first path is the location of vcpkg (it contains the vcpkg executable and data files). + # The other paths starting with '!' are exclusions: they contain termporary files generated during the build of the installed packages. + path: | + ${{ env.VCPKG_ROOT }} + !${{ env.VCPKG_ROOT }}/buildtrees + !${{ env.VCPKG_ROOT }}/packages + !${{ env.VCPKG_ROOT }}/downloads + # The key is composed in a way that it gets properly invalidated: this must happen whenever vcpkg's Git commit id changes, or the list of packages changes. In this case a cache miss must happen and a new entry with a new key with be pushed to GitHub the cache service. + # The key includes: hash of the vcpkg.json file, the hash of the vcpkg Git commit id, and the used vcpkg's triplet. The vcpkg's commit id would suffice, but computing an hash out it does not harm. + # Note: given a key, the cache content is immutable. If a cache entry has been created improperly, in order the recreate the right content the key must be changed as well, and it must be brand new (i.e. not existing already). + key: | + ${{ hashFiles( 'vcpkg.json' ) }}-${{ hashFiles( '.git/modules/vcpkg/HEAD' )}}-${{ matrix.triplet }}-invalidate + + - name: Install dependencies + run: | + python -m pip install --upgrade pip + pip install -r requirements-tests.txt + pip install -r requirements-ui.txt + + - name: Pre-requisites + shell: cmd + run: | + choco install wget zip unzip --no-progress + wget -nv https://github.com/microsoft/Microsoft-MPI/releases/download/v10.1.1/msmpisetup.exe + msmpisetup.exe -unattend + + - name: Read antares-solver version + id: antares-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_version' + + - name: Read antares-xpansion version + id: antares-xpansion-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_xpansion_version' + + - name: Read antares-deps version + id: antares-deps-version + uses: ./.github/actions/read-json-value + with: + path: 'antares-version.json' + key: 'antares_deps_version' + + - name: Install deps with VCPKG + run: | + cd vcpkg + ./bootstrap-vcpkg.sh + vcpkg install --triplet ${{matrix.triplet}} + rm -rf buildtrees + rm -rf packages + rm -rf downloads + shell: bash + + - name: Compile tbb + uses: ./.github/workflows/compile-tbb + with: + cmake: 'cmake' + + - name: Download pre-compiled librairies + uses: ./.github/workflows/download-extract-precompiled-libraries-zip + with: + antares-deps-version: ${{steps.antares-deps-version.outputs.result}} + antares-version: ${{steps.antares-version.outputs.result}} + os: ${{matrix.os}} + + - name: Download userguide + uses: actions/download-artifact@v3 + with: + name: user-guide + path: docs/ + + - name: Expand xpress value in env + #I can't seem to expand the variable in the cmake command line so export it in env + shell: bash + run: | + [[ ${{ matrix.xprs }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" + echo "XPRESS_VALUE=$XPRESS_VALUE" >> $GITHUB_ENV + + - name: Configure + #Inverted ternary : @({'condition is false'},{'condition is true'})[$condition] => ({true}, {false})[!$condition] + run: | + $pwd=Get-Location + cmake -B _build -S . -DDEPS_INSTALL_DIR=rte-antares-deps-Release -DCMAKE_PREFIX_PATH="$pwd\rte-antares-${{steps.antares-version.outputs.result}}-installer-64bits" -DBUILD_TESTING=ON -DCMAKE_BUILD_TYPE=Release -DCMAKE_TOOLCHAIN_FILE="${{env.VCPKG_ROOT}}/scripts/buildsystems/vcpkg.cmake" -DVCPKG_TARGET_TRIPLET=${{ matrix.triplet }} -DCMAKE_INSTALL_PREFIX=_install -DBUILD_UI=ON -DUSER_GUIDE_PATH="docs/${{ needs.userguide.outputs.pdf-name }}" -DXPRESS=${{ env.XPRESS_VALUE }} -DXPRESS_ROOT="${{ env.XPRESSDIR }}" + + - name: Build + run: | + cmake --build _build --config Release -j2 --target install + + - name: Running unit tests + shell: cmd + run: | + set PATH=%PATH%;C:\Program Files\Microsoft MPI\Bin\ + set PATH=%PATH%;${{ env.XPRESS }} + cd _build + ctest -C Release --output-on-failure -L "medium|unit|benders|lpnamer" + + - name: Create installer .zip + shell: bash + run: | + cd _build + cpack -G ZIP + export ZIP_NAME=$(ls *.zip) + echo "ZIP_NAME=$ZIP_NAME" >> $GITHUB_ENV + + - name: set name variables + id: single_file_name + shell: bash + run: | + [[ ${{ matrix.xprs }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" + XPRS=${{ env.XPRESS_VALUE }} + [ $XPRS == "ON" ] && WITH_XPRS="-xpress" || WITH_XPRS="" + VERSION=${{steps.antares-xpansion-version.outputs.result}}${WITH_XPRS} + echo "VERSION_WITH_XPRESS=$VERSION" + echo "VERSION_WITH_XPRESS=$VERSION" >> $GITHUB_ENV + + - name: Upload installer + uses: actions/upload-artifact@v3 + with: + name: ${{env.ZIP_NAME}} + path: _build/${{env.ZIP_NAME}} + + - name: Create single file .zip + id: create-single-file + uses: ./.github/workflows/single-file-creation-zip + with: + antares-xpansion-version: ${{env.VERSION_WITH_XPRESS}} + + - name: Upload single file + uses: actions/upload-artifact@v3 + with: + name: ${{ steps.create-single-file.outputs.archive-name }} + path: ${{ steps.create-single-file.outputs.archive-path }} + + - id: zip_name + shell: bash + run: | + echo "zip_name=${{env.ZIP_NAME}}" >> "$GITHUB_OUTPUT" + echo "singlefile_name=${{steps.create-single-file.outputs.archive-name}}" >> "$GITHUB_OUTPUT" + + upload_asset_to_release: + if: github.event_name == 'release' && github.event.action == 'created' + runs-on: ubuntu-latest + needs: build + env: + ZIP_NAME: ${{needs.build.outputs.zip_name}} + SINGLEFILE_NAME: ${{needs.build.outputs.singlefile_name}} + steps: + - name: Get release + if: github.event_name == 'release' && github.event.action == 'created' + id: get_release + uses: bruceadams/get-release@main + + - name: Download Artifact + uses: actions/download-artifact@v3 + with: + name: $ZIP_NAME + path: . + + - name: Download Artifact + uses: actions/download-artifact@v3 + with: + name: $SINGLEFILE_NAME + path: . + + - name: Upload Release Asset + env: + GH_REPO: ${{ github.repository }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + run: | + gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} $ZIP_NAME + gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} $SINGLEFILE_NAME + + ######################## \ No newline at end of file