Skip to content
Snippets Groups Projects
.gitlab-ci.yml 14.1 KiB
Newer Older
    - pull-db
    - test-coverage
    - deploy-coverage-page
    - generate-go-yaml
    - go-trigger
    # Gitlab optimization https://docs.gitlab.com/ee/ci/large_repositories/
    GIT_DEPTH: 10
    # Workspaces default variables
    PROJECT_NAME: "workspaces"
    ENV_HOST: ws-dev.nrao.edu
    # Postgres Service Variables
    POSTGRES_DB: archive
    POSTGRES_USER: "archive"
    POSTGRES_PASSWORD: "docker"

    - if: $CI_MERGE_REQUEST_TITLE =~ /^WIP:|^Draft:/
      when: never
    - if: $CI_MERGE_REQUEST_IID
    - if: $CI_COMMIT_TAG
    - if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH || $CI_COMMIT_BRANCH =~ /(^[0-9]\.[0-9]|^[0-9]\.[0-9]\.[0-9])-DEVELOPMENT/'
# Import Templates
include:
    - '/ci/build.template.yml'
    - '/ci/push.template.yml'
    - '/ci/cleanup.template.yml'
    - '/ci/unit-test.template.yml'
    - '/ci/push-package.template.yml'

# Unit testing steps require a specific database image to be available; this step downloads it
pull db image:
    stage: pull-db
        - echo "$HARBOR_PASSWORD" | docker login --username "$HARBOR_USER" --password-stdin "$REGISTRY_URL"
        - docker pull ${REGISTRY_URL}/workspaces/db:workspaces
###############################################
###############################################
    PACKAGE_PATH: "apps/cli/executables/pexable/carta_envoy"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/casa_envoy"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/utilities/core_sampler"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/conveyor"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
  interruptible: true
    PACKAGE_PATH: "apps/cli/executables/pexable/deliver"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/ingest_envoy"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/mediator"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/null"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/productfetcher"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/update_stage"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/vela"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/wf_inspector"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/ws_annihilator"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package
    PACKAGE_PATH: "apps/cli/executables/pexable/ws_metrics"
Daniel Lyons's avatar
Daniel Lyons committed
  extends: .build-package

###############################################
# Build Service and Web Images
###############################################
    variables:
        SERVICE_NAME: "workflow"
    extends: .build
    variables:
        SERVICE_NAME: "capability"
    variables:
        SERVICE_NAME: "notification"
    variables:
        SERVICE_NAME: "web"
        PATH_PREFIX: "apps/"
    extends: .build
###############################################
# Test Stages for Services
###############################################
        PATH_PREFIX: "services/"
    variables:
        SERVICE_NAME: "capability"
        PATH_PREFIX: "services/"
    variables:
        SERVICE_NAME: "notification"
        PATH_PREFIX: "services/"
    extends: .unit-test


###############################################
# Create Coverage Report
###############################################
.unit test coverage:
    stage: test-coverage
    image: python:3.10-slim
    before_script:
        - pip install pytest pytest-cov
        - coverage report -i --omit="**/test_*.py,**/_version.py,**/conftest.py,**/*interfaces.py" --skip-empty
        - coverage xml -i --omit="**/test_*.py,**/_version.py,**/conftest.py,**/*interfaces.py" --skip-empty
        - coverage html -i --omit="**/test_*.py,**/_version.py,**/conftest.py,**/*interfaces.py" --skip-empty
          coverage_report:
            coverage_format: cobertura
            path: coverage.xml
      - unit test workflow
      - unit test capability
      - unit test notification
        - if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH || $CI_COMMIT_BRANCH =~ /(^[0-9]\.[0-9]|^[0-9]\.[0-9]\.[0-9])-DEVELOPMENT/'
        - if: '$CI_PIPELINE_SOURCE == "merge_request_event"'

###############################################
# Push Service and Web Images to Registry
###############################################
        PATH_PREFIX: "services/"
        PATH_PREFIX: "services/"
    variables:
        SERVICE_NAME: "notification"
        PATH_PREFIX: "services/"
        PATH_PREFIX: "apps/"
    extends: .push
    # UI tests coming soon!
    # needs:
    #     - unit test dev ui

###############################################
# Push Packages
###############################################
push carta-envoy:
  stage: push-packages
  variables:
    PACKAGE_NAME: "carta_envoy"
    PIP_NAME: "carta-envoy"
  extends: .push-packages

push casa-envoy:
  stage: push-packages
  variables:
    PACKAGE_NAME: "casa_envoy"
    PIP_NAME: "casa-envoy"
  extends: .push-packages

push conveyor:
  stage: push-packages
  variables:
    PACKAGE_NAME: "conveyor"
    PIP_NAME: "conveyor"
  extends: .push-packages

push deliver:
  stage: push-packages
  variables:
Brittany Faciane's avatar
Brittany Faciane committed
    PACKAGE_NAME: "deliver"
    PIP_NAME: "ssa_deliver"
  extends: .push-packages

push ingest-envoy:
  stage: push-packages
  variables:
    PACKAGE_NAME: "ingest_envoy"
    PIP_NAME: "ingest-envoy"
  extends: .push-packages

push mediator:
  stage: push-packages
  variables:
Brittany Faciane's avatar
Brittany Faciane committed
    PACKAGE_NAME: "mediator"
    PIP_NAME: "ssa_mediator"
  extends: .push-packages

push null:
  stage: push-packages
  variables:
Brittany Faciane's avatar
Brittany Faciane committed
    PACKAGE_NAME: "null"
    PIP_NAME: "ssa_null"
  extends: .push-packages

push productfetcher:
  stage: push-packages
  variables:
    PACKAGE_NAME: "productfetcher"
    PIP_NAME: "productfetcher"
  extends: .push-packages

push update-stage:
  stage: push-packages
  variables:
    PACKAGE_NAME: "update_stage"
    PIP_NAME: "ssa-update-stage"
  extends: .push-packages

push vela:
  stage: push-packages
  variables:
    PACKAGE_NAME: "vela"
    PIP_NAME: "ssa-vela"
  extends: .push-packages

push wf-inspector:
  stage: push-packages
  variables:
    PACKAGE_NAME: "wf_inspector"
    PIP_NAME: "wf-inspector"
  extends: .push-packages

push ws-annihilator:
  stage: push-packages
  variables:
    PACKAGE_NAME: "ws_annihilator"
    PIP_NAME: "ws-annihilator"
  extends: .push-packages

push ws-metrics:
  stage: push-packages
  variables:
    PACKAGE_NAME: "ws_metrics"
    PIP_NAME: "ws-metrics"
  extends: .push-packages

###############################################
# Clean Pipeline of Service and Web Images
###############################################
clean build workflow:
    variables:
        SERVICE_NAME: "workflow"
        PATH_PREFIX: "services/"
    extends: .cleanup
clean build capability:
    variables:
        SERVICE_NAME: "capability"
        PATH_PREFIX: "services/"
    extends: .cleanup
clean build notification:
    variables:
        SERVICE_NAME: "notification"
        PATH_PREFIX: "services/"

clean build web:
    stage: .post
    variables:
        SERVICE_NAME: "web"
        PATH_PREFIX: "apps/"
    extends: .cleanup
    allow_failure: true

###############################################
# Deployment Stages
###############################################
    stage: deploy-coverage-page
    image: python:3.10-slim
    dependencies:
        - unit test coverage
    before_script:
      - pip install -r docs/requirements.txt
      - apt update
      - apt install make
    script:
        - mkdir public
        - mv htmlcov public/htmlcov
        - cd docs && make html && mv _build/html/* ../public/
    artifacts:
        paths:
        - public
        expire_in: 2 weeks
    rules:
      - if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH || $CI_COMMIT_BRANCH =~ /(^[0-9]\.[0-9]|^[0-9]\.[0-9]\.[0-9])-DEVELOPMENT/'
Charlotte Hausman's avatar
Charlotte Hausman committed
 # Generate go builder yaml for child pipeline
go generate yaml:
Charlotte Hausman's avatar
Charlotte Hausman committed
   stage: generate-go-yaml
   image: python:3.10-slim
Charlotte Hausman's avatar
Charlotte Hausman committed
   before_script:
       - apt update && apt install -y git
       - pip install pyyaml
   script:
       - DEPLOY_ENV=${DEPLOY_ENV} ./ci/bin/generate-go-yaml.py
   rules:
       - if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH || $CI_COMMIT_BRANCH =~ /(^[0-9]\.[0-9]|^[0-9]\.[0-9]\.[0-9])-DEVELOPMENT/'
Charlotte Hausman's avatar
Charlotte Hausman committed
         changes:
           - apps/cli/executables/go/**/*
       - if: '$CI_COMMIT_TAG =~ /^end-of-sprint-[0-9]+/ || $CI_COMMIT_TAG =~ /[0-9]+\.[0-9]+\.[0-9]+-rc[0-9]+/'
         variables:
           # override DEPLOY_ENV
           DEPLOY_ENV: "test"
       - if: '$CI_COMMIT_TAG =~ /[0-9]+\.[0-9]+\.[0-9]+$/'
         variables:
           DEPLOY_ENV: "prod"
   artifacts:
       paths:
           - generated-go-build-pipeline.yml

 # Trigger child pipeline based on generated go builder yaml
go child pipeline:
Charlotte Hausman's avatar
Charlotte Hausman committed
   stage: go-trigger
   trigger:
       include:
           - artifact: generated-go-build-pipeline.yml
             job: go generate yaml
       strategy: depend
   rules:
       - if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH || $CI_COMMIT_BRANCH =~ /(^[0-9]\.[0-9]|^[0-9]\.[0-9]\.[0-9])-DEVELOPMENT/'
Charlotte Hausman's avatar
Charlotte Hausman committed
         changes:
           - apps/cli/executables/go/**/*
       - if: '$CI_COMMIT_TAG =~ /^end-of-sprint-[0-9]+/ || $CI_COMMIT_TAG =~ /[0-9]+\.[0-9]+\.[0-9]+-rc[0-9]+/'
         variables:
           # override DEPLOY_ENV
           DEPLOY_ENV: "test"
       - if: '$CI_COMMIT_TAG =~ /[0-9]+\.[0-9]+\.[0-9]+$/'
         variables:
           DEPLOY_ENV: "prod"
    script:
        # Docker doesn't allow variable interpolation when declaring Docker Secret names
        # This sed command finds and replaces "dsoc_ENV_secrets:" with "dsoc_${DEPLOY_ENV}_secrets:"
        - sed -i "s/dsoc_ENV_secrets:/dsoc_${DEPLOY_ENV}_secrets:/g" docker-compose.yml
        - sed -i "s/naasc_ENV_secrets:/naasc_${DEPLOY_ENV}_secrets:/g" docker-compose.yml
        - ENV=$DEPLOY_ENV TAG=$IMAGE_TAG DL_HOST=$DL_HOST ENV_HOST=$ENV_HOST WS_VERSION=$VERSION BASE_REGISTRY_URL=$REGISTRY_URL docker stack deploy --compose-file docker-compose.yml --with-registry-auth workspaces-${DEPLOY_ENV}
    rules:
Charlotte Hausman's avatar
Charlotte Hausman committed
        - if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH || $CI_COMMIT_BRANCH =~ /(^[0-9]\.[0-9]|^[0-9]\.[0-9]\.[0-9])-DEVELOPMENT/'
Charlotte Hausman's avatar
Charlotte Hausman committed
            IMAGE_TAG: ${CI_COMMIT_BRANCH}
            # override DEPLOY_ENV
            DEPLOY_ENV: "dev"
            # override DL_HOST
            DL_HOST: https://dl-nrao.nrao.edu
            # override ENV_HOST
            ENV_HOST: ws-dev.nrao.edu
Charlotte Hausman's avatar
Charlotte Hausman committed
            VERSION: 0.0.1+$CI_COMMIT_BRANCH
        - if: '$CI_COMMIT_TAG =~ /^end-of-sprint-[0-9]+/'
          variables:
            IMAGE_TAG: $CI_COMMIT_TAG
            # override DEPLOY_ENV
            DEPLOY_ENV: "test"
            # override DL_HOST
            DL_HOST: https://dl-dsoc-test.nrao.edu
            # override ENV_HOST
            ENV_HOST: ws-test.nrao.edu
            VERSION: 0.0.2+$CI_COMMIT_TAG
        - if: '$CI_COMMIT_TAG =~ /[0-9]+\.[0-9]+\.[0-9]+-rc[0-9]+/'
          variables:
            IMAGE_TAG: $CI_COMMIT_TAG
            # override DEPLOY_ENV
            DEPLOY_ENV: "test"
            # override DL_HOST
            DL_HOST: https://dl-dsoc-test.nrao.edu
            ENV_HOST: ws-test.nrao.edu
Charlotte Hausman's avatar
Charlotte Hausman committed
            VERSION: $CI_COMMIT_TAG
        - if: '$CI_COMMIT_TAG =~ /[0-9]+\.[0-9]+\.[0-9]+$/'
          variables:
            IMAGE_TAG: $CI_COMMIT_TAG
            # override DEPLOY_ENV
            DEPLOY_ENV: "prod"
            # override DL_HOST
            DL_HOST: https://dl-dsoc.nrao.edu
            # override ENV_HOST
            ENV_HOST: ws.nrao.edu
Charlotte Hausman's avatar
Charlotte Hausman committed
            VERSION: $CI_COMMIT_TAG