.gitlab-ci.yml 7.62 KiB
Newer Older
# pipelines can be triggered manually in the web
# setting DEPLOY_TAG will only deploy the tagged image


gabriel klawitter's avatar
gabriel klawitter committed
stages:
gabriel klawitter's avatar
gabriel klawitter committed
  - test
  - build
gabriel klawitter's avatar
gabriel klawitter committed
image:                             parity/rust:nightly

variables:
  CI_SERVER_NAME:                  "GitLab CI"
  CARGO_HOME:                      "${CI_PROJECT_DIR}/.cargo"
  # have OS based build containers in the future
  DOCKER_OS:                       "ubuntu:xenial"
  ARCH:                            "x86_64"
.collect-artifacts:                &collect-artifacts
gabriel klawitter's avatar
gabriel klawitter committed
  artifacts:
    name:                          "${CI_JOB_NAME}_${CI_COMMIT_REF_NAME}"
    when:                          on_success
    expire_in:                     7 days
    paths:
.kubernetes-build:                 &kubernetes-build
  tags:
    - kubernetes-parity-build
  environment:
#### stage:                        merge-test

check-merge-conflict:
  stage:                           merge-test
  image:                           parity/tools:latest
  cache:                           {}
  <<:                              *kubernetes-build
  only:
    - /^[0-9]+$/
  variables:
    GITHUB_API:                    "https://api.github.com"
    GITLAB_API:                    "https://gitlab.parity.io/api/v4"
    GITHUB_API_PROJECT:            "parity%2Finfrastructure%2Fgithub-api"
  script:
    - ./scripts/gitlab/check_merge_conflict.sh



test-linux-stable:                  &test
gabriel klawitter's avatar
gabriel klawitter committed
  stage:                           test
  cache:
    key:                           "${CI_JOB_NAME}-test"
    paths:
      - ${CARGO_HOME}
      - ./target
  variables:
    RUST_TOOLCHAIN: stable
    # Enable debug assertions since we are running optimized builds for testing
    # but still want to have debug assertions.
    RUSTFLAGS: -Cdebug-assertions=y
    TARGET: native
  tags:
    - linux-docker
gabriel klawitter's avatar
gabriel klawitter committed
  only:
    - tags
    - master
    - schedules
    - web
  before_script:
   - test -d ${CARGO_HOME} -a -d ./target &&
     echo "build cache size:" &&
     du -h --max-depth=2 ${CARGO_HOME} ./target
   - ./scripts/build.sh
    - time cargo test --all --release --verbose --locked


.build-only:                      &build-only
  only:
    - master
    - tags
    - web


build-linux-release:          &build
gabriel klawitter's avatar
gabriel klawitter committed
  stage:                           build
  cache:
    key:                           "${CI_JOB_NAME}-build"
    paths:
      - ${CARGO_HOME}
      - ./target
  <<:                              *collect-artifacts
  <<:                              *build-only
    - linux-docker
  before_script:
   - ./scripts/build.sh
gabriel klawitter's avatar
gabriel klawitter committed
  script:
    - time cargo build --release --verbose
    - mkdir -p ./artifacts
    - mv ./target/release/polkadot ./artifacts/.
    - echo -n "Polkadot version = "
    - if [ "${CI_COMMIT_TAG}" ]; then
        echo "${CI_COMMIT_TAG}" | tee ./artifacts/VERSION;
        ./artifacts/polkadot --version |
        sed -n -r 's/^polkadot ([0-9.]+.*-[0-9a-f]{7,13})-.*$/\1/p' |
        tee ./artifacts/VERSION;
      fi
    - sha256sum ./artifacts/polkadot | tee ./artifacts/polkadot.sha256
    - cp -r scripts/docker/* ./artifacts

.publish-build:                    &publish-build
    - build-linux-release
  <<:                              *build-only
  <<:                              *kubernetes-build



publish-docker-release:
  <<:                              *publish-build
  image:                           docker:stable
  services:
    - docker:dind
  # collect VERSION artifact here to pass it on to kubernetes
  <<:                              *collect-artifacts
    DOCKER_HOST:                   tcp://localhost:2375
    DOCKER_DRIVER:                 overlay2
    GIT_STRATEGY:                  none
    # DOCKERFILE:                  scripts/docker/Dockerfile
    CONTAINER_IMAGE:               parity/polkadot
  before_script:
    - test "$Docker_Hub_User_Parity" -a "$Docker_Hub_Pass_Parity"
        || ( echo "no docker credentials provided"; exit 1 )
    - docker login -u "$Docker_Hub_User_Parity" -p "$Docker_Hub_Pass_Parity"
    - docker info
  script:
    - VERSION="$(cat ./artifacts/VERSION)"
    - echo "Polkadot version = ${VERSION}"
    - cd ./artifacts
    - docker build --tag $CONTAINER_IMAGE:$VERSION --tag $CONTAINER_IMAGE:latest .
    - docker push $CONTAINER_IMAGE:$VERSION
    - docker push $CONTAINER_IMAGE:latest
  after_script:
    - docker logout
    # only VERSION information is needed for the deployment
    - find ./artifacts/ -depth -not -name VERSION -not -name artifacts -delete




publish-s3-release:
  <<:                              *publish-build
  image:                           parity/awscli:latest
  variables:
    GIT_STRATEGY:                  none
    BUCKET:                        "releases.parity.io"
    PREFIX:                        "polkadot/${ARCH}-${DOCKER_OS}"
  script:
    - aws s3 sync ./artifacts/ s3://${BUCKET}/${PREFIX}/$(cat ./artifacts/VERSION)/
    - echo "update objects in latest path"
    - for file in ./artifacts/*; do
      name="$(basename ${file})";
      aws s3api copy-object
        --copy-source ${BUCKET}/${PREFIX}/$(cat ./artifacts/VERSION)/${name}
        --bucket ${BUCKET} --key ${PREFIX}/latest/${name};
      done
  after_script:
    - aws s3 ls s3://${BUCKET}/${PREFIX}/latest/
        --recursive --human-readable --summarize
.deploy-template:                  &deploy
  image:                           parity/kubetools:latest
gabriel klawitter's avatar
gabriel klawitter committed
  tags:
    # this is the runner that is used to deploy it
    - kubernetes-parity-build
    - test -z "${DEPLOY_TAG}" &&
      test -f ./artifacts/VERSION &&
      DEPLOY_TAG="$(cat ./artifacts/VERSION)"
    - test "${DEPLOY_TAG}" || ( echo "Neither DEPLOY_TAG nor VERSION information available"; exit 1 )
  script:
    - echo "Polkadot version = ${DEPLOY_TAG}"
    # or use helm to render the template
    - helm template
      --values ./scripts/kubernetes/values.yaml
      ./scripts/kubernetes | kubectl apply -f - --dry-run=false
    - echo "# polkadot namespace"
    - kubectl -n polkadot get all
    - echo "# polkadot's nodes' external ip addresses:"
    - kubectl get nodes -l node=polkadot
      -o jsonpath='{range .items[*]}{.metadata.name}{"\t"}{range @.status.addresses[?(@.type=="ExternalIP")]}{.address}{"\n"}{end}'
    - echo "# polkadots' nodes"
    - kubectl -n polkadot get pods
      -o jsonpath='{range .items[*]}{.metadata.name}{"\t"}{.spec.nodeName}{"\n"}{end}'





.deploy-cibuild:                   &deploy-cibuild
  dependencies:
    - publish-docker-release

.deploy-tag:                       &deploy-tag
  <<:                              *deploy
  only:
    variables:
      - $DEPLOY_TAG



# have environment:url eventually point to the logs
deploy-ew3:
  <<:                              *deploy-cibuild
    name: parity-prod-ew3
deploy-ue1:
  <<:                              *deploy-cibuild
    name: parity-prod-ue1
deploy-ew3-tag:
  <<:                              *deploy-tag
  environment:
    name: parity-prod-ew3

deploy-ue1-tag:
  <<:                              *deploy-tag
  environment:
    name: parity-prod-ue1