From 536efc7c5ecfd141dbe7969dfcab1649297b38b9 Mon Sep 17 00:00:00 2001
From: Jason Marechal <jason.marechal+github@gmail.com>
Date: Wed, 5 Jun 2024 10:50:37 +0200
Subject: [PATCH] Revert "Disable workflows"

This reverts commit 52494c35eee7401ad90c8ce1144e7484a402e6d9.
---
 .github/workflows/build_centos7.yml           | 200 +++++++++++
 .github/workflows/build_oracle8.yml           | 151 ++++++++
 .github/workflows/build_windows.yml           | 152 +++++++++
 .github/workflows/centos-release.yml          | 321 ++++++++++++++++++
 .../workflows/centos7-system-deps-build.yml   | 152 +++++++++
 .github/workflows/ol8-release.yml             | 284 ++++++++++++++++
 .github/workflows/publish_centos_docker.yml   |  27 ++
 .github/workflows/sonarcloud.yml              | 143 ++++++++
 .../workflows/windows-vcpkg-deps-build.yml    | 120 +++++++
 .github/workflows/windows-vcpkg.yml           | 284 ++++++++++++++++
 10 files changed, 1834 insertions(+)
 create mode 100644 .github/workflows/build_centos7.yml
 create mode 100644 .github/workflows/build_oracle8.yml
 create mode 100644 .github/workflows/build_windows.yml
 create mode 100644 .github/workflows/centos-release.yml
 create mode 100644 .github/workflows/centos7-system-deps-build.yml
 create mode 100644 .github/workflows/ol8-release.yml
 create mode 100644 .github/workflows/publish_centos_docker.yml
 create mode 100644 .github/workflows/sonarcloud.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 000000000..569b92aa4
--- /dev/null
+++ b/.github/workflows/build_centos7.yml
@@ -0,0 +1,200 @@
+name: Centos7 Build
+
+on:
+  merge_group:
+  push:
+    branches:
+      - develop
+      - dependabot/*
+  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@v44
+        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/xpansion-centos7
+          username: ${{ secrets.DOCKER_USERNAME }}
+          password: ${{ secrets.DOCKER_PASSWORD }}
+          workdir: docker
+          dockerfile: centos7-system-deps
+          cache: false
+          tags: latest,1.0.0
+
+  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@v4
+      - 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/xpansion-centos7'
+    strategy:
+      matrix:
+        xprs: [
+          # { value: XPRESS-ON, ref: 8.13a },
+          { value: XPRESS-ON, ref: 9.2.5 },
+          #{ value: 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
+      VCPKG_ROOT: ${{ github.workspace }}/vcpkg
+
+    steps:
+      - run: |
+          source /opt/rh/devtoolset-10/enable
+          echo $PATH >> $GITHUB_PATH
+      - name: Get release
+        if: github.event_name == 'release' && github.event.action == 'created'
+        id: get_release
+        uses: bruceadams/get-release@v1.3.2
+
+      - uses: actions/checkout@v3 #Keep at 3
+        with:
+          submodules: true
+
+      - run: |
+          yum install -y nodejs
+
+      - name: Setup cmake
+        uses: jwlawson/actions-setup-cmake@v1.13
+        with:
+          cmake-version: '3.28.x'
+
+      #Lukka's action doesn't work on runner.
+      #jwlawson's action doesn't work in ACT
+      #I left this here to quicly switch between one or the other
+      #      - uses: lukka/get-cmake@latest
+      #        with:
+      #          useLocalCache: false
+      #          useCloudCache: true
+
+      - name: Checkout xpressmp linux
+        uses: actions/checkout@v3 #keep v3
+        with:
+          token: ${{ secrets.AS_TOKEN }}
+          repository: rte-france/xpress-mp
+          path: ${{ env.XPRESSDIR }}
+          github-server-url: https://github.com
+          ref: ${{matrix.xprs.ref}}
+        if: matrix.xprs.value == 'XPRESS-ON'
+
+      - 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: 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
+
+      - name: Compile tbb
+        uses: ./.github/workflows/compile-tbb
+
+      - name: Install dependencies
+        run: |
+          pip3 install --upgrade pip
+          pip3 install wheel #Does not work in requirements
+          pip3 install -r requirements-tests.txt
+          pip3 install -r requirements-ui.txt
+
+      - name: vcpkg install
+        run: |
+          pushd vcpkg
+          git fetch --unshallow
+          ./bootstrap-vcpkg.sh
+          popd
+          vcpkg/vcpkg install
+
+      - name: Configure
+        run: |
+          [[ ${{ matrix.xprs.value }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" 
+          source /opt/rh/devtoolset-10/enable
+          cmake -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 }} \
+                 -DALLOW_RUN_AS_ROOT=ON \
+                 -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
+
+      - name: Build
+        run: |
+          cmake --build _build --config Release -j$(nproc)
+
+      - name: Running unit tests
+        timeout-minutes: 120
+        shell: bash
+        run: |
+          export PATH=${GITHUB_WORKSPACE}/vcpkg_installed/x64-linux/tools/openmpi/bin/:$PATH
+          export LD_LIBRARY_PATH=LD_LIBRARY_PATH:${{ env.XPRS_LIB_Path_CONTAINER }}
+          export XPRESS=${{ env.XPRESS_CONTAINER }}
+          cd _build
+          ctest -C Release --output-on-failure -L "unit|benders|lpnamer|medium"
diff --git a/.github/workflows/build_oracle8.yml b/.github/workflows/build_oracle8.yml
new file mode 100644
index 000000000..b9f6f2147
--- /dev/null
+++ b/.github/workflows/build_oracle8.yml
@@ -0,0 +1,151 @@
+name: Oracle 8 Build
+
+on:
+  merge_group:
+  push:
+    branches:
+      - develop
+      - dependabot/*
+  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@v4
+      - 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: [
+          # { value: XPRESS-ON, ref: 8.13a },
+          { value: XPRESS-ON, ref: 9.2.5 },
+          # { value: 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 wget rpm-build redhat-lsb-core openmpi-devel
+          dnf install -y unzip libuuid-devel gcc-toolset-10-toolchain python3-devel zlib-devel
+          #make gcc &co available system wide and "action wide"
+          source /opt/rh/gcc-toolset-10/enable
+          echo $PATH >> $GITHUB_PATH
+
+      - run: |
+          dnf module install -y nodejs:20/common
+
+      - uses: lukka/get-cmake@latest
+        with:
+          useLocalCache: false
+          useCloudCache: true
+
+      - uses: actions/checkout@v4
+        with:
+          submodules: true
+
+      - name: Checkout xpressmp linux
+        uses: actions/checkout@v4
+        with:
+          token: ${{ secrets.AS_TOKEN }}
+          repository: rte-france/xpress-mp
+          path: ${{ env.XPRESSDIR }}
+          github-server-url: https://github.com
+          ref: ${{matrix.xprs.ref}}
+        if: matrix.xprs.value == 'XPRESS-ON'
+
+      - name: Set up Python
+        run: |
+          dnf update -y
+          dnf install -y python3 python3-pip
+          pip3 install wheel #Too late to install in requirements.txt
+          pip3 install -r requirements-tests.txt
+
+      - 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 TBB
+        uses: ./.github/workflows/compile-tbb
+
+      - run: |
+          mkdir -p ${{ github.workspace }}/vcpkg_cache
+
+      - name: vcpkg install
+        run: |
+          pushd vcpkg
+          git fetch --unshallow
+          ./bootstrap-vcpkg.sh
+          popd
+          vcpkg/vcpkg install
+
+      - name: Configure
+        run: |
+          [[ ${{ matrix.xprs.value }} == "XPRESS-ON" ]] && XPRESS_VALUE="ON" || XPRESS_VALUE="OFF" 
+          cmake -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 }} \
+                 -DALLOW_RUN_AS_ROOT=ON \
+                 -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
+
+      - name: Build
+        run: |
+          cmake --build _build --config Release -j$(nproc)
+
+      - name: Running unit tests
+        timeout-minutes: 120
+        shell: bash
+        run: |
+          export PATH=${GITHUB_WORKSPACE}/vcpkg_installed/x64-linux/tools/openmpi/bin/:$PATH
+          export LD_LIBRARY_PATH=LD_LIBRARY_PATH:${{ env.XPRS_LIB_Path_CONTAINER }}
+          export XPRESS=${{ env.XPRESS_CONTAINER }}
+          cd _build
+          ctest -C Release --output-on-failure -L "unit|benders|lpnamer|medium"
diff --git a/.github/workflows/build_windows.yml b/.github/workflows/build_windows.yml
new file mode 100644
index 000000000..a41422727
--- /dev/null
+++ b/.github/workflows/build_windows.yml
@@ -0,0 +1,152 @@
+name: Windows build
+
+on:
+  merge_group:
+  push:
+    branches:
+      - main
+      - develop
+      - dependabot/*
+  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: [ #{ value: XPRESS-ON, ref: 8.13a },
+          { value: XPRESS-ON, ref: 9.2.5 },
+          #{ value: 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@v4
+        with:
+          submodules: true
+
+      - name: Checkout xpressmp linux
+        if: matrix.xprs.value == 'XPRESS-ON'
+        uses: actions/checkout@v4
+        with:
+          repository: rte-france/xpress-mp-temp
+          path: ${{ env.XPRESSDIR }}
+          ref: ${{matrix.xprs.ref}}
+          token: ${{ secrets.AS_TOKEN }}
+
+      - name: Get release
+        if: github.event_name == 'release' && github.event.action == 'created'
+        id: get_release
+        uses:
+          bruceadams/get-release@v1.3.2
+
+      - name: Set up Python
+        uses: actions/setup-python@v5
+        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@v4
+        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
+          git fetch --unshallow
+          ./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.value }} == "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 }}
+      - name: Build
+        run: |
+          cmake --build _build --config Release -j4
+
+      - name: Running unit tests
+        timeout-minutes: 120
+        shell: cmd
+        run: |
+          set PATH=%PATH%;C:\Program Files\Microsoft MPI\Bin
+          set PATH=%PATH%;${{ env.XPRESS }}
+          set XPRESSDIR=${{ env.XPRESSDIR }}
+          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 000000000..99c0a8804
--- /dev/null
+++ b/.github/workflows/centos-release.yml
@@ -0,0 +1,321 @@
+name: Centos7 release
+
+on:
+  push:
+    branches:
+      - main
+      - develop
+      - ci/*
+      - dependabot/*
+  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@v44
+        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/xpansion-centos7
+          username: ${{ secrets.DOCKER_USERNAME }}
+          password: ${{ secrets.DOCKER_PASSWORD }}
+          workdir: docker
+          dockerfile: centos7-system-deps
+          cache: false
+          tags: latest,1.0.0
+
+  userguide:
+    runs-on: ubuntu-latest
+    outputs:
+      pdf-name: ${{ steps.create-user-guide.outputs.pdf-name }}
+
+    steps:
+      - uses: actions/checkout@v4
+
+      - 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 #aligned with download in centOS job
+        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@v4
+      - 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/xpansion-centos7'
+    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@v8
+
+      - name: Checkout
+        uses: actions/checkout@v3 #keep v3
+        with:
+          submodules: true
+
+      - run: |
+          source /opt/rh/devtoolset-10/enable
+          echo $PATH >> $GITHUB_PATH
+
+      - run: |
+          yum install -y nodejs
+
+      - name: Setup cmake
+        uses: jwlawson/actions-setup-cmake@v1.13
+        with:
+          cmake-version: '3.28.x'
+
+      - 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
+
+      - name: Compile tbb
+        uses: ./.github/workflows/compile-tbb
+
+      - name: Install dependencies
+        run: |
+          pip3 install --upgrade pip
+          pip3 install wheel #Does not work in requirements
+          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: 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: vcpkg install
+        run: |
+          pushd vcpkg
+          git fetch --unshallow
+          ./bootstrap-vcpkg.sh
+          popd
+          vcpkg/vcpkg install
+
+      - 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-10/enable
+          cmake -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} \
+                 -DALLOW_RUN_AS_ROOT=ON \
+                 -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
+
+      - name: Build
+        shell: bash
+        run: |
+          cmake --build _build --config Release -j$(nproc)
+          cd _build
+          cmake --install .
+
+      - name: Running unit tests
+        timeout-minutes: 120
+        shell: bash
+        run: |
+          export PATH=${GITHUB_WORKSPACE}/vcpkg_installed/x64-linux/tools/openmpi/bin/:$PATH
+          export LD_LIBRARY_PATH=LD_LIBRARY_PATH:${{ env.XPRS_LIB_Path_CONTAINER }}
+          export XPRESS=${{ env.XPRESS_CONTAINER }}
+          cd _build
+          ctest -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"
+          cpack -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: ${{ env.ZIP_NAME}}
+          path: .
+
+      - name: Download Artifact
+        uses: actions/download-artifact@v3
+        with:
+          name: ${{env.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 }} ${{env.ZIP_NAME}}
+          gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} ${{env.SINGLEFILE_NAME}}
+
+      ########################
diff --git a/.github/workflows/centos7-system-deps-build.yml b/.github/workflows/centos7-system-deps-build.yml
new file mode 100644
index 000000000..39cc66dd0
--- /dev/null
+++ b/.github/workflows/centos7-system-deps-build.yml
@@ -0,0 +1,152 @@
+name: Centos7 CI (build dependencies)
+
+on:
+  push:
+    branches:
+      - main
+      - develop
+      - release/*
+      - ci/*
+      - dependabot/*
+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@v44
+        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/xpansion-centos7
+          username: ${{ secrets.DOCKER_USERNAME }}
+          password: ${{ secrets.DOCKER_PASSWORD }}
+          workdir: docker
+          dockerfile: centos7-system-deps
+          cache: false
+          tags: latest,1.0.0
+
+  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@v4
+      - 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/xpansion-centos7'
+
+    steps:
+      - id: branch-name
+        uses: tj-actions/branch-names@v8
+
+      - uses: actions/checkout@v3 #keep v3
+        with:
+          submodules: true
+
+      - run: |
+          source /opt/rh/devtoolset-10/enable
+          echo $PATH >> $GITHUB_PATH
+
+      - name: Install dependencies
+        run: |
+          pip3 install wheel #Does not work in requirements
+          pip3 install -r requirements-tests.txt
+
+      - run: |
+          yum install -y nodejs
+
+      - name: Setup cmake
+        uses: jwlawson/actions-setup-cmake@v1.13
+        with:
+          cmake-version: '3.28.x'
+
+      - name: Compile tbb
+        uses: ./.github/workflows/compile-tbb
+
+      - 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: vcpkg install
+        run: |
+          pushd vcpkg
+          git fetch --unshallow
+          ./bootstrap-vcpkg.sh
+          popd
+          vcpkg/vcpkg install
+
+      - name: Configure
+        run: |
+          cmake -B _build -S . \
+          -DDEPS_INSTALL_DIR=rte-antares-deps-Release \
+          -DBUILD_TESTING=ON -DCMAKE_BUILD_TYPE=Release  -DCMAKE_INSTALL_PREFIX=_install -DBUILD_UI=ON -DALLOW_RUN_AS_ROOT=ON -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
+
+      - name: Build
+        run: |
+          cmake --build _build --config Release -j$(nproc)
+          cd _build
+          cmake --install .
+
+      - name: Running unit tests
+        run: |
+          export PATH=${GITHUB_WORKSPACE}/vcpkg_installed/x64-linux/tools/openmpi/bin/:$PATH
+          cd _build
+          ctest -C Release --output-on-failure -L "unit|benders|lpnamer|medium"
+
+      - name: .tar.gz creation
+        run: |
+          cd _build
+          cpack -G TGZ
+
+      - id: create-single-file
+        name: Single file .tar.gz creation
+        uses: ./.github/workflows/single-file-creation-tgz
+        with:
+          antares-xpansion-version: ${{needs.version.outputs.antares-xpansion-version}}
diff --git a/.github/workflows/ol8-release.yml b/.github/workflows/ol8-release.yml
new file mode 100644
index 000000000..e74ec6537
--- /dev/null
+++ b/.github/workflows/ol8-release.yml
@@ -0,0 +1,284 @@
+name: Oracle-linux8 release
+
+on:
+  push:
+    branches:
+      - main
+      - develop
+      - ci/*
+      - dependabot/*
+  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@v4
+
+      - 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@v4
+        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@v4
+      - 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: [ userguide, versions ]
+    container: 'oraclelinux:8'
+    strategy:
+      matrix:
+        xprs: [
+          { value: XPRESS-ON, ref: 9.2.5 },
+          #{ value: 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@v8
+
+      - name: Install System
+        run: |
+          dnf install -y epel-release git wget rpm-build redhat-lsb-core
+          dnf install -y unzip libuuid-devel gcc-toolset-10-toolchain zlib-devel python3-devel
+          source /opt/rh/gcc-toolset-10/enable
+          echo $PATH >> $GITHUB_PATH
+
+      - name: Checkout
+        uses: actions/checkout@v4
+        with:
+          submodules: true
+
+      - run: |
+          dnf module install -y nodejs:20/common
+
+      - uses: lukka/get-cmake@latest
+        with:
+          useLocalCache: false
+          useCloudCache: true
+
+      - run: |
+          mkdir -p ${{ github.workspace }}/vcpkg_cache
+
+      - name: vcpkg install
+        run: |
+          pushd vcpkg
+          git fetch --unshallow
+          ./bootstrap-vcpkg.sh
+          popd
+          vcpkg/vcpkg install
+
+      - 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
+          #variant: -ortools-xpress
+
+      - name: Compile tbb
+        uses: ./.github/workflows/compile-tbb
+
+      - name: Install dependencies
+        run: |
+          pip3 install --upgrade pip
+          pip3 install wheel #Does not work in requirements
+          pip3 install -r requirements-tests.txt
+          pip3 install -r requirements-ui.txt
+
+      - name: Download userguide
+        uses: actions/download-artifact@v4
+        with:
+          name: user-guide
+          path: docs/
+
+      - name: Checkout xpressmp linux
+        uses: actions/checkout@v4
+        with:
+          token: ${{ secrets.AS_TOKEN }}
+          repository: rte-france/xpress-mp
+          path: ${{ env.XPRESSDIR }}
+          github-server-url: https://github.com
+          ref: ${{matrix.xprs.ref}}
+        if: matrix.xprs.value == 'XPRESS-ON'
+
+      - name: Configure
+        shell: bash
+        run: |
+          if [ ${{ matrix.xprs.value }} == "XPRESS-ON" ]; then
+          export XPRESS_VALUE="ON"
+          else
+          export XPRESS_VALUE="OFF"
+          fi
+          source /opt/rh/gcc-toolset-10/enable
+          export LD_LIBRARY_PATH=/usr/lib64/openmpi/lib:$LD_LIBRARY_PATH
+          export PATH=/usr/lib64/openmpi/bin:$PATH
+          cmake -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} \
+                 -DALLOW_RUN_AS_ROOT=ON \
+                 -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
+
+      - name: Build
+        shell: bash
+        run: |
+          cmake --build _build --config Release -j$(nproc)
+          cd _build
+          cmake --install .
+
+      - name: Running unit tests
+        timeout-minutes: 120
+        shell: bash
+        run: |
+          export PATH=${GITHUB_WORKSPACE}/vcpkg_installed/x64-linux/tools/openmpi/bin/:$PATH
+          export LD_LIBRARY_PATH=LD_LIBRARY_PATH:${{ env.XPRS_LIB_Path_CONTAINER }}
+          export XPRESS=${{ env.XPRESS_CONTAINER }}
+          cd _build
+          ctest -C Release --output-on-failure -L "unit|benders|lpnamer|medium"
+
+      - name: set name variables
+        id: single_file_name
+        shell: bash
+        run: |
+          if [ ${{ matrix.xprs.value }} == "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}}-OracleServer-8.9"
+          cpack -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@v4
+        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@v4
+        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@v4
+        with:
+          name: ${{env.ZIP_NAME}}
+          path: .
+
+      - name: Download Artifact
+        uses: actions/download-artifact@v4
+        with:
+          name: ${{env.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 }} ${{env.ZIP_NAME}}
+          gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} ${{env.SINGLEFILE_NAME}}
+
+      ########################
\ No newline at end of file
diff --git a/.github/workflows/publish_centos_docker.yml b/.github/workflows/publish_centos_docker.yml
new file mode 100644
index 000000000..53284c09d
--- /dev/null
+++ b/.github/workflows/publish_centos_docker.yml
@@ -0,0 +1,27 @@
+name: Publish docker image
+
+on:
+  workflow_dispatch:
+
+env:
+  GITHUB_TOKEN: ${{ github.token }}
+
+jobs:
+  docker_publish:
+    runs-on: ubuntu-latest
+    steps:
+      - uses: actions/checkout@master
+        with:
+          fetch-depth: 0
+
+      - name: Docker file push
+        id: docker_push
+        uses: elgohr/Publish-Docker-Github-Action@main
+        with:
+          name: antaresrte/xpansion-centos7
+          username: ${{ secrets.DOCKER_USERNAME }}
+          password: ${{ secrets.DOCKER_PASSWORD }}
+          workdir: docker
+          dockerfile: centos7-system-deps
+          cache: false
+          tags: latest,1.0.0
\ No newline at end of file
diff --git a/.github/workflows/sonarcloud.yml b/.github/workflows/sonarcloud.yml
new file mode 100644
index 000000000..59eba6eae
--- /dev/null
+++ b/.github/workflows/sonarcloud.yml
@@ -0,0 +1,143 @@
+name: SonarCloud
+
+on:
+  push:
+    branches:
+      - main
+      - develop
+      - release/*
+      - dependabot/*
+  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 ]
+
+    steps:
+
+      - uses: actions/checkout@v4
+        with:
+          fetch-depth: 0
+
+      - id: sonar-install
+        name: Install sonar-scanner and build-wrapper
+        uses: SonarSource/sonarcloud-github-c-cpp@v2
+
+      - name: ccache
+        uses: hendrikmuhs/ccache-action@v1.2
+        with:
+          key: ${{ matrix.os }}-${{ matrix.xprs.value }}
+
+      - name: Set up Python
+        uses: actions/setup-python@v5
+        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
+          sudo apt-get install g++-10 gcc-10
+          cd /usr/src/googletest/
+          sudo cmake .
+          sudo cmake --build . --target install
+
+      - name: Update alternatives
+        #mpicxx  uses "g++" so we need g++ to be symbolic link to g++-10
+        run: |
+          sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-10 10
+          sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-10 10
+          sudo update-alternatives --install /usr/bin/cc cc /usr/bin/gcc 30
+          sudo update-alternatives --set cc /usr/bin/gcc
+          sudo update-alternatives --install /usr/bin/c++ c++ /usr/bin/g++ 30
+          sudo update-alternatives --set c++ /usr/bin/g++
+
+      - 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: Init submodule
+        run: |
+          git submodule update --init --recursive .
+
+      - name: Configure
+        shell: bash
+        run: |
+          cmake -B _build -S . \
+          -DCMAKE_C_COMPILER_LAUNCHER=ccache \
+          -DCMAKE_C_COMPILER=/usr/bin/gcc-10 \
+          -DCMAKE_CXX_COMPILER_LAUNCHER=ccache \
+          -DCMAKE_CXX_COMPILER=/usr/bin/g++-10 \
+          -DDEPS_INSTALL_DIR=rte-antares-deps-Release \
+          -DCODE_COVERAGE=ON \
+          -DBUILD_TESTING=ON \
+          -DBUILD_antares_solver=OFF \
+          -DCMAKE_BUILD_TYPE=Release \
+          -DCMAKE_INSTALL_PREFIX=_install \
+          -DCMAKE_EXPORT_COMPILE_COMMANDS=ON \
+          -DCMAKE_TOOLCHAIN_FILE=vcpkg/scripts/buildsystems/vcpkg.cmake
+
+      - run: |
+          sed -i 's#: ".*/mpicxx #: "g++ #' $GITHUB_WORKSPACE/_build/compile_commands.json
+
+      - name: Build
+        run: cmake --build _build --config Release -j$(nproc)
+
+      - 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_HOST_URL }}"
\ No newline at end of file
diff --git a/.github/workflows/windows-vcpkg-deps-build.yml b/.github/workflows/windows-vcpkg-deps-build.yml
new file mode 100644
index 000000000..a15055b59
--- /dev/null
+++ b/.github/workflows/windows-vcpkg-deps-build.yml
@@ -0,0 +1,120 @@
+name: Windows CI full build
+
+on:
+  push:
+    branches:
+      - main
+      - develop
+      - release/*
+      - ci/*
+      - dependabot/*
+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@v4
+        with:
+          submodules: true
+
+      - name: Enable git longpaths
+        run: git config --system core.longpaths true
+
+      - name: Set up Python
+        uses: actions/setup-python@v5
+        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@v4
+        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
+          git fetch --unshallow
+          ./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 -j4
+          cd _build
+          cmake --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 000000000..9cb96f8b2
--- /dev/null
+++ b/.github/workflows/windows-vcpkg.yml
@@ -0,0 +1,284 @@
+name: Windows release
+
+on:
+  push:
+    branches:
+      - main
+      - develop
+      - ci/*
+      - dependabot/*
+  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@v4
+
+      - 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@v4
+        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 }}
+      singlefile_name: ${{steps.zip_name.outputs.singlefile_name}}
+    steps:
+      - uses: actions/checkout@v4
+        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@v4
+        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@v5
+        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@v4
+        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
+          git fetch --unshallow
+          ./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@v4
+        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 }}
+
+      - name: Build
+        run: |
+          cmake --build _build --config Release -j4
+          cd _build
+          cmake --install .
+
+      - name: Running unit tests
+        shell: cmd
+        run: |
+          set PATH=%PATH%;C:\Program Files\Microsoft MPI\Bin\
+          set PATH=%PATH%;${{ env.XPRESS }}
+          set XPRESSDIR=${{ env.XPRESSDIR }}
+          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@v4
+        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@v4
+        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@v4
+        with:
+          name: ${{env.ZIP_NAME}}
+          path: .
+
+      - name: Download Artifact
+        uses: actions/download-artifact@v4
+        with:
+          name: ${{env.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 }} ${{env.ZIP_NAME}}
+          gh release upload --repo ${{env.GH_REPO}} ${{ steps.get_release.outputs.tag_name }} ${{env.SINGLEFILE_NAME}}
+
+      ########################
\ No newline at end of file