From 67467a732adfe0f6e4d35da39a01c06c91564e84 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jason=20Mar=C3=A9chal?= <45510813+JasonMarechal25@users.noreply.github.com> Date: Thu, 11 Jan 2024 16:27:41 +0100 Subject: [PATCH] Oracle8 build (#664) Add new workflow to build on oracle 8 platform. --------- Co-authored-by: abdoulbari zakir <32519851+a-zakir@users.noreply.github.com> --- .github/workflows/build_oracle8.yml | 145 +++++++++++++++++++++ .github/workflows/compile-boost/action.yml | 1 + .github/workflows/compile-tbb/action.yml | 6 +- antares-version.json | 2 +- requirements.txt | 1 + 5 files changed, 152 insertions(+), 3 deletions(-) create mode 100644 .github/workflows/build_oracle8.yml diff --git a/.github/workflows/build_oracle8.yml b/.github/workflows/build_oracle8.yml new file mode 100644 index 000000000..8814e793c --- /dev/null +++ b/.github/workflows/build_oracle8.yml @@ -0,0 +1,145 @@ +name: Oracle 8 Build + +on: + merge_group: + push: + branches: + - develop + pull_request: + release: + types: [ created ] + +env: + GITHUB_TOKEN: ${{ github.token }} + +jobs: + 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: + name: Build + runs-on: ubuntu-latest + container: 'oraclelinux:8' + strategy: + matrix: + xprs: [ XPRESS-ON, XPRESS-OFF ] + needs: [ versions ] + 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: Install System + run: | + dnf install -y epel-release git cmake wget rpm-build redhat-lsb-core openmpi-devel + dnf install -y unzip libuuid-devel boost-test boost-devel gcc-toolset-9-toolchain zlib-devel python3-devel + + - 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.13 + if: matrix.xprs == 'XPRESS-ON' + + - name: Set up Python + run: | + dnf update -y + dnf install -y python3 python3-pip + + - run: + echo ${{needs.versions.outputs.antares-deps-version}} + + - 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: Oracle8 + os-full-name: OracleServer-8.9 + + - name: Compile Boost + uses: ./.github/workflows/compile-boost + with: + prefix: "../rte-antares-deps-Release/" + + - name: Compile TBB + uses: ./.github/workflows/compile-tbb + + - name: Install dependencies + run: | + source /opt/rh/gcc-toolset-9/enable + pip3 install -r requirements-tests.txt + + - name: Configure + run: | + [[ ${{ matrix.xprs }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" + source /opt/rh/gcc-toolset-9/enable + dnf install jsoncpp-devel + 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=OFF \ + -DXPRESS=${{ env.XPRESS_VALUE }} \ + -DXPRESS_ROOT=${{ env.XPRESSDIR }} \ + -DALLOW_RUN_AS_ROOT=ON + + + - name: Build + run: | + source /opt/rh/gcc-toolset-9/enable + export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH + export PATH=/usr/lib64/openmpi/bin:$PATH + cmake --build _build --config Release -j2 + + - 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" diff --git a/.github/workflows/compile-boost/action.yml b/.github/workflows/compile-boost/action.yml index 9d25a87a0..100430f10 100644 --- a/.github/workflows/compile-boost/action.yml +++ b/.github/workflows/compile-boost/action.yml @@ -10,6 +10,7 @@ runs: - id: install-boost shell: bash run: | + source /opt/rh/gcc-toolset-9/enable || true export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH export PATH=/usr/lib64/openmpi/bin:$PATH wget https://github.com/boostorg/boost/releases/download/boost-1.81.0/boost-1.81.0.tar.gz diff --git a/.github/workflows/compile-tbb/action.yml b/.github/workflows/compile-tbb/action.yml index 0db04eb49..b5362154b 100644 --- a/.github/workflows/compile-tbb/action.yml +++ b/.github/workflows/compile-tbb/action.yml @@ -3,13 +3,15 @@ description: "tbb is required for execution policy (parallelization c++)." inputs: cmake: description: 'cmake version' - required: true + default: cmake + runs: using: "composite" steps: - id: install-tbb shell: bash - run: | + run: | + source /opt/rh/gcc-toolset-9/enable || true git clone https://github.com/wjakob/tbb.git cd tbb/build ${{ inputs.cmake }} .. diff --git a/antares-version.json b/antares-version.json index 52658ab5b..ce581d557 100644 --- a/antares-version.json +++ b/antares-version.json @@ -1,5 +1,5 @@ { - "antares_version": "8.8.0-rc2", + "antares_version": "8.8.0", "antares_version_executable": "8.8", "antares_xpansion_version": "1.2.0", "antares_deps_version": "2.0.7", diff --git a/requirements.txt b/requirements.txt index 67d762f47..7b019ee7f 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,3 +1,4 @@ +wheel pyinstaller>=4.3 pyyaml dataclasses