From f1b38faeb85b0147e6ccb50d304c92e7148a9ae8 Mon Sep 17 00:00:00 2001
From: Mohammad Abudayyeh <47318409+moabu@users.noreply.github.com>
Date: Thu, 14 Nov 2024 11:35:16 +0300
Subject: [PATCH] ci: move jenkins operations to GH (#10082)
* ci: move jenkins operations to GH
* ci: update token
* ci: adjust to allow building one resource at a time
* ci: adjust to allow building one resource at a time
* ci: adjust to allow building one resource at a time
* ci: initial organization of jans workdfloes
---
.github/maven-settings.xml | 9 +
...build_image.yml => build-docker-image.yml} | 0
...htly-build.yml => build-nightly-build.yml} | 0
.github/workflows/build-test.yml | 266 ++++++++++++++++++
.github/workflows/build-wars.yml | 100 -------
.github/workflows/documenation_check.yml | 57 ----
.../workflows/jans_pycloud_build_package.yml | 63 -----
.github/workflows/lint-docs.yml | 37 +++
.../{flake8-lint.yml => lint-flak8.yml} | 0
.github/workflows/{docs.yml => ops-docs.yml} | 56 +++-
..._pr_issues.yml => ops-label-pr-issues.yml} | 0
...{pr-ref-issue.yml => ops-pr-ref-issue.yml} | 0
.../workflows/{sync.yml => ops-sync-tf.yml} | 0
.../{backport.yml => release-backport.yml} | 0
...ub_cache.yml => sanitary-github-cache.yml} | 0
...ow_runs.yml => sanitary-workflow-runs.yml} | 0
.../{codeql-analysis.yml => scan-codeql.yml} | 2 +-
...endency-review.yml => scan-dependency.yml} | 0
..._code_quality_check.yml => scan-sonar.yml} | 0
.../{scorecard.yml => security-scorecard.yml} | 0
...{test_cedarling.yml => test-cedarling.yml} | 0
...testcases.yml => test-jans-pycloudlib.yml} | 0
.../{microk8s.yml => test-microk8s.yml} | 2 +-
.../workflows/test_docker_linux_installer.yml | 136 ---------
agama/pom.xml | 5 +
automation/startjanssenmonolithdemo.sh | 24 +-
docker-jans-monolith/scripts/entrypoint.sh | 50 +++-
jans-auth-server/agama/engine/pom.xml | 5 +
jans-auth-server/agama/inboundID/pom.xml | 13 +
jans-auth-server/pom.xml | 10 +-
jans-bom/pom.xml | 5 +
jans-casa/app-fips/pom.xml | 2 +-
jans-casa/app/pom.xml | 2 +-
jans-casa/plugins/acct-linking/pom.xml | 13 +
jans-casa/plugins/bioid/pom.xml | 13 +
.../plugins/client-authorizations/pom.xml | 13 +
jans-casa/plugins/custom-branding/pom.xml | 13 +
jans-casa/plugins/email_2fa_core/pom.xml | 13 +
.../plugins/strong-authn-settings/pom.xml | 13 +
jans-casa/pom.xml | 13 +
jans-config-api/pom.xml | 5 +
jans-core/pom.xml | 5 +
jans-fido2/pom.xml | 5 +
.../job-scheduler/pom.xml | 8 +
jans-keycloak-integration/pom.xml | 5 +
jans-keycloak-link/pom.xml | 13 +
jans-link/pom.xml | 13 +
jans-link/server-fips/pom.xml | 8 +
jans-link/server/pom.xml | 8 +
jans-link/service/pom.xml | 8 +
jans-lock/lock-server/pom.xml | 5 +
jans-orm/pom.xml | 5 +
jans-scim/pom.xml | 5 +
53 files changed, 651 insertions(+), 377 deletions(-)
create mode 100644 .github/maven-settings.xml
rename .github/workflows/{docker_build_image.yml => build-docker-image.yml} (100%)
rename .github/workflows/{activate-nightly-build.yml => build-nightly-build.yml} (100%)
create mode 100644 .github/workflows/build-test.yml
delete mode 100644 .github/workflows/build-wars.yml
delete mode 100644 .github/workflows/documenation_check.yml
delete mode 100644 .github/workflows/jans_pycloud_build_package.yml
create mode 100644 .github/workflows/lint-docs.yml
rename .github/workflows/{flake8-lint.yml => lint-flak8.yml} (100%)
rename .github/workflows/{docs.yml => ops-docs.yml} (66%)
rename .github/workflows/{label_pr_issues.yml => ops-label-pr-issues.yml} (100%)
rename .github/workflows/{pr-ref-issue.yml => ops-pr-ref-issue.yml} (100%)
rename .github/workflows/{sync.yml => ops-sync-tf.yml} (100%)
rename .github/workflows/{backport.yml => release-backport.yml} (100%)
rename .github/workflows/{clean_github_cache.yml => sanitary-github-cache.yml} (100%)
rename .github/workflows/{delete_workflow_runs.yml => sanitary-workflow-runs.yml} (100%)
rename .github/workflows/{codeql-analysis.yml => scan-codeql.yml} (98%)
rename .github/workflows/{dependency-review.yml => scan-dependency.yml} (100%)
rename .github/workflows/{central_code_quality_check.yml => scan-sonar.yml} (100%)
rename .github/workflows/{scorecard.yml => security-scorecard.yml} (100%)
rename .github/workflows/{test_cedarling.yml => test-cedarling.yml} (100%)
rename .github/workflows/{testcases.yml => test-jans-pycloudlib.yml} (100%)
rename .github/workflows/{microk8s.yml => test-microk8s.yml} (97%)
delete mode 100644 .github/workflows/test_docker_linux_installer.yml
diff --git a/.github/maven-settings.xml b/.github/maven-settings.xml
new file mode 100644
index 00000000000..49e17ff1124
--- /dev/null
+++ b/.github/maven-settings.xml
@@ -0,0 +1,9 @@
+
+
+
+ github
+ ${env.GITHUB_ACTOR}
+ ${env.JANS_TOKEN}
+
+
+
\ No newline at end of file
diff --git a/.github/workflows/docker_build_image.yml b/.github/workflows/build-docker-image.yml
similarity index 100%
rename from .github/workflows/docker_build_image.yml
rename to .github/workflows/build-docker-image.yml
diff --git a/.github/workflows/activate-nightly-build.yml b/.github/workflows/build-nightly-build.yml
similarity index 100%
rename from .github/workflows/activate-nightly-build.yml
rename to .github/workflows/build-nightly-build.yml
diff --git a/.github/workflows/build-test.yml b/.github/workflows/build-test.yml
new file mode 100644
index 00000000000..f446cdda464
--- /dev/null
+++ b/.github/workflows/build-test.yml
@@ -0,0 +1,266 @@
+name: Janssen Build & Test
+
+on:
+ push:
+ branches:
+ - main
+ schedule:
+ - cron: '0 8 * * *'
+ pull_request:
+ branches:
+ - main
+ workflow_dispatch:
+ inputs:
+ project:
+ type: choice
+ options:
+ - "jans-bom"
+ - "jans-orm"
+ - "jans-core"
+ - "jans-lock/lock-server"
+ - "agama"
+ - "jans-auth-server"
+ - "jans-link"
+ - "jans-fido2"
+ - "jans-scim"
+ - "jans-keycloak-link"
+ - "jans-config-api"
+ - "jans-keycloak-integration"
+ - "jans-casa"
+ - "jans-bom jans-orm jans-core jans-lock/lock-server agama jans-auth-server jans-link jans-fido2 jans-scim jans-keycloak-link jans-config-api jans-keycloak-integration jans-casa"
+ description: 'Service'
+ required: true
+ default: "jans-bom jans-orm jans-core jans-lock/lock-server agama jans-auth-server jans-link jans-fido2 jans-scim jans-keycloak-link jans-config-api jans-keycloak-integration jans-casa"
+
+jobs:
+ prep-matrix:
+ runs-on: ubuntu-latest
+ outputs:
+ matrix: ${{ steps.set-matrix.outputs.matrix }}
+ steps:
+ - name: Harden Runner
+ uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
+ with:
+ egress-policy: audit
+ - id: set-matrix
+ run: |
+ projects="${{ github.event.inputs.project }}"
+ if [ -z "$projects" ]; then
+ projects="jans-bom jans-orm jans-core jans-lock/lock-server agama jans-auth-server jans-link jans-fido2 jans-scim jans-keycloak-link jans-config-api jans-keycloak-integration jans-casa"
+ fi
+ matrix="{\"include\":["
+ for project in $projects; do
+ matrix="$matrix{\"service\":\"$project\",\"maven_skip_tests\":true},"
+ done
+ matrix="${matrix%,}]}"
+ echo $matrix
+ echo "matrix=$matrix" >> $GITHUB_OUTPUT
+
+ build-with-disabled-tests:
+ runs-on: ubuntu-20.04
+ needs: prep-matrix
+ permissions:
+ contents: read
+ packages: write
+ env:
+ VERSION_NAME: main
+ MAVEN_SKIP_TESTS: true
+ PROFILE_NAME: "default"
+
+ strategy:
+ max-parallel: 1
+ matrix: ${{ fromJson(needs.prep-matrix.outputs.matrix) }}
+
+ steps:
+ - name: Harden Runner
+ uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
+ with:
+ egress-policy: audit
+ - name: Checkout code
+ uses: actions/checkout@v4
+ with:
+ ref: ${{ github.event.inputs.branch }}
+
+ - name: Set up Java 17
+ uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'adopt'
+
+ - name: Set up Maven
+ uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'adopt'
+ cache: 'maven'
+
+ - name: Build ${{ matrix.service }}
+ run: |
+ if [ "${{ github.event_name }}" == "pull_request" ]; then
+ mvn -f ${{ matrix.service }}/pom.xml -Dcfg=${{ env.PROFILE_NAME }} -Dmaven.test.skip=${{ matrix.maven_skip_tests }} clean install -Drevision=${{ github.head_ref }}-SNAPSHOT
+ else
+ mvn -f ${{ matrix.service }}/pom.xml -Dcfg=${{ env.PROFILE_NAME }} -Dmaven.test.skip=${{ matrix.maven_skip_tests }} clean install
+ fi
+
+ - name: Publish to GitHub Packages
+ run: mvn -B deploy -Dmaven.test.skip=${{ matrix.maven_skip_tests }} -Dcfg=${{ env.PROFILE_NAME }}
+ working-directory: ${{ matrix.service }}
+ env:
+ GITHUB_TOKEN: ${{ secrets.MOAUTO_WORKFLOW_TOKEN }}
+
+ - name: Archive results
+ if: always()
+ uses: actions/upload-artifact@v4
+ with:
+ name: build-results
+ path: ${{ matrix.service }}/target
+
+ - name: Send notification on failure
+ if: failure()
+ run: echo "Build failed"
+
+ cleanup:
+ if: github.event_name == 'push' && github.event.ref == 'refs/heads/main'
+ runs-on: ubuntu-20.04
+ steps:
+ - name: Harden Runner
+ uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
+ with:
+ egress-policy: audit
+ - name: Clean up PR assets
+ run: |
+ # List all SNAPSHOT versions
+ versions=$(curl -s -H "Authorization: token ${{ secrets.MOAUTO_WORKFLOW_TOKEN }}" "https://maven.pkg.github.com/JanssenProject/jans/maven-metadata.xml" | grep -oP '(?<=)[^<]+')
+
+ for version in $versions; do
+ if [[ $version == *-SNAPSHOT ]]; then
+ # Delete the version from GitHub Packages
+ curl -X DELETE -H "Authorization: token ${{ secrets.MOAUTO_WORKFLOW_TOKEN }}" "https://maven.pkg.github.com/JanssenProject/jans/io/jans/${{ matrix.service.project }}/$version"
+ fi
+ done
+
+ run-tests:
+ if: github.event_name == 'push' || github.event_name == 'pull_request' || (github.event_name == 'workflow_dispatch' && github.event.inputs.project == 'jans-bom, jans-orm, jans-core, jans-lock/lock-server, agama, jans-auth-server, jans-link, jans-fido2, jans-scim, jans-keycloak-link, jans-config-api, jans-keycloak-integration, jans-casa')
+ permissions: write-all
+ runs-on: ubuntu-20.04
+ env:
+ MAVEN_SKIP_TESTS: false
+ CONTAINER_NAME_SPANNER: ubuntu20-spanner
+ CONTAINER_NAME_CB: ubuntu20-couchbase
+ CONTAINER_NAME_LDAP: ubuntu20-ldap
+ CONTAINER_NAME_MYSQL: ubuntu20-mysql
+ CONTAINER_NAME_POSTGRESQL: ubuntu20-postgresql
+ DEVELOPMENT_BUILD: true
+ SKIP_FINDBUGS: true
+ DEPENDENCY_CHECK: true
+ VERSION_NAME: main
+ PROFILE_NAME: default
+ strategy:
+ max-parallel: 5
+ matrix:
+ persistence:
+ - "MYSQL"
+ - "PGSQL"
+ fail-fast: false
+ steps:
+ - name: Harden Runner
+ uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
+ with:
+ egress-policy: audit
+ - name: Checkout code
+ uses: actions/checkout@v4
+ with:
+ ref: ${{ github.event.inputs.branch }}
+
+ - name: Set up Java 17
+ uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'adopt'
+
+ - name: Set up Maven
+ uses: actions/setup-java@v4
+ with:
+ java-version: '17'
+ distribution: 'adopt'
+ cache: 'maven'
+
+ - name: Set up Go
+ uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0
+ with:
+ go-version: 1.18
+
+ - name: Import GPG key
+ id: import_gpg
+ uses: crazy-max/ghaction-import-gpg@01dd5d3ca463c7f10f7f4f7b4f177225ac661ee4 # v6.1.0
+ with:
+ gpg_private_key: ${{ secrets.MOAUTO_GPG_PRIVATE_KEY }}
+ passphrase: ${{ secrets.MOAUTO_GPG_PRIVATE_KEY_PASSPHRASE }}
+ git_user_signingkey: true
+ git_commit_gpgsign: true
+
+ - name: Configure Git
+ run: |
+ git config --global user.name "mo-auto"
+ git config --global user.email "54212639+mo-auto@users.noreply.github.com"
+ git config --global user.signingkey "${{ steps.import_gpg.outputs.keyid }}"
+ echo "${{ secrets.MOAUTO_WORKFLOW_TOKEN }}" | gh auth login --with-token
+
+ - name: Run Jans Monolith
+ env:
+ JANS_FQDN: demoexample.jans.io
+ EXT_IP: $(ifconfig eth0 | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')
+ JANS_BUILD_COMMIT: main
+ run: |
+ export ip=$(ifconfig eth0 | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')
+ sudo chmod a+x automation/startjanssenmonolithdemo.sh
+ sudo RUN_TESTS=true bash ./automation/startjanssenmonolithdemo.sh "demoexample.jans.io" "${{ matrix.persistence }}" "$ip" "${{ github.sha }}"
+
+ echo "generating rdbms docs for ${{ matrix.persistence-backends }}..."
+ git clone https://mo-auto:${{ secrets.MOAUTO_WORKFLOW_TOKEN }}@github.com/JanssenProject/jans.git
+ cd jans
+ git config pull.rebase true
+ git checkout -b cn-jans-update-${{ matrix.persistence-backends }}-auto-generated-docs || echo "Branch exists"
+ git pull origin cn-jans-update-${{ matrix.persistence-backends }}-auto-generated-docs || echo "Nothing to pull"
+ sudo bash ./automation/docs/generate-rdbms-docs.sh "$persistence" || echo "generating rdbms docs failed for ${{ matrix.persistence-backends }}!!!"
+ git add . || echo "generating rdbms docs failed !!!"
+ git commit -a -S -m "docs: auto-generated ${{ matrix.persistence-backends }} docs" || echo "Nothing to commit"
+ git push --set-upstream origin cn-jans-update-${{ matrix.persistence-backends }}-auto-generated-docs || echo "generating rdbms docs failed !!!"
+ MESSAGE="fix(docs): autogenerate ${{ matrix.persistence-backends }} RDBMS docs"
+ gh pr create --body "Auto generated RDBMS docs" --title "${MESSAGE}" || echo "PR exists"
+ cd ..
+ echo "generating rdbms docs for ${{ matrix.persistence-backends }} done"
+
+ export JANS_URL=https://demoexample.jans.io
+ export JANS_CLIENT_ID=9876baac-de39-4c23-8a78-674b59df8c09
+ export JANS_CLIENT_SECRET=1t5Fin3#security
+ export JANS_INSECURE_CLIENT=true
+ export TF_ACC=1
+ cd terraform-provider-jans
+ go install github.com/jstemmer/go-junit-report/v2@latest
+ go test -v 2>&1 ./... | go-junit-report > /tmp/reports/${{ matrix.persistence-backends }}report.xml
+ cd ..
+
+ - name: List Reports
+ run: |
+ ls /tmp/reports/
+
+ - name: Upload Test Results
+ uses: actions/upload-artifact@v4
+ with:
+ name: ${{ matrix.persistence }}-test-results
+ path: /tmp/reports
+
+ - name: Publish Test Report ${{ matrix.persistence }}
+ uses: starburstdata/action-testng-report@v1
+ with:
+ report_paths: /tmp/reports/${{ matrix.persistence }}*.xml
+ github_token: ${{ github.token }}
+ fail_if_empty: false
+
+ # - name: Publish Test Report Surefire
+ # uses: scacap/action-surefire-report@v1
+ # if: success() || failure()
+ # with:
+ # github_token: ${{ github.token }}
+ # report_paths: /tmp/reports/**.xml
\ No newline at end of file
diff --git a/.github/workflows/build-wars.yml b/.github/workflows/build-wars.yml
deleted file mode 100644
index 8446be62283..00000000000
--- a/.github/workflows/build-wars.yml
+++ /dev/null
@@ -1,100 +0,0 @@
-name: Build Wars
-on:
- workflow_dispatch:
- pull_request:
- branches:
- - main
- paths:
- - 'jans-keycloak-integration/**'
- - 'jans-keycloak-link/**'
- - 'agama/**'
- - 'jans-auth-server/**'
- - 'jans-lock/**'
- - 'jans-bom/**'
- - 'jans-config-api/**'
- - 'jans-core/**'
- - 'jans-fido2/**'
- - 'jans-orm/**'
- - 'jans-scim/**'
- - 'jans-link/**'
-
- push:
- branches:
- - main
- paths:
- - 'jans-keycloak-integration/**'
- - 'jans-keycloak-link/**'
- - 'agama/**'
- - 'jans-auth-server/**'
- - 'jans-lock/**'
- - 'jans-bom/**'
- - 'jans-config-api/**'
- - 'jans-core/**'
- - 'jans-fido2/**'
- - 'jans-orm/**'
- - 'jans-scim/**'
- - 'jans-link/**'
-jobs:
- build:
- if: github.repository == 'JanssenProject/jans'
- name: Build wars
- runs-on: ubuntu-latest
- continue-on-error: true
- strategy:
- max-parallel: 11
- matrix:
- fldrpath: ['jans-bom','agama','jans-fido2','jans-core','jans-auth-server','jans-orm','jans-config-api','jans-scim','jans-keycloak-integration','jans-link','jans-keycloak-link','jans-lock']
- steps:
- - name: Harden Runner
- uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
- with:
- egress-policy: audit
-
- - name : Variables
- run: |
- echo ${{ github.repository }}
- echo ${{ github.actor }}
-
- - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- with:
- repository: ${{ github.repository }}
-
- - name: find changed directories
- run: |
- if [ $GITHUB_BASE_REF ]; then
- # Pull Request
- echo "Triggerring event: pull request"
- echo Pull request base ref: $GITHUB_BASE_REF
- git fetch origin $GITHUB_BASE_REF --depth=1
- if [ ${{ github.event.action }} = "opened" ]; then
- echo "Triggerring action: opened"
- echo "DIRECTORIES_CHANGED=$( git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ github.event.pull_request.head.sha }} | cut -d/ -f1 | sort -u | sed -z 's/\n/,/g;s/^/[/;s/,$/]/;s/$/\n/')" >> ${GITHUB_ENV}
- fi
- if [ ${{ github.event.action }} = "synchronize" ]; then
- echo "Triggerring action: synchronize"
- echo "DIRECTORIES_CHANGED=$( git diff --name-only ${{ github.event.before }} ${{ github.event.pull_request.head.sha }} | cut -d/ -f1 | sort -u | sed -z 's/\n/,/g;s/^/[/;s/,$/]/;s/$/\n/')" >> ${GITHUB_ENV}
- fi
- else
- # Push
- echo "Triggerring event: push"
- git fetch origin ${{ github.event.before }} --depth=1
- echo "DIRECTORIES_CHANGED=$( git diff --name-only ${{ github.event.before }} ${{ github.sha }} | cut -d/ -f1 | sort -u | sed -z 's/\n/,/g;s/^/[/;s/,$/]/;s/$/\n/')" >> ${GITHUB_ENV}
- fi
- echo "$DIRECTORIES_CHANGED"
-
- - uses: actions/setup-java@387ac29b308b003ca37ba93a6cab5eb57c8f5f93 # v4.0.0
- if: contains(env.DIRECTORIES_CHANGED, matrix.fldrpath)
- with:
- java-version: '17'
- distribution: 'zulu'
-
- - name: Publish package
- if: contains(env.DIRECTORIES_CHANGED, matrix.fldrpath)
- env:
- GITHUB_USERNAME: ${{ github.actor }}
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- run: |
- pwd
- mvn clean install -DskipTests --file ${{ matrix.fldrpath }}
- mvn -B package --file ${{ matrix.fldrpath }}/pom.xml -Dmaven.test.skip=true
- mvn --file ${{ matrix.fldrpath }}/pom.xml deploy -Dmaven.test.skip=true
diff --git a/.github/workflows/documenation_check.yml b/.github/workflows/documenation_check.yml
deleted file mode 100644
index 642d4e84e64..00000000000
--- a/.github/workflows/documenation_check.yml
+++ /dev/null
@@ -1,57 +0,0 @@
-name: Check documentation on PRs
-on:
- workflow_dispatch:
- pull_request:
- types:
- - opened
- - edited
-
-permissions:
- contents: read
-
-jobs:
- check_pr_for_docs:
- env:
- GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- runs-on: ubuntu-latest
- steps:
- - name: Harden Runner
- uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
- with:
- egress-policy: audit
-
- - name: Checkout code
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- with:
- fetch-depth: 0
-
- - name: Install latest GH
- continue-on-error: true
- run: |
- VERSION=`curl "https://api.github.com/repos/cli/cli/releases/latest" | grep '"tag_name"' | sed -E 's/.*"([^"]+)".*/\1/' | cut -c2-`
- echo $VERSION
- curl -sSL https://github.com/cli/cli/releases/download/v${VERSION}/gh_${VERSION}_linux_amd64.tar.gz -o gh_${VERSION}_linux_amd64.tar.gz
- tar xvf gh_${VERSION}_linux_amd64.tar.gz
- sudo cp gh_${VERSION}_linux_amd64/bin/gh /usr/local/bin/
- gh version
-
- - name: Check commit message
- continue-on-error: false
- id: check_message
- run: |
- PULL_NUMBER=${{ github.event.pull_request.number }}
- echo "Parsing commits from PR $PULL_NUMBER"
- MESSAGE=$(gh pr view "$PULL_NUMBER" --json commits | jq -r '.commits[].messageHeadline' | grep "^docs" || echo "")
- echo "$MESSAGE"
- if [[ -z "$MESSAGE" ]]; then
- echo "conventional commit starting with docs: does not exist. Checking if user confirmed no impact on docs in PR body"
- pr_body=$(gh pr view https://github.com/${{ github.repository }}/pull/"$PULL_NUMBER" --json body -q '.body')
- if [[ $pr_body == *"- [x] **I confirm that there is no impact on the docs due to the code changes in this PR.**"* ]]; then
- echo "Checklist item is filled in PR body. Author confirmed no impact."
- exit 0
- else
- echo "Author did not check the item that states: **I confirm that there is no impact on the docs due to the code changes in this PR.**"
- exit 1
- fi
- fi
- exit 0
diff --git a/.github/workflows/jans_pycloud_build_package.yml b/.github/workflows/jans_pycloud_build_package.yml
deleted file mode 100644
index bba28154041..00000000000
--- a/.github/workflows/jans_pycloud_build_package.yml
+++ /dev/null
@@ -1,63 +0,0 @@
-name: Images Janspycloud updater
-
-on:
- push:
- branches:
- - main
- paths:
- - "jans-pycloudlib/**"
- - "!**.md"
- - "!jans-pycloudlib/jans/pycloudlib/version.py"
- workflow_dispatch:
-
-permissions:
- contents: read
-
-jobs:
- pycloud-updater:
- permissions:
- contents: write # for Git to git push
- if: github.actor != 'mo-auto' && github.repository == 'JanssenProject/jans'
- runs-on: ubuntu-latest
- env:
- PR_DOCKER_BRANCH_NAME: update-jans-pycloudlib
- steps:
- - name: Harden Runner
- uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
- with:
- egress-policy: audit
-
- - name: Checkout
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
-
- - name: Import GPG key
- id: import_gpg
- uses: crazy-max/ghaction-import-gpg@01dd5d3ca463c7f10f7f4f7b4f177225ac661ee4 # v6.1.0
- with:
- gpg_private_key: ${{ secrets.MOAUTO_GPG_PRIVATE_KEY }}
- passphrase: ${{ secrets.MOAUTO_GPG_PRIVATE_KEY_PASSPHRASE }}
- git_user_signingkey: true
- git_commit_gpgsign: true
-
- - name: Configure Git
- run: |
- git config --global user.name "mo-auto"
- git config --global user.email "54212639+mo-auto@users.noreply.github.com"
- git config --global user.signingkey "${{ steps.import_gpg.outputs.keyid }}"
- git checkout -b ${{ env.PR_DOCKER_BRANCH_NAME }}
- echo "${{ secrets.MOAUTO_WORKFLOW_TOKEN }}" | gh auth login --with-token
-
- - name: Update stable requirements in docker images
- id: build_stable_reqs
- run: |
- dockerimages="auth-server casa certmanager config-api configurator fido2 keycloak-link link persistence-loader saml scim "
- for image in $dockerimages; do
- sed -i '/git+https/c\git+https://github.com/${{ github.repository }}@${{ github.sha }}#egg=jans-pycloudlib&subdirectory=jans-pycloudlib' ./docker-jans-$image/requirements.txt
- done
-
- - name: Configure Git
- run: |
- git add -A
- git commit -S -s -m "chore(jans-pycloudlib): updated build"
- git push origin ${{ env.PR_DOCKER_BRANCH_NAME }}
- PR=$(gh pr create --assignee "moabu" --base "main" --body "Updated build date. Auto-generated." --label "enhancement,bot" --reviewer "moabu" --title "chore(Dockerfile): updated build dates" || echo "PR Branch is already open")
diff --git a/.github/workflows/lint-docs.yml b/.github/workflows/lint-docs.yml
new file mode 100644
index 00000000000..8cd86548322
--- /dev/null
+++ b/.github/workflows/lint-docs.yml
@@ -0,0 +1,37 @@
+name: Lint documentation
+on:
+ workflow_dispatch:
+ pull_request:
+ types:
+ - opened
+ - edited
+ paths:
+ - "docs/**"
+permissions:
+ contents: read
+
+jobs:
+ lint_docs:
+ if: github.repository == 'JanssenProject/jans' && github.event_name == 'pull_request'
+ env:
+ GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ runs-on: ubuntu-latest
+ steps:
+ - name: Harden Runner
+ uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
+ with:
+ egress-policy: audit
+
+ - name: Checkout code
+ uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
+ with:
+ fetch-depth: 0
+
+ - name: Markdown linter
+ continue-on-error: true
+ run: |
+ sudo apt-get install rubygems -y
+ sudo gem install mdl
+ mdl --style automation/markdown/.mdl_style.rb docs/
+
+
diff --git a/.github/workflows/flake8-lint.yml b/.github/workflows/lint-flak8.yml
similarity index 100%
rename from .github/workflows/flake8-lint.yml
rename to .github/workflows/lint-flak8.yml
diff --git a/.github/workflows/docs.yml b/.github/workflows/ops-docs.yml
similarity index 66%
rename from .github/workflows/docs.yml
rename to .github/workflows/ops-docs.yml
index dd1069b1ffa..1a72e2f7e63 100644
--- a/.github/workflows/docs.yml
+++ b/.github/workflows/ops-docs.yml
@@ -5,15 +5,60 @@ on:
types:
- opened
- edited
- paths:
- - 'docs/**'
permissions:
contents: read
jobs:
- docs:
+ check_pr_for_docs:
if: github.repository == 'JanssenProject/jans'
+ env:
+ GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ runs-on: ubuntu-latest
+ steps:
+ - name: Harden Runner
+ uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
+ with:
+ egress-policy: audit
+
+ - name: Checkout code
+ uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
+ with:
+ fetch-depth: 0
+
+ - name: Install latest GH
+ continue-on-error: true
+ run: |
+ VERSION=`curl "https://api.github.com/repos/cli/cli/releases/latest" | grep '"tag_name"' | sed -E 's/.*"([^"]+)".*/\1/' | cut -c2-`
+ echo $VERSION
+ curl -sSL https://github.com/cli/cli/releases/download/v${VERSION}/gh_${VERSION}_linux_amd64.tar.gz -o gh_${VERSION}_linux_amd64.tar.gz
+ tar xvf gh_${VERSION}_linux_amd64.tar.gz
+ sudo cp gh_${VERSION}_linux_amd64/bin/gh /usr/local/bin/
+ gh version
+
+ - name: Check commit message
+ continue-on-error: false
+ id: check_message
+ run: |
+ PULL_NUMBER=${{ github.event.pull_request.number }}
+ echo "Parsing commits from PR $PULL_NUMBER"
+ MESSAGE=$(gh pr view "$PULL_NUMBER" --json commits | jq -r '.commits[].messageHeadline' | grep "^docs" || echo "")
+ echo "$MESSAGE"
+ if [[ -z "$MESSAGE" ]]; then
+ echo "conventional commit starting with docs: does not exist. Checking if user confirmed no impact on docs in PR body"
+ pr_body=$(gh pr view https://github.com/${{ github.repository }}/pull/"$PULL_NUMBER" --json body -q '.body')
+ if [[ $pr_body == *"- [x] **I confirm that there is no impact on the docs due to the code changes in this PR.**"* ]]; then
+ echo "Checklist item is filled in PR body. Author confirmed no impact."
+ exit 0
+ else
+ echo "Author did not check the item that states: **I confirm that there is no impact on the docs due to the code changes in this PR.**"
+ exit 1
+ fi
+ fi
+ exit 0
+
+ docs:
+ if: github.repository == 'JanssenProject/jans' && github.event_name == 'pull_request' && contains(github.event.pull_request.changed_files, 'docs/')
runs-on: ubuntu-latest
steps:
- name: Harden Runner
@@ -55,7 +100,7 @@ jobs:
fi
check_pr:
- if: github.repository == 'JanssenProject/jans'
+ if: github.repository == 'JanssenProject/jans' && github.event_name == 'pull_request' && contains(github.event.pull_request.changed_files, 'docs/')
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
runs-on: ubuntu-latest
@@ -112,7 +157,7 @@ jobs:
lint_docs:
- if: github.repository == 'JanssenProject/jans'
+ if: github.repository == 'JanssenProject/jans' && github.event_name == 'pull_request' && contains(github.event.pull_request.changed_files, 'docs/')
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
runs-on: ubuntu-latest
@@ -134,3 +179,4 @@ jobs:
sudo gem install mdl
mdl --style automation/markdown/.mdl_style.rb docs/
+
diff --git a/.github/workflows/label_pr_issues.yml b/.github/workflows/ops-label-pr-issues.yml
similarity index 100%
rename from .github/workflows/label_pr_issues.yml
rename to .github/workflows/ops-label-pr-issues.yml
diff --git a/.github/workflows/pr-ref-issue.yml b/.github/workflows/ops-pr-ref-issue.yml
similarity index 100%
rename from .github/workflows/pr-ref-issue.yml
rename to .github/workflows/ops-pr-ref-issue.yml
diff --git a/.github/workflows/sync.yml b/.github/workflows/ops-sync-tf.yml
similarity index 100%
rename from .github/workflows/sync.yml
rename to .github/workflows/ops-sync-tf.yml
diff --git a/.github/workflows/backport.yml b/.github/workflows/release-backport.yml
similarity index 100%
rename from .github/workflows/backport.yml
rename to .github/workflows/release-backport.yml
diff --git a/.github/workflows/clean_github_cache.yml b/.github/workflows/sanitary-github-cache.yml
similarity index 100%
rename from .github/workflows/clean_github_cache.yml
rename to .github/workflows/sanitary-github-cache.yml
diff --git a/.github/workflows/delete_workflow_runs.yml b/.github/workflows/sanitary-workflow-runs.yml
similarity index 100%
rename from .github/workflows/delete_workflow_runs.yml
rename to .github/workflows/sanitary-workflow-runs.yml
diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/scan-codeql.yml
similarity index 98%
rename from .github/workflows/codeql-analysis.yml
rename to .github/workflows/scan-codeql.yml
index dcaecab3e91..6fdf1b4abca 100644
--- a/.github/workflows/codeql-analysis.yml
+++ b/.github/workflows/scan-codeql.yml
@@ -43,7 +43,7 @@ jobs:
matrix:
# Override automatic language detection by changing the below list
# Supported options are ['csharp', 'cpp', 'go', 'java', 'javascript', 'python']
- language: ['python', 'java', 'javascript']
+ language: ['python', 'java', 'javascript', 'go']
# Learn more...
# https://docs.github.com/en/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#overriding-automatic-language-detection
diff --git a/.github/workflows/dependency-review.yml b/.github/workflows/scan-dependency.yml
similarity index 100%
rename from .github/workflows/dependency-review.yml
rename to .github/workflows/scan-dependency.yml
diff --git a/.github/workflows/central_code_quality_check.yml b/.github/workflows/scan-sonar.yml
similarity index 100%
rename from .github/workflows/central_code_quality_check.yml
rename to .github/workflows/scan-sonar.yml
diff --git a/.github/workflows/scorecard.yml b/.github/workflows/security-scorecard.yml
similarity index 100%
rename from .github/workflows/scorecard.yml
rename to .github/workflows/security-scorecard.yml
diff --git a/.github/workflows/test_cedarling.yml b/.github/workflows/test-cedarling.yml
similarity index 100%
rename from .github/workflows/test_cedarling.yml
rename to .github/workflows/test-cedarling.yml
diff --git a/.github/workflows/testcases.yml b/.github/workflows/test-jans-pycloudlib.yml
similarity index 100%
rename from .github/workflows/testcases.yml
rename to .github/workflows/test-jans-pycloudlib.yml
diff --git a/.github/workflows/microk8s.yml b/.github/workflows/test-microk8s.yml
similarity index 97%
rename from .github/workflows/microk8s.yml
rename to .github/workflows/test-microk8s.yml
index c9e5f74dd31..b47f3162e1b 100644
--- a/.github/workflows/microk8s.yml
+++ b/.github/workflows/test-microk8s.yml
@@ -24,7 +24,7 @@ jobs:
max-parallel: 6
matrix:
istio: ["true", "false"]
- # add '"pgsql" when supported
+ #TODO: add '"pgsql"
persistence-backends: ["MYSQL"]
fail-fast: false
runs-on: ubuntu-latest
diff --git a/.github/workflows/test_docker_linux_installer.yml b/.github/workflows/test_docker_linux_installer.yml
deleted file mode 100644
index c9d863426a5..00000000000
--- a/.github/workflows/test_docker_linux_installer.yml
+++ /dev/null
@@ -1,136 +0,0 @@
-name: Test Linux installer
-on:
- workflow_dispatch:
- push:
- branches:
- - main
- paths:
- - "jans-linux-setup/**"
- pull_request:
- branches:
- - main
- paths:
- - "jans-linux-setup/**"
-permissions:
- checks: write
- pull-requests: write
-jobs:
- build:
- runs-on: ubuntu-20.04
- strategy:
- max-parallel: 6
- matrix:
- # add '"pgsql" when supported
- persistence-backends: ["MYSQL", "PGSQL", "COUCHBASE"]
- python-version: ["3.7"]
- fail-fast: false
- steps:
- - name: Harden Runner
- uses: step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4 # v2.7.1
- with:
- egress-policy: audit
-
- - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- - name: Set up Python3
- uses: actions/setup-python@0a5c61591373683505ea898e09a3ea4f39ef2b9c # v5.0.0
- with:
- python-version: ${{ matrix.python-version }}
-
- - name: Set up Go
- uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0
- with:
- go-version: 1.18
-
- - name: Import GPG key
- id: import_gpg
- uses: crazy-max/ghaction-import-gpg@01dd5d3ca463c7f10f7f4f7b4f177225ac661ee4 # v6.1.0
- with:
- gpg_private_key: ${{ secrets.MOAUTO_GPG_PRIVATE_KEY }}
- passphrase: ${{ secrets.MOAUTO_GPG_PRIVATE_KEY_PASSPHRASE }}
- git_user_signingkey: true
- git_commit_gpgsign: true
-
- - name: Configure Git
- run: |
- git config --global user.name "mo-auto"
- git config --global user.email "54212639+mo-auto@users.noreply.github.com"
- git config --global user.signingkey "${{ steps.import_gpg.outputs.keyid }}"
- echo "${{ secrets.MOAUTO_WORKFLOW_TOKEN }}" | gh auth login --with-token
-
- - name: Test Jans monolith demo
- run: |
- ip=$(ifconfig eth0 | grep -Eo 'inet (addr:)?([0-9]*\.){3}[0-9]*' | grep -Eo '([0-9]*\.){3}[0-9]*' | grep -v '127.0.0.1')
- sudo chmod u+x automation/startjanssenmonolithdemo.sh
- sudo RUN_TESTS=true bash ./automation/startjanssenmonolithdemo.sh "demoexample.jans.io" "${{ matrix.persistence-backends }}" "${ip}" "${{ github.sha }}"
- persistence=$(echo "${{ matrix.persistence-backends }}" | tr '[:upper:]' '[:lower:]')
- mv /tmp/reports /${{ matrix.persistence-backends }}-reports
-
- echo "generating rdbms docs for ${{ matrix.persistence-backends }}..."
- git clone https://mo-auto:${{ secrets.MOAUTO_WORKFLOW_TOKEN }}@github.com/JanssenProject/jans.git
- cd jans
- git config pull.rebase true
- git checkout -b cn-jans-update-${{ matrix.persistence-backends }}-auto-generated-docs || echo "Branch exists"
- git pull origin cn-jans-update-${{ matrix.persistence-backends }}-auto-generated-docs || echo "Nothing to pull"
- sudo bash ./automation/docs/generate-rdbms-docs.sh "$persistence" || echo "generating rdbms docs failed for ${{ matrix.persistence-backends }}!!!"
- git add . || echo "generating rdbms docs failed !!!"
- git commit -a -S -m "docs: auto-generated ${{ matrix.persistence-backends }} docs" || echo "Nothing to commit"
- git push --set-upstream origin cn-jans-update-${{ matrix.persistence-backends }}-auto-generated-docs || echo "generating rdbms docs failed !!!"
- MESSAGE="fix(docs): autogenerate ${{ matrix.persistence-backends }} RDBMS docs"
- gh pr create --body "Auto generated RDBMS docs" --title "${MESSAGE}" || echo "PR exists"
- cd ..
- echo "generating rdbms docs for ${{ matrix.persistence-backends }} done"
-
- export JANS_URL=https://demoexample.jans.io
- export JANS_CLIENT_ID=9876baac-de39-4c23-8a78-674b59df8c09
- export JANS_CLIENT_SECRET=1t5Fin3#security
- export JANS_INSECURE_CLIENT=true
- export TF_ACC=1
- cd terraform-provider-jans
- go install github.com/jstemmer/go-junit-report/v2@latest
- go test -v 2>&1 ./... | go-junit-report > ${{ matrix.persistence-backends }}report.xml
- cd ..
-
- - name: Publish Test Results
- continue-on-error: true
- uses: EnricoMi/publish-unit-test-result-action@e780361cd1fc1b1a170624547b3ffda64787d365 # v2.12.0
- if: >-
- github.event.pull_request.head.repo.full_name == github.repository ||
- github.event_name == 'workflow_dispatch' ||
- github.event_name == 'push'
- with:
- large_files: true
- check_name: Java ${{ matrix.persistence-backends }} Tests
- report_individual_runs: "true"
- files: |
- /${{ matrix.persistence-backends }}-reports/*.xml
-
- - name: Upload Test Results
- continue-on-error: true
- if: always()
- uses: actions/upload-artifact@26f96dfa697d77e81fd5907df203aa23a56210a8 # v4.3.0
- with:
- name: java-${{ matrix.persistence-backends }}-test-results
- path: "/${{ matrix.persistence-backends }}-reports/*.xml"
-
- - uses: dorny/test-reporter@31a54ee7ebcacc03a09ea97a7e5465a47b84aea5 # v1
- continue-on-error: true
- if: >-
- github.event.pull_request.head.repo.full_name == github.repository ||
- github.event_name == 'workflow_dispatch' ||
- github.event_name == 'push'
- id: go
- with:
- name: Go ${{ matrix.persistence-backends }} Tests
- path: './terraform-provider-jans/${{ matrix.persistence-backends }}report.xml'
- reporter: java-junit
-
- - name: Download Artifacts
- uses: actions/download-artifact@6b208ae046db98c579e8a3aa621ab581ff575935 # v4.1.1
- with:
- name: java-${{ matrix.persistence-backends }}-test-results
- path: java-${{ matrix.persistence-backends }}-test-results
-
- - name: Publish Test Results
- uses: EnricoMi/publish-unit-test-result-action/composite@e780361cd1fc1b1a170624547b3ffda64787d365 # v2.12.0
- with:
- files: "java-${{ matrix.persistence-backends }}-test-results/**/*.xml"
diff --git a/agama/pom.xml b/agama/pom.xml
index e150eb66858..0fb22886d65 100644
--- a/agama/pom.xml
+++ b/agama/pom.xml
@@ -33,6 +33,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/automation/startjanssenmonolithdemo.sh b/automation/startjanssenmonolithdemo.sh
index 446feee979a..88a070380eb 100644
--- a/automation/startjanssenmonolithdemo.sh
+++ b/automation/startjanssenmonolithdemo.sh
@@ -49,7 +49,7 @@ WORKING_DIRECTORY=$PWD
# note that as we're pulling from a monorepo (with multiple project in it)
# we are using partial-clone and sparse-checkout to get the docker-jans-monolith code
rm -rf /tmp/jans || echo "/tmp/jans doesn't exist"
-git clone --filter blob:none --no-checkout https://github.com/janssenproject/jans /tmp/jans \
+git clone --filter blob:none --no-checkout https://github.com/JanssenProject/jans /tmp/jans \
&& cd /tmp/jans \
&& git sparse-checkout init --cone \
&& git checkout "$JANS_BUILD_COMMIT" \
@@ -129,15 +129,35 @@ while [ $SECONDS -lt $end ]; do
sleep 10
done
echo -e "Running build.. \n"
+docker exec -w /tmp/jans/jans-orm docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=true clean compile install
docker exec -w /tmp/jans/jans-auth-server docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=true -fae clean compile install
+docker exec -w /tmp/jans/jans-auth-server/agama docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=true -fae clean compile install
+docker exec -w /tmp/jans/jans-scim docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=true clean compile install site
+docker exec -w /tmp/jans/jans-config-api docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=true clean compile install
+docker exec -w /tmp/jans/jans-fido2 docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=true clean compile install
echo -e "Running tests.. \n"
+docker exec -w /tmp/jans/jans-orm docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=false test
docker exec -w /tmp/jans/jans-auth-server docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=false test
+docker exec -w /tmp/jans/jans-auth-server/agama docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=false test
+docker exec -w /tmp/jans/jans-scim docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=false test
+docker exec -w /tmp/jans/jans-config-api docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=false -DfailIfNoTests=false -Dtest=io.jans.configapi.JenkinsTestRunner test
+docker exec -w /tmp/jans/jans-fido2 docker-jans-monolith-jans-1 mvn -Dcfg="$JANS_FQDN" -Dmaven.test.skip=false test
echo -e "copying reports.. \n"
docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-auth-server/client/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-auth-client-testng-results.xml
docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-auth-server/agama/model/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-auth-agama-model-testng-results.xml
docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-auth-server/test-model/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-auth-test-model-testng-results.xml
docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-auth-server/model/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-auth-model-testng-results.xml
-
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/couchbase/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-couchbase-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/spanner-sample/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-spanner-sample-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/couchbase-sample/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-couchbase-sample-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/sql-sample/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-sql-sample-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/sql/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-sql-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/spanner/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-spanner-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/util/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-util-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/model/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-model-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-orm/filter/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-orm-filter-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-scim/client/target/surefire-reports/testng-results.xml /tmp/reports/$JANS_PERSISTENCE-jans-scim-client-testng-results.xml
+docker cp docker-jans-monolith-jans-1:/tmp/jans/jans-config-api/server/target/surefire-reports/results-json.txt /tmp/reports/$JANS_PERSISTENCE-jans-config-api-server-testng-results.xml
EOF
if [[ "$RUN_TESTS" == "true" ]]; then
sudo bash testendpoints.sh
diff --git a/docker-jans-monolith/scripts/entrypoint.sh b/docker-jans-monolith/scripts/entrypoint.sh
index a7a7fdab03f..2969fb7f4fe 100644
--- a/docker-jans-monolith/scripts/entrypoint.sh
+++ b/docker-jans-monolith/scripts/entrypoint.sh
@@ -96,15 +96,15 @@ register_fqdn() {
fi
}
-prepare_auth_server_test() {
+prepare_auth_server_tests() {
WORKING_DIRECTORY=$PWD
echo "***** cloning jans auth server folder!! *****"
rm -rf /tmp/jans || echo "Jans isn't cloned yet..Cloning"\
- && git clone --filter blob:none --no-checkout https://github.com/janssenproject/jans /tmp/jans \
+ && git clone --filter blob:none --no-checkout https://github.com/JanssenProject/jans /tmp/jans \
&& cd /tmp/jans \
&& git sparse-checkout init --cone \
&& git checkout "${JANS_SOURCE_VERSION}" \
- && git sparse-checkout set jans-auth-server \
+ && git sparse-checkout set jans-auth-server jans-scim jans-config-api jans-orm jans-fido2 \
&& cd jans-auth-server \
&& echo "Copying auth server test profiles from ephemeral server" \
&& cp -R /opt/jans/jans-setup/output/test/jans-auth ./ \
@@ -120,7 +120,7 @@ prepare_auth_server_test() {
&& echo "Removing test profile folder" \
&& rm -rf ./jans-auth \
&& cd agama \
- && cp /opt/jans/jans-setup/output/test/jans-auth/config-agama-test.properties . \
+ && cp /opt/jans/jans-setup/output/test/agama/config-agama-test.properties . \
&& mkdir -p ./engine/profiles/"${CN_HOSTNAME}" \
&& mv config-agama-test.properties ./engine/profiles/"${CN_HOSTNAME}"/config-agama-test.properties \
&& cd .. \
@@ -132,11 +132,51 @@ prepare_auth_server_test() {
&& cd "$WORKING_DIRECTORY"
}
+prepare_scim_test() {
+ WORKING_DIRECTORY=$PWD
+ cd /tmp/jans \
+ && cd jans-scim \
+ && echo "Copying scim server test profiles from ephemeral server" \
+ && cp -R /opt/jans/jans-setup/output/test/scim-client ./ \
+ && echo "Creating scim server profile folders" \
+ && mkdir -p ./client/profiles/"${CN_HOSTNAME}" \
+ && echo "Copying scim server profile files" \
+ && cp ./scim-client/client/config-scim-test.properties ./client/profiles/"${CN_HOSTNAME}" \
+ && echo "Removing test profile folder" \
+ && rm -rf ./scim-client \
+ && cd .. \
+ && cd "$WORKING_DIRECTORY"
+}
+
+prepare_config_api_test() {
+ WORKING_DIRECTORY=$PWD
+ cd /tmp/jans \
+ && cd jans-config-api \
+ && echo "Copying config-api test profiles from ephemeral server" \
+ && cp -R /opt/jans/jans-setup/output/test/jans-config-api ./ \
+ && rm -rf ./profiles/"${CN_HOSTNAME}" \
+ && echo "Creating config-api profile folders" \
+ && mkdir -p ./profiles/"${CN_HOSTNAME}" \
+ && echo "Copying config-api server profile files" \
+ && cp ./jans-config-api/client/* ./profiles/"${CN_HOSTNAME}" \
+ && echo "Copying default configuration properties" \
+ && cp ./profiles/default/config-build.properties ./profiles/"${CN_HOSTNAME}" \
+ && echo "Removing test profile folder" \
+ && rm -rf ./jans-config-api \
+ && cd .. \
+ && cd "$WORKING_DIRECTORY"
+}
+
+
prepare_java_tests() {
if [[ "${RUN_TESTS}" == "true" ]]; then
echo "***** Running Java tests!! *****"
echo "***** Running Auth server tests!! *****"
- prepare_auth_server_test
+ prepare_auth_server_tests
+ echo "***** Running Scim tests!! *****"
+ prepare_scim_test
+ echo "***** Running Config Api tests!! *****"
+ prepare_config_api_test
echo "***** Java tests completed!! *****"
fi
}
diff --git a/jans-auth-server/agama/engine/pom.xml b/jans-auth-server/agama/engine/pom.xml
index e6620c249ca..2c128da40e1 100644
--- a/jans-auth-server/agama/engine/pom.xml
+++ b/jans-auth-server/agama/engine/pom.xml
@@ -20,6 +20,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Jans repository
diff --git a/jans-auth-server/agama/inboundID/pom.xml b/jans-auth-server/agama/inboundID/pom.xml
index 4543762390a..81435b2245c 100644
--- a/jans-auth-server/agama/inboundID/pom.xml
+++ b/jans-auth-server/agama/inboundID/pom.xml
@@ -7,6 +7,14 @@
jar
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
io.jans
jans-auth-server-parent
@@ -21,6 +29,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Jans repository
diff --git a/jans-auth-server/pom.xml b/jans-auth-server/pom.xml
index 360cd02db77..40d57852eed 100644
--- a/jans-auth-server/pom.xml
+++ b/jans-auth-server/pom.xml
@@ -67,11 +67,11 @@
-
- mavencentral
- maven central
- https://repo1.maven.org/maven2
-
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
true
diff --git a/jans-bom/pom.xml b/jans-bom/pom.xml
index e619cb11dbd..e9f09f4dc98 100644
--- a/jans-bom/pom.xml
+++ b/jans-bom/pom.xml
@@ -64,6 +64,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
central
Maven Repository Switchboard
diff --git a/jans-casa/app-fips/pom.xml b/jans-casa/app-fips/pom.xml
index d8f0fa2228d..fd68f7c0a3a 100644
--- a/jans-casa/app-fips/pom.xml
+++ b/jans-casa/app-fips/pom.xml
@@ -360,7 +360,7 @@
maven-war-plugin
org.apache.maven.plugins
- 2.3
+ 3.3.2
false
diff --git a/jans-casa/app/pom.xml b/jans-casa/app/pom.xml
index 873993e6db8..6b7d8c8d87e 100644
--- a/jans-casa/app/pom.xml
+++ b/jans-casa/app/pom.xml
@@ -334,7 +334,7 @@
maven-war-plugin
org.apache.maven.plugins
- 2.3
+ 3.3.2
diff --git a/jans-casa/plugins/acct-linking/pom.xml b/jans-casa/plugins/acct-linking/pom.xml
index a46c815472e..2d72b337d7a 100644
--- a/jans-casa/plugins/acct-linking/pom.xml
+++ b/jans-casa/plugins/acct-linking/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
jar
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
11
11
@@ -15,6 +23,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-casa/plugins/bioid/pom.xml b/jans-casa/plugins/bioid/pom.xml
index 1dd573ed183..0ae2b685388 100644
--- a/jans-casa/plugins/bioid/pom.xml
+++ b/jans-casa/plugins/bioid/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
jar
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
11
11
@@ -15,6 +23,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-casa/plugins/client-authorizations/pom.xml b/jans-casa/plugins/client-authorizations/pom.xml
index 57139bec9b8..2229bd724ec 100644
--- a/jans-casa/plugins/client-authorizations/pom.xml
+++ b/jans-casa/plugins/client-authorizations/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
jar
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
11
11
@@ -15,6 +23,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-casa/plugins/custom-branding/pom.xml b/jans-casa/plugins/custom-branding/pom.xml
index 9fdad5aa58a..16fad6ae5e9 100644
--- a/jans-casa/plugins/custom-branding/pom.xml
+++ b/jans-casa/plugins/custom-branding/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
jar
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
11
11
@@ -15,6 +23,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-casa/plugins/email_2fa_core/pom.xml b/jans-casa/plugins/email_2fa_core/pom.xml
index ffe3058c6e6..ab1578db476 100644
--- a/jans-casa/plugins/email_2fa_core/pom.xml
+++ b/jans-casa/plugins/email_2fa_core/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
jar
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
11
11
@@ -16,6 +24,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
mavencentral
maven central
diff --git a/jans-casa/plugins/strong-authn-settings/pom.xml b/jans-casa/plugins/strong-authn-settings/pom.xml
index b8bcf828b5d..83b01e93db7 100644
--- a/jans-casa/plugins/strong-authn-settings/pom.xml
+++ b/jans-casa/plugins/strong-authn-settings/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
jar
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
11
11
@@ -15,6 +23,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-casa/pom.xml b/jans-casa/pom.xml
index 4806c9608c8..560666d64dd 100644
--- a/jans-casa/pom.xml
+++ b/jans-casa/pom.xml
@@ -8,6 +8,14 @@
1.1.6-SNAPSHOT
pom
+
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
${maven.min-version}
@@ -34,6 +42,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-config-api/pom.xml b/jans-config-api/pom.xml
index 87a360c6538..6d01d6e6fbb 100644
--- a/jans-config-api/pom.xml
+++ b/jans-config-api/pom.xml
@@ -73,6 +73,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
mavencentral
maven central
diff --git a/jans-core/pom.xml b/jans-core/pom.xml
index 5dfa0fe24de..fd4a6e98074 100644
--- a/jans-core/pom.xml
+++ b/jans-core/pom.xml
@@ -201,6 +201,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
mavencentral
maven central
diff --git a/jans-fido2/pom.xml b/jans-fido2/pom.xml
index c8107b43a08..8afe5628061 100644
--- a/jans-fido2/pom.xml
+++ b/jans-fido2/pom.xml
@@ -45,6 +45,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
repository.jboss.org
JBoss Repository
diff --git a/jans-keycloak-integration/job-scheduler/pom.xml b/jans-keycloak-integration/job-scheduler/pom.xml
index 9e7944c7062..7fdd64971d4 100644
--- a/jans-keycloak-integration/job-scheduler/pom.xml
+++ b/jans-keycloak-integration/job-scheduler/pom.xml
@@ -6,6 +6,14 @@
kc-jans-scheduler
jar
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
io.jans
jans-kc-parent
diff --git a/jans-keycloak-integration/pom.xml b/jans-keycloak-integration/pom.xml
index 1e0830e4221..ee1c0f30dae 100644
--- a/jans-keycloak-integration/pom.xml
+++ b/jans-keycloak-integration/pom.xml
@@ -63,6 +63,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans.io
Janssen project repository
diff --git a/jans-keycloak-link/pom.xml b/jans-keycloak-link/pom.xml
index 5e1dcca4454..d1601881d04 100644
--- a/jans-keycloak-link/pom.xml
+++ b/jans-keycloak-link/pom.xml
@@ -12,6 +12,14 @@
pom
http://maven.apache.org
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
${project.version}
3.0.3
@@ -28,6 +36,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
mavencentral
maven central
diff --git a/jans-link/pom.xml b/jans-link/pom.xml
index c65ee8fc1f7..40ce5a2d48e 100644
--- a/jans-link/pom.xml
+++ b/jans-link/pom.xml
@@ -20,6 +20,14 @@
jans link server parent
http://maven.apache.org
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
${project.version}
@@ -41,6 +49,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
mavencentral
maven central
diff --git a/jans-link/server-fips/pom.xml b/jans-link/server-fips/pom.xml
index 6d4ae5da051..5582dac9917 100644
--- a/jans-link/server-fips/pom.xml
+++ b/jans-link/server-fips/pom.xml
@@ -6,6 +6,14 @@
jans link server (FIPS)
war
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
jans-link-server-parent
io.jans
diff --git a/jans-link/server/pom.xml b/jans-link/server/pom.xml
index 034b303951d..df15845c406 100644
--- a/jans-link/server/pom.xml
+++ b/jans-link/server/pom.xml
@@ -10,6 +10,14 @@
jans link server
http://maven.apache.org
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
UTF-8
diff --git a/jans-link/service/pom.xml b/jans-link/service/pom.xml
index 984ec5e68a1..7a8330d9a8a 100644
--- a/jans-link/service/pom.xml
+++ b/jans-link/service/pom.xml
@@ -10,6 +10,14 @@
jans link service
http://maven.apache.org
+
+
+ github
+ Github Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
+
+
UTF-8
diff --git a/jans-lock/lock-server/pom.xml b/jans-lock/lock-server/pom.xml
index 9fe7c50671a..5b020b8cbfe 100644
--- a/jans-lock/lock-server/pom.xml
+++ b/jans-lock/lock-server/pom.xml
@@ -55,6 +55,11 @@
maven central
https://repo1.maven.org/maven2
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
jans
Janssen project repository
diff --git a/jans-orm/pom.xml b/jans-orm/pom.xml
index b2f7bfe21ca..9e1c6770b04 100644
--- a/jans-orm/pom.xml
+++ b/jans-orm/pom.xml
@@ -63,6 +63,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
mavencentral
maven central
diff --git a/jans-scim/pom.xml b/jans-scim/pom.xml
index 31e71a21cea..f4a34ea896a 100644
--- a/jans-scim/pom.xml
+++ b/jans-scim/pom.xml
@@ -40,6 +40,11 @@
+
+ github
+ GitHub Packages
+ https://maven.pkg.github.com/JanssenProject/jans
+
repository.jboss.org
JBoss Repository