Skip to content
Snippets Groups Projects
.gitlab-ci.yml 6.15 KiB
Newer Older
Varac's avatar
Varac committed
include:
  - remote: https://open.greenhost.net/openappstack/openappstack/raw/master/.gitlab/ci_templates/kaniko.yml

Mark's avatar
Mark committed
stages:
  - build
Mark's avatar
Mark committed
  - build-test-images
Mark's avatar
Mark committed
  - application-test
Mark's avatar
Mark committed
  - integration-test
Mark's avatar
Mark committed

Varac's avatar
Varac committed
consent_provider:
Mark's avatar
Mark committed
  stage: build
Varac's avatar
Varac committed
  variables:
    KANIKO_CONTEXT: "consent_provider"
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
Mark's avatar
Mark committed
  only:
    changes:
Mark's avatar
Mark committed
      - consent_provider/**/*
      - .gitlab-ci.yml
Mark's avatar
Mark committed

Mark's avatar
Mark committed
logout_provider:
  stage: build
  variables:
    KANIKO_CONTEXT: "logout_provider"
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
  only:
    changes:
      - logout_provider/**/*
      - .gitlab-ci.yml

Varac's avatar
Varac committed
login_provider:
Mark's avatar
Mark committed
  stage: build
Varac's avatar
Varac committed
  variables:
    KANIKO_CONTEXT: "login_provider"
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
Mark's avatar
Mark committed
  only:
    changes:
Mark's avatar
Mark committed
      - login_provider/**/*
      - .gitlab-ci.yml
# Build kratos image
Mart van Santen's avatar
Mart van Santen committed
kratos:
  stage: build
  needs: []
  variables:
    KANIKO_CONTEXT: "kratos"
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
  only:
    changes:
      - kratos/**/*
      - .gitlab-ci.yml


Mark's avatar
Mark committed
integration_test_app:
Mark's avatar
Mark committed
  stage: build-test-images
Mark's avatar
Mark committed
  variables:
Mark's avatar
Mark committed
    KANIKO_CONTEXT: "test/integration_tests"
Mark's avatar
Mark committed
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
  only:
    changes:
Mark's avatar
Mark committed
      - test/integration_tests/**/*
      - .gitlab-ci.yml

integration_test:
Mark's avatar
Mark committed
  stage: build-test-images
Mark's avatar
Mark committed
    KANIKO_CONTEXT: "test/integration_tests/test"
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
  only:
    changes:
Mark's avatar
Mark committed
      - test/integration_tests/test/**/*
      - test/integration_tests/test/Dockerfile
      - .gitlab-ci.yml

pylint:
  stage: build-test-images
  variables:
    KANIKO_CONTEXT: "test/lint/pylint"
    KANIKO_BUILD_IMAGENAME: $CI_JOB_NAME
  extends: .kaniko_build
  only:
    changes:
      - test/lint/pylint/Dockerfile
      - test/lint/pylint/requirements.txt
      - .gitlab-ci.yml

Mark's avatar
Mark committed

behave-integration:
  stage: integration-test
  services:
    - name: postgres:latest
      alias: postgres
    - name: ${CI_REGISTRY_IMAGE}/login_provider:${CI_COMMIT_REF_NAME}
      alias: login
    - name: ${CI_REGISTRY_IMAGE}/consent_provider:${CI_COMMIT_REF_NAME}
      alias: consent
Mark's avatar
Mark committed
    - name: ${CI_REGISTRY_IMAGE}/logout_provider:${CI_COMMIT_REF_NAME}
      alias: logout
Mark's avatar
Mark committed
    - name: docker.io/oryd/hydra:v1.8
Mark's avatar
Mark committed
      alias: hydra
      command:
        - serve
        - all
        - --dangerous-force-http
        - --dangerous-allow-insecure-redirect-urls
Mark's avatar
Mark committed
        - "http://oidc:5000/callback"
    - name: open.greenhost.net:4567/openappstack/user-panel/backend:master
Mark's avatar
Mark committed
      alias: backend
Mark's avatar
Mark committed
    - name: ${CI_REGISTRY_IMAGE}/integration_test_app:${CI_COMMIT_REF_NAME}
Mark's avatar
Mark committed
      alias: oidc
Mark's avatar
Mark committed
  variables:
    # Feature Flag FF_NETWORK_PER_BUILD Enables creation of a docker network per build
    # with the docker executor of the gitlab-runner. This is required for service
    # interconnection. Requires gitlab-runner v12.9.0
    FF_NETWORK_PER_BUILD: 1
Mark's avatar
Mark committed
    DATABASE_HOST: "postgres"
Mark's avatar
Mark committed
    URLS_LOGIN: "http://login:5000/login"
Mark's avatar
Mark committed
    URLS_LOGOUT: "http://logout:5002/logout"
Mark's avatar
Mark committed
    URLS_CONSENT: "http://consent:5001/consent"
    URLS_SELF_ISSUER: "http://hydra:4444/"
    BASE_URL: "http://hydra:4444/"
Mark's avatar
Mark committed
    HYDRA_ADMIN_URL: "http://hydra:4445"
Mark's avatar
Mark committed
    ACCESS_TOKEN_URL: "http://hydra:4444/oauth2/token"
    AUTHORIZE_URL: "http://hydra:4444/oauth2/auth"
    USERINFO_URL: "http://hydra:4444/userinfo"
    GRAPHQL_URL: "http://backend:5000/graphql"
Mark's avatar
Mark committed
    GIT_SUBMODULE_STRATEGY: "recursive"
    TESTUSER_USERNAME: "testuser"
Mark's avatar
Mark committed
    TESTUSER_USERNAME2: "testuser2"
Mark's avatar
Mark committed
    TESTUSER_PASSWORD: "password"
    TESTUSER_EMAIL: "testuser@example.net"
Mark's avatar
Mark committed
    TESTUSER_EMAIL2: "testuser2@example.net"
Mark's avatar
Mark committed
    ROLE: "admin"
Mark's avatar
Mark committed
    DSN: "memory"
    SECRETS_SYSTEM: "youReallyNeedToChangeThis"
    DATABASE_USER: postgres
    DATABASE_PASSWORD: secret
    DATABASE_NAME: postgres
    POSTGRES_PASSWORD: secret
    POSTGRES_USER: postgres
    POSTGRES_DB: postgres
    OAUTHLIB_INSECURE_TRANSPORT: "true"
    KEY: "testapp"
    SECRET: "secret"
    DEBUG: "true"
    FLASK_ENV: "development"
  image: ${CI_REGISTRY_IMAGE}/integration_test:${CI_COMMIT_REF_NAME}
Mark's avatar
Mark committed
  script:
    # Create user and application objects
    - /bin/bash user-panel/backend/utils/create-user.bash ${TESTUSER_USERNAME} ${TESTUSER_PASSWORD} ${TESTUSER_EMAIL} backend:5000
    - /bin/bash user-panel/backend/utils/create-user.bash ${TESTUSER_USERNAME2} ${TESTUSER_PASSWORD} ${TESTUSER_EMAIL2} backend:5000
Mark's avatar
Mark committed
    - /bin/bash user-panel/backend/utils/create-application.bash ${KEY} "Application used for testing" backend:5000
    - /bin/bash user-panel/backend/utils/create-role.bash ${ROLE} backend:5000
    - /bin/bash user-panel/backend/utils/grant-access.bash ${TESTUSER_USERNAME} ${KEY} backend:5000
    - /bin/bash user-panel/backend/utils/assign-role.bash ${TESTUSER_USERNAME} ${ROLE} backend:5000
    # Wait for 60s for hydra to become available. Then create the oauth2 client object
Mark's avatar
Mark committed
    - while [[ $HYDRAADMINSTATUS -ne "200" &&  60 -ge $TIMER ]]; do HYDRAADMINSTATUS=`curl http://hydra:4445/health/ready -o /dev/null -w "%{http_code}"` || TIMER=$TIMER+5 && sleep 5 ; done
Mark's avatar
Mark committed
    - /bin/bash test/create-hydra-client.bash ${KEY} ${SECRET} http://hydra:4445 http://oidc:5000/callback http://oidc:5000/ http://oidc:5000/logout
Mark's avatar
Mark committed
    - cd test/integration_tests/test/behave/
Mark's avatar
Mark committed
    - TIMER=0
    - while [[ $HYDRASTATUS -ne "200" &&  60 -ge $TIMER ]]; do HYDRASTATUS=`curl http://hydra:4444/health/ready -o /dev/null -w "%{http_code}"` || TIMER=$TIMER+5 && sleep 5 ; done
Mark's avatar
Mark committed
    - >
        python3 -m behave
        -D headless=True
Mark's avatar
Mark committed
        -D url=http://oidc:5000
Mark's avatar
Mark committed
        -D username=${TESTUSER_USERNAME}
        -D username2=${TESTUSER_USERNAME2}
        -D password=${TESTUSER_PASSWORD}
        -D email=${TESTUSER_EMAIL}
        -D role=${ROLE}
Mark's avatar
Mark committed
  artifacts:
    paths:
Mark's avatar
Mark committed
      - test/integration_tests/test/behave/screenshots/
Mark's avatar
Mark committed
    expire_in: 1 month
    when: on_failure

pylint-lint:
  stage: lint
  variables:
    GIT_AUTHOR_NAME: "RUNNER"
    GIT_AUTHOR_EMAIL: "runner@greenhost.net"
    PYLINT_PLUGINS: "pylint_flask pylint_flask_sqlalchemy"
  image: ${CI_REGISTRY_IMAGE}/pylint:${CI_COMMIT_REF_NAME}
  script:
    - echo "Reverting back to master to squash commits"
Mart van Santen's avatar
Mart van Santen committed
    # - git reset --soft master
    - git lint