From c131021b021bdef5abea88df29890b43b27cb5ee Mon Sep 17 00:00:00 2001 From: Joris Mancini <53527338+TheMaskedTurtle@users.noreply.github.com> Date: Thu, 24 Oct 2024 14:43:59 +0200 Subject: [PATCH] chore: switch to common automated workflows from powsybl (#21) Signed-off-by: Joris Mancini --- .github/workflows/build.yml | 21 ++++++++++++ .github/workflows/maven.yml | 61 ----------------------------------- .github/workflows/patch.yml | 24 ++++++++++++++ .github/workflows/release.yml | 27 ++++++++++++++++ pom.xml | 2 +- 5 files changed, 73 insertions(+), 62 deletions(-) create mode 100644 .github/workflows/build.yml delete mode 100644 .github/workflows/maven.yml create mode 100644 .github/workflows/patch.yml create mode 100644 .github/workflows/release.yml diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml new file mode 100644 index 0000000..19ffae2 --- /dev/null +++ b/.github/workflows/build.yml @@ -0,0 +1,21 @@ +name: CI + +on: + push: + branches: + - 'main' + pull_request: + +jobs: + build: + uses: powsybl/github-ci/.github/workflows/build-generic.yml@baf0d2ed84b70d359132693880d5e530cd93f168 + with: + sonarOrganization: gridsuite + sonarProjectKey: org.gridsuite:case-import-server + dockerImage: docker.io/gridsuite/case-import-server + dockerUsername: gridsuiteci + eventType: case_import_server_updated + secrets: + sonar-token: ${{ secrets.SONAR_TOKEN }} + docker-token: ${{ secrets.DOCKERHUB_TOKEN }} + repo-token: ${{ secrets.REPO_ACCESS_TOKEN }} diff --git a/.github/workflows/maven.yml b/.github/workflows/maven.yml deleted file mode 100644 index 65c6071..0000000 --- a/.github/workflows/maven.yml +++ /dev/null @@ -1,61 +0,0 @@ -name: CI - -on: - push: - branches: - - 'main' - tags: - - 'v[0-9]*' - pull_request: - -jobs: - build: - - runs-on: ubuntu-latest - - steps: - - name: Set up JDK 17 - uses: actions/setup-java@v1 - with: - java-version: 17 - - - name: Checkout sources - uses: actions/checkout@v1 - - - name: Build with Maven - run: mvn --batch-mode -P jacoco,perform-integration-test install - - - name: Run SonarCloud analysis - run: > - mvn --batch-mode -DskipTests sonar:sonar - -Dsonar.host.url=https://sonarcloud.io - -Dsonar.organization=gridsuite - -Dsonar.projectKey=org.gridsuite:case-import-server - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} - - - name: Build Docker image - Main - if: github.ref == 'refs/heads/main' - run: > - mvn --batch-mode deploy -DskipTests -Dmaven.install.skip -Dmaven.deploy.skip -Dpowsybl.docker.deploy - -Djib.httpTimeout=60000 - -Djib.to.image=docker.io/gridsuite/case-import-server - -Djib.to.auth.username=gridsuiteci - -Djib.to.auth.password=${{ secrets.DOCKERHUB_TOKEN }} - - - name: Build Docker image - Tag - if: startsWith(github.ref, 'refs/tags/') - run: > - mvn --batch-mode deploy -DskipTests -Dmaven.install.skip -Dmaven.deploy.skip -Dpowsybl.docker.deploy - -Djib.httpTimeout=60000 - -Djib.to.image=docker.io/gridsuite/case-import-server:${GITHUB_REF_NAME#v} - -Djib.to.auth.username=gridsuiteci - -Djib.to.auth.password=${{ secrets.DOCKERHUB_TOKEN }} - - - name: Broadcast update event - if: github.ref == 'refs/heads/main' - uses: gridsuite/broadcast-event@main - with: - token: ${{ secrets.REPO_ACCESS_TOKEN }} - event-type: case_import_server_updated diff --git a/.github/workflows/patch.yml b/.github/workflows/patch.yml new file mode 100644 index 0000000..25cc53c --- /dev/null +++ b/.github/workflows/patch.yml @@ -0,0 +1,24 @@ +name: Patch + +on: + workflow_dispatch: + inputs: + releaseVersion: + description: version to patch (vX.X) + required: true + +jobs: + run-patch: + uses: powsybl/github-ci/.github/workflows/patch-generic.yml@baf0d2ed84b70d359132693880d5e530cd93f168 + with: + githubappId: ${{ vars.GRIDSUITE_ACTIONS_APPID }} + sonarOrganization: gridsuite + sonarProjectKey: org.gridsuite:case-import-server + dockerImage: docker.io/gridsuite/case-import-server + dockerUsername: gridsuiteci + releaseVersion: ${{ github.event.inputs.releaseVersion }} + secrets: + githubappPrivateKey: ${{ secrets.GRIDSUITE_ACTIONS_SECRET }} + sonar-token: ${{ secrets.SONAR_TOKEN }} + docker-token: ${{ secrets.DOCKERHUB_TOKEN }} + diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..b54dc7d --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,27 @@ +name: Release + +on: + workflow_dispatch: + inputs: + releaseVersion: + description: Release version (vX.X) + required: true + gitReference: + description: SHA of the commit from where to release or branch name + required: true + +jobs: + run-release: + uses: powsybl/github-ci/.github/workflows/release-generic.yml@baf0d2ed84b70d359132693880d5e530cd93f168 + with: + githubappId: ${{ vars.GRIDSUITE_ACTIONS_APPID }} + sonarOrganization: gridsuite + sonarProjectKey: org.gridsuite:case-import-server + dockerImage: docker.io/gridsuite/case-import-server + dockerUsername: gridsuiteci + releaseVersion: ${{ github.event.inputs.releaseVersion }} + gitReference: ${{ github.event.inputs.gitReference }} + secrets: + githubappPrivateKey: ${{ secrets.GRIDSUITE_ACTIONS_SECRET }} + sonar-token: ${{ secrets.SONAR_TOKEN }} + docker-token: ${{ secrets.DOCKERHUB_TOKEN }} diff --git a/pom.xml b/pom.xml index 94b7c22..22bf06e 100644 --- a/pom.xml +++ b/pom.xml @@ -21,7 +21,7 @@ org.gridsuite gridsuite-case-import-server - 1.0.0-SNAPSHOT + 2.8.0-SNAPSHOT jar Case import server