keycloak-scim/.github/workflows/js-ci.yml
2023-03-30 10:58:52 -04:00

284 lines
7.3 KiB
YAML

name: Keycloak JavaScript CI
on:
push:
branches-ignore:
- main
- dependabot/**
pull_request:
schedule:
- cron: 0 20,23,2,5 * * *
workflow_dispatch:
concurrency:
# Only cancel jobs for PR updates
group: js-ci-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
defaults:
run:
shell: bash
jobs:
conditional:
name: Check conditional workflows and jobs
if: github.event_name != 'schedule' || github.repository == 'keycloak/keycloak'
runs-on: ubuntu-latest
outputs:
js-ci: ${{ steps.conditional.outputs.js }}
steps:
- uses: actions/checkout@v3
- id: conditional
uses: ./.github/actions/conditional
build-keycloak:
name: Build Keycloak
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Setup Java
uses: actions/setup-java@v3
with:
distribution: temurin
java-version: 17
check-latest: true
cache: maven
- name: Build Keycloak
run: |
mvn clean install --batch-mode --errors -DskipTests -DskipTestsuite -DskipExamples -DskipAccount2 -DskipCommon -Pdistribution
mv ./quarkus/dist/target/keycloak-999.0.0-SNAPSHOT.tar.gz ./keycloak-999.0.0-SNAPSHOT.tar.gz
- name: Upload Keycloak dist
uses: actions/upload-artifact@v3
with:
name: keycloak
path: keycloak-999.0.0-SNAPSHOT.tar.gz
admin-client:
name: Admin Client
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
env:
WORKSPACE: "@keycloak/keycloak-admin-client"
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- run: npm run lint --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run build --workspace=${{ env.WORKSPACE }}
working-directory: js
keycloak-js:
name: Keycloak JS
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
env:
WORKSPACE: keycloak-js
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- run: npm run build --workspace=${{ env.WORKSPACE }}
working-directory: js
keycloak-masthead:
name: Keycloak Masthead
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
env:
WORKSPACE: keycloak-masthead
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- run: npm run lint --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run build --workspace=${{ env.WORKSPACE }}
working-directory: js
ui-shared:
name: UI Shared
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
env:
WORKSPACE: ui-shared
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- run: npm run lint --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run build --workspace=${{ env.WORKSPACE }}
working-directory: js
account-ui:
name: Account UI
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
env:
WORKSPACE: account-ui
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- run: npm run lint --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run build --workspace=${{ env.WORKSPACE }}
working-directory: js
admin-ui:
name: Admin UI
needs: conditional
if: needs.conditional.outputs.js-ci == 'true'
runs-on: ubuntu-latest
env:
WORKSPACE: admin-ui
steps:
- uses: actions/checkout@v3
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- run: npm run lint --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run test --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run build --workspace=${{ env.WORKSPACE }}
working-directory: js
- run: npm run cy:check-types --workspace=${{ env.WORKSPACE }}
working-directory: js
admin-ui-e2e:
name: Admin UI E2E
needs:
- conditional
- build-keycloak
if: needs.conditional.outputs.js-ci == 'true' && github.repository == 'keycloak/keycloak'
runs-on: ubuntu-latest
env:
WORKSPACE: admin-ui
strategy:
matrix:
container: [1, 2, 3, 4, 5]
steps:
- uses: actions/checkout@v3
- name: Install Google Chrome
uses: browser-actions/setup-chrome@v1
with:
chrome-version: stable
- uses: ./.github/actions/npm-setup
with:
working-directory: js
- name: Compile Admin Client
run: npm run build --workspace=@keycloak/keycloak-admin-client
working-directory: js
- name: Download Keycloak server
uses: actions/download-artifact@v3
with:
name: keycloak
- name: Start Keycloak Server
run: |
tar xfvz keycloak-999.0.0-SNAPSHOT.tar.gz
keycloak-999.0.0-SNAPSHOT/bin/kc.sh start-dev --features=admin-fine-grained-authz,declarative-user-profile &> ~/server.log &
env:
KEYCLOAK_ADMIN: admin
KEYCLOAK_ADMIN_PASSWORD: admin
- name: Start LDAP server
run: npm run cy:ldap-server --workspace=${{ env.WORKSPACE }} &
working-directory: js
- name: Run Cypress
uses: cypress-io/github-action@v5
with:
install: false
record: true
parallel: true
browser: chrome
wait-on: http://localhost:8080
working-directory: js/apps/admin-ui
env:
CYPRESS_BASE_URL: http://localhost:8080/admin/
CYPRESS_KEYCLOAK_SERVER: http://localhost:8080
CYPRESS_RECORD_KEY: b8f1d15e-eab8-4ee7-8e44-c6d7cd8fc0eb
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Upload server logs
uses: actions/upload-artifact@v3
with:
name: server-log-${{ matrix.container }}
path: ~/server.log
check-set-status:
name: Set check conclusion
needs:
- admin-client
- keycloak-js
- keycloak-masthead
- ui-shared
- account-ui
- admin-ui
- admin-ui-e2e
runs-on: ubuntu-latest
outputs:
conclusion: ${{ steps.check.outputs.conclusion }}
steps:
- uses: actions/checkout@v3
- id: check
uses: ./.github/actions/checks-success
check:
name: Status Check - Keycloak JavaScript CI
if: always() && ( github.event_name != 'schedule' || github.repository == 'keycloak/keycloak' )
needs:
- conditional
- check-set-status
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Check status
uses: ./.github/actions/checks-job-pass
with:
required: ${{ needs.conditional.outputs.js-ci }}
conclusion: ${{ needs.check-set-status.outputs.conclusion }}