mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 21:01:02 +00:00
579 lines
22 KiB
YAML
579 lines
22 KiB
YAML
# .gitlab-ci.yml
|
|
#
|
|
# polkadot
|
|
#
|
|
# pipelines can be triggered manually in the web
|
|
# setting DEPLOY_TAG will only deploy the tagged image
|
|
#
|
|
# please do not add new jobs without "rules:" and "*-env". There are &rules-test for everything,
|
|
# &rules-pr-only preset. And "kubernetes-env" with "docker-env" to set a runner
|
|
# which executes the job.
|
|
|
|
stages:
|
|
- test
|
|
- build
|
|
- publish
|
|
- deploy
|
|
|
|
image: paritytech/ci-linux:production
|
|
|
|
workflow:
|
|
rules:
|
|
- if: $CI_COMMIT_TAG
|
|
- if: $CI_COMMIT_BRANCH
|
|
|
|
variables:
|
|
GIT_STRATEGY: fetch
|
|
GIT_DEPTH: 100
|
|
CI_SERVER_NAME: "GitLab CI"
|
|
DOCKER_OS: "debian:stretch"
|
|
ARCH: "x86_64"
|
|
VAULT_SERVER_URL: "https://vault.parity-mgmt-vault.parity.io"
|
|
VAULT_AUTH_PATH: "gitlab-parity-io-jwt"
|
|
VAULT_AUTH_ROLE: "cicd_gitlab_parity_${CI_PROJECT_NAME}"
|
|
|
|
default:
|
|
cache: {}
|
|
|
|
.collect-artifacts: &collect-artifacts
|
|
artifacts:
|
|
name: "${CI_JOB_NAME}_${CI_COMMIT_REF_NAME}"
|
|
when: on_success
|
|
expire_in: 28 days
|
|
paths:
|
|
- ./artifacts/
|
|
|
|
.kubernetes-env: &kubernetes-env
|
|
retry:
|
|
max: 2
|
|
when:
|
|
- runner_system_failure
|
|
- unknown_failure
|
|
- api_failure
|
|
interruptible: true
|
|
tags:
|
|
- kubernetes-parity-build
|
|
|
|
.docker-env: &docker-env
|
|
retry:
|
|
max: 2
|
|
when:
|
|
- runner_system_failure
|
|
- unknown_failure
|
|
- api_failure
|
|
interruptible: true
|
|
tags:
|
|
- linux-docker
|
|
|
|
.compiler-info: &compiler-info
|
|
before_script:
|
|
- rustup show
|
|
- cargo --version
|
|
- sccache -s
|
|
|
|
.rules-test: &rules-test
|
|
# these jobs run always*
|
|
rules:
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
when: never
|
|
- when: always
|
|
|
|
.pr-only: &rules-pr-only
|
|
# these jobs run only on PRs
|
|
rules:
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
when: never
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
when: never
|
|
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs
|
|
|
|
#### Vault secrets
|
|
.vault-secrets: &vault-secrets
|
|
secrets:
|
|
AWS_ACCESS_KEY_ID:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/AWS_ACCESS_KEY_ID@kv
|
|
file: false
|
|
AWS_SECRET_ACCESS_KEY:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/AWS_SECRET_ACCESS_KEY@kv
|
|
file: false
|
|
DOCKER_HUB_USER:
|
|
vault: cicd/gitlab/parity/DOCKER_HUB_USER@kv
|
|
file: false
|
|
DOCKER_HUB_PASS:
|
|
vault: cicd/gitlab/parity/DOCKER_HUB_PASS@kv
|
|
file: false
|
|
GITHUB_PR_TOKEN:
|
|
vault: cicd/gitlab/parity/GITHUB_PR_TOKEN@kv
|
|
file: false
|
|
GITHUB_USER:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/GITHUB_USER@kv
|
|
file: false
|
|
GITHUB_RELEASE_TOKEN:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/GITHUB_RELEASE_TOKEN@kv
|
|
file: false
|
|
GITHUB_TOKEN:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/GITHUB_TOKEN@kv
|
|
file: false
|
|
MATRIX_ACCESS_TOKEN:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/MATRIX_ACCESS_TOKEN@kv
|
|
file: false
|
|
MATRIX_ROOM_ID:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/MATRIX_ROOM_ID@kv
|
|
file: false
|
|
PARITYPR_USER:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/PARITYPR_USER@kv
|
|
file: false
|
|
PARITYPR_PASS:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/PARITYPR_PASS@kv
|
|
file: false
|
|
PIPELINE_TOKEN:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/PIPELINE_TOKEN@kv
|
|
file: false
|
|
REL_MAN_ROOM_ID:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/REL_MAN_ROOM_ID@kv
|
|
file: false
|
|
SSH_PRIVATE_KEY:
|
|
vault: cicd/gitlab/$CI_PROJECT_PATH/SSH_PRIVATE_KEY@kv
|
|
file: false
|
|
|
|
#### stage: test
|
|
|
|
check-runtime:
|
|
stage: test
|
|
image: paritytech/tools:latest
|
|
<<: *kubernetes-env
|
|
<<: *rules-pr-only
|
|
<<: *vault-secrets
|
|
variables:
|
|
GITLAB_API: "https://gitlab.parity.io/api/v4"
|
|
GITHUB_API_PROJECT: "parity%2Finfrastructure%2Fgithub-api"
|
|
script:
|
|
- ./scripts/gitlab/check_runtime.sh
|
|
allow_failure: true
|
|
|
|
check-line-width:
|
|
stage: test
|
|
image: paritytech/tools:latest
|
|
<<: *kubernetes-env
|
|
<<: *rules-pr-only
|
|
script:
|
|
- ./scripts/gitlab/check_line_width.sh
|
|
allow_failure: true
|
|
|
|
cargo-fmt:
|
|
stage: test
|
|
<<: *kubernetes-env
|
|
<<: *rules-pr-only
|
|
script:
|
|
- cargo +nightly fmt --all -- --check
|
|
allow_failure: true
|
|
|
|
test-deterministic-wasm:
|
|
stage: test
|
|
<<: *rules-test
|
|
<<: *docker-env
|
|
<<: *compiler-info
|
|
<<: *vault-secrets
|
|
script:
|
|
- ./scripts/gitlab/test_deterministic_wasm.sh
|
|
|
|
test-build-linux-stable:
|
|
stage: test
|
|
<<: *docker-env
|
|
<<: *compiler-info
|
|
<<: *collect-artifacts
|
|
<<: *vault-secrets
|
|
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 -Dwarnings"
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
- if: $CI_COMMIT_REF_NAME =~ /^v[0-9]+\.[0-9]+.*$/ # i.e. v1.0, v2.1rc1
|
|
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
script:
|
|
- ./scripts/gitlab/test_linux_stable.sh
|
|
# we're using the bin built here, instead of having a parallel `build-linux-release`
|
|
- time cargo build --release --verbose --bin polkadot
|
|
- sccache -s
|
|
# pack artifacts
|
|
- mkdir -p ./artifacts
|
|
- VERSION="${CI_COMMIT_REF_NAME}" # will be tag or branch name
|
|
- mv ./target/release/polkadot ./artifacts/.
|
|
- sha256sum ./artifacts/polkadot | tee ./artifacts/polkadot.sha256
|
|
- EXTRATAG="$(./artifacts/polkadot --version |
|
|
sed -n -r 's/^polkadot ([0-9.]+.*-[0-9a-f]{7,13})-.*$/\1/p')"
|
|
- EXTRATAG="${CI_COMMIT_REF_NAME}-${EXTRATAG}-$(cut -c 1-8 ./artifacts/polkadot.sha256)"
|
|
- echo "Polkadot version = ${VERSION} (EXTRATAG = ${EXTRATAG})"
|
|
- echo -n ${VERSION} > ./artifacts/VERSION
|
|
- echo -n ${EXTRATAG} > ./artifacts/EXTRATAG
|
|
- cp -r scripts/docker/* ./artifacts
|
|
|
|
check-runtime-benchmarks:
|
|
stage: test
|
|
<<: *rules-test
|
|
<<: *docker-env
|
|
<<: *compiler-info
|
|
<<: *vault-secrets
|
|
script:
|
|
# Check that the node will compile with `runtime-benchmarks` feature flag.
|
|
- ./scripts/gitlab/check_runtime_benchmarks.sh
|
|
- sccache -s
|
|
|
|
check-no-default-features:
|
|
stage: test
|
|
<<: *rules-test
|
|
<<: *docker-env
|
|
<<: *compiler-info
|
|
<<: *vault-secrets
|
|
script:
|
|
# Check that polkadot-cli will compile no default features.
|
|
- ./scripts/gitlab/check_no_default_features.sh
|
|
- sccache -s
|
|
|
|
spellcheck:
|
|
stage: test
|
|
<<: *docker-env
|
|
<<: *rules-pr-only
|
|
script:
|
|
- cargo spellcheck --version
|
|
# compare with the commit parent to the PR, given it's from a default branch
|
|
- git fetch origin +${CI_DEFAULT_BRANCH}:${CI_DEFAULT_BRANCH}
|
|
- time cargo spellcheck check -vvv --cfg=scripts/gitlab/spellcheck.toml --checkers hunspell --code 1
|
|
-r $(git diff --name-only ${CI_COMMIT_SHA} $(git merge-base ${CI_COMMIT_SHA} ${CI_DEFAULT_BRANCH}))
|
|
allow_failure: true
|
|
|
|
build-adder-collator:
|
|
stage: test
|
|
<<: *collect-artifacts
|
|
<<: *docker-env
|
|
<<: *compiler-info
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
script:
|
|
- time cargo build --release --verbose -p test-parachain-adder-collator
|
|
- sccache -s
|
|
# pack artifacts
|
|
- mkdir -p ./artifacts
|
|
- mv ./target/release/adder-collator ./artifacts/.
|
|
- echo -n "${CI_COMMIT_REF_NAME}" > ./artifacts/VERSION
|
|
- echo -n "${CI_COMMIT_REF_NAME}-${CI_COMMIT_SHORT_SHA}" > ./artifacts/EXTRATAG
|
|
- echo "adder-collator version = $(cat ./artifacts/VERSION) (EXTRATAG = $(cat ./artifacts/EXTRATAG))"
|
|
- cp -r scripts/docker/* ./artifacts
|
|
|
|
#### stage: build
|
|
|
|
check-transaction-versions:
|
|
image: node:15
|
|
stage: build
|
|
<<: *rules-test
|
|
<<: *docker-env
|
|
<<: *vault-secrets
|
|
needs:
|
|
- job: test-build-linux-stable
|
|
artifacts: true
|
|
before_script:
|
|
- apt-get -y update; apt-get -y install jq lsof
|
|
- npm install --ignore-scripts -g @polkadot/metadata-cmp
|
|
- git fetch origin release
|
|
script:
|
|
- scripts/gitlab/check_extrinsics_ordering.sh
|
|
|
|
generate-impl-guide:
|
|
stage: build
|
|
<<: *rules-test
|
|
<<: *docker-env
|
|
image:
|
|
name: michaelfbryan/mdbook-docker-image:v0.4.4
|
|
entrypoint: [""]
|
|
script:
|
|
- mdbook build roadmap/implementers-guide
|
|
|
|
build-rustdoc:
|
|
stage: build
|
|
<<: *docker-env
|
|
<<: *rules-test
|
|
variables:
|
|
SKIP_WASM_BUILD: 1
|
|
artifacts:
|
|
name: "${CI_JOB_NAME}_${CI_COMMIT_REF_NAME}-doc"
|
|
when: on_success
|
|
expire_in: 7 days
|
|
paths:
|
|
- ./crate-docs/
|
|
script:
|
|
# FIXME: it fails with `RUSTDOCFLAGS="-Dwarnings"` and `--all-features`
|
|
- time cargo doc --no-deps --workspace --verbose
|
|
- rm -f ./target/doc/.lock
|
|
- mv ./target/doc ./crate-docs
|
|
# FIXME: remove me after CI image gets nonroot
|
|
- chown -R nonroot:nonroot ./crate-docs
|
|
- echo "<meta http-equiv=refresh content=0;url=polkadot_service/index.html>" > ./crate-docs/index.html
|
|
- sccache -s
|
|
|
|
.build-push-image: &build-push-image
|
|
<<: *kubernetes-env
|
|
<<: *vault-secrets
|
|
image: quay.io/buildah/stable
|
|
variables: &image-variables
|
|
GIT_STRATEGY: none
|
|
DOCKER_USER: ${PARITYPR_USER}
|
|
DOCKER_PASS: ${PARITYPR_PASS}
|
|
before_script: &check-versions
|
|
- test -s ./artifacts/VERSION || exit 1
|
|
- test -s ./artifacts/EXTRATAG || exit 1
|
|
- VERSION="$(cat ./artifacts/VERSION)"
|
|
- EXTRATAG="$(cat ./artifacts/EXTRATAG)"
|
|
- echo "Polkadot version = ${VERSION} (EXTRATAG = ${EXTRATAG})"
|
|
script:
|
|
- test "$DOCKER_USER" -a "$DOCKER_PASS" ||
|
|
( echo "no docker credentials provided"; exit 1 )
|
|
- cd ./artifacts
|
|
- buildah bud
|
|
--format=docker
|
|
--build-arg VCS_REF="${CI_COMMIT_SHA}"
|
|
--build-arg BUILD_DATE="$(date -u '+%Y-%m-%dT%H:%M:%SZ')"
|
|
--build-arg IMAGE_NAME="${IMAGE_NAME}"
|
|
--tag "$IMAGE_NAME:$VERSION"
|
|
--tag "$IMAGE_NAME:$EXTRATAG"
|
|
--file ${DOCKERFILE} .
|
|
# The job will success only on the protected branch
|
|
- echo "$DOCKER_PASS" |
|
|
buildah login --username "$DOCKER_USER" --password-stdin docker.io
|
|
- buildah info
|
|
- buildah push --format=v2s2 "$IMAGE_NAME:$VERSION"
|
|
- buildah push --format=v2s2 "$IMAGE_NAME:$EXTRATAG"
|
|
after_script:
|
|
- buildah logout --all
|
|
|
|
publish-polkadot-image:
|
|
stage: build
|
|
<<: *build-push-image
|
|
variables:
|
|
<<: *image-variables
|
|
# scripts/docker/Dockerfile
|
|
DOCKERFILE: Dockerfile
|
|
IMAGE_NAME: docker.io/paritypr/synth-wave
|
|
rules:
|
|
# Don't run on releases - this is handled by the Github Action here:
|
|
# .github/workflows/publish-docker-release.yml
|
|
- if: $CI_COMMIT_REF_NAME =~ /^v[0-9]+\.[0-9]+.*$/ # i.e. v1.0, v2.1rc1
|
|
when: never
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
variables:
|
|
<<: *image-variables
|
|
IMAGE_NAME: docker.io/parity/rococo
|
|
DOCKER_USER: ${DOCKER_HUB_USER}
|
|
DOCKER_PASS: ${DOCKER_HUB_PASS}
|
|
needs:
|
|
- job: test-build-linux-stable
|
|
artifacts: true
|
|
after_script:
|
|
# pass artifacts to the simnet-tests job
|
|
# https://docs.gitlab.com/ee/ci/multi_project_pipelines.html#with-variable-inheritance
|
|
- echo "PARACHAINS_IMAGE_NAME=${IMAGE_NAME}" > ./artifacts/parachains.env
|
|
- echo "PARACHAINS_IMAGE_TAG=$(cat ./artifacts/EXTRATAG)" >> ./artifacts/parachains.env
|
|
artifacts:
|
|
reports:
|
|
# this artifact is used in simnet-tests job
|
|
dotenv: ./artifacts/parachains.env
|
|
|
|
publish-adder-collator-image:
|
|
# service image for Simnet
|
|
stage: build
|
|
<<: *build-push-image
|
|
variables:
|
|
<<: *image-variables
|
|
# scripts/docker/collator.Dockerfile
|
|
DOCKERFILE: collator.Dockerfile
|
|
IMAGE_NAME: docker.io/paritypr/colander
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
needs:
|
|
- job: build-adder-collator
|
|
artifacts: true
|
|
after_script:
|
|
- buildah logout --all
|
|
# pass artifacts to the simnet-tests job
|
|
- echo "COLLATOR_IMAGE_NAME=${IMAGE_NAME}" > ./artifacts/collator.env
|
|
- echo "COLLATOR_IMAGE_TAG=$(cat ./artifacts/EXTRATAG)" >> ./artifacts/collator.env
|
|
artifacts:
|
|
reports:
|
|
# this artifact is used in simnet-tests job
|
|
dotenv: ./artifacts/collator.env
|
|
|
|
.update_weights: &update-weights
|
|
stage: build
|
|
when: manual
|
|
tags:
|
|
- weights
|
|
variables:
|
|
RUNTIME: polkadot
|
|
artifacts:
|
|
paths:
|
|
- ${RUNTIME}_weights_${CI_COMMIT_SHORT_SHA}.patch
|
|
script: |
|
|
./scripts/run_benches_for_runtime.sh $RUNTIME
|
|
git diff -P > ${RUNTIME}_weights_${CI_COMMIT_SHORT_SHA}.patch
|
|
|
|
update_polkadot_weights:
|
|
<<: *update-weights
|
|
|
|
update_kusama_weights:
|
|
<<: *update-weights
|
|
variables:
|
|
RUNTIME: kusama
|
|
|
|
update_westend_weights:
|
|
<<: *update-weights
|
|
variables:
|
|
RUNTIME: westend
|
|
|
|
#### stage: publish
|
|
|
|
publish-s3-release: &publish-s3
|
|
stage: publish
|
|
needs:
|
|
- job: test-build-linux-stable
|
|
artifacts: true
|
|
<<: *kubernetes-env
|
|
<<: *vault-secrets
|
|
image: paritytech/awscli:latest
|
|
variables:
|
|
GIT_STRATEGY: none
|
|
PREFIX: "builds/polkadot/${ARCH}-${DOCKER_OS}"
|
|
rules:
|
|
# publishing binaries nightly
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
before_script:
|
|
- *check-versions
|
|
script:
|
|
- echo "uploading objects to https://releases.parity.io/${PREFIX}/${VERSION}"
|
|
- aws s3 sync --acl public-read ./artifacts/ s3://${AWS_BUCKET}/${PREFIX}/${VERSION}/
|
|
- echo "update objects at https://releases.parity.io/${PREFIX}/${EXTRATAG}"
|
|
- find ./artifacts -type f | while read file; do
|
|
name="${file#./artifacts/}";
|
|
aws s3api copy-object
|
|
--copy-source ${AWS_BUCKET}/${PREFIX}/${VERSION}/${name}
|
|
--bucket ${AWS_BUCKET} --key ${PREFIX}/${EXTRATAG}/${name};
|
|
done
|
|
- |
|
|
cat <<-EOM
|
|
|
|
|
| polkadot binary paths:
|
|
|
|
|
| - https://releases.parity.io/${PREFIX}/${EXTRATAG}/polkadot
|
|
| - https://releases.parity.io/${PREFIX}/${VERSION}/polkadot
|
|
|
|
|
EOM
|
|
after_script:
|
|
- aws s3 ls s3://${AWS_BUCKET}/${PREFIX}/${EXTRATAG}/
|
|
--recursive --human-readable --summarize
|
|
|
|
publish-rustdoc:
|
|
stage: publish
|
|
<<: *kubernetes-env
|
|
<<: *vault-secrets
|
|
image: paritytech/tools:latest
|
|
variables:
|
|
GIT_DEPTH: 100
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "web" && $CI_COMMIT_REF_NAME == "master"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
# `needs:` can be removed after CI image gets nonroot. In this case `needs:` stops other
|
|
# artifacts from being dowloaded by this job.
|
|
needs:
|
|
- job: build-rustdoc
|
|
artifacts: true
|
|
script:
|
|
- rm -rf /tmp/*
|
|
# Set git config
|
|
- rm -rf .git/config
|
|
- git config user.email "devops-team@parity.io"
|
|
- git config user.name "${GITHUB_USER}"
|
|
- git config remote.origin.url "https://${GITHUB_TOKEN}@github.com/paritytech/polkadot.git"
|
|
- git config remote.origin.fetch "+refs/heads/*:refs/remotes/origin/*"
|
|
- git fetch origin gh-pages
|
|
# Save README and docs
|
|
- cp -r ./crate-docs/ /tmp/doc/
|
|
- cp README.md /tmp/doc/
|
|
- git checkout gh-pages
|
|
# Remove everything and restore generated docs and README
|
|
- rm -rf ./*
|
|
- mv /tmp/doc/* .
|
|
# Upload files
|
|
- git add --all --force
|
|
# `git commit` has an exit code of > 0 if there is nothing to commit.
|
|
# This causes GitLab to exit immediately and marks this job failed.
|
|
# We don't want to mark the entire job failed if there's nothing to
|
|
# publish though, hence the `|| true`.
|
|
- git commit -m "Updated docs for ${CI_COMMIT_REF_NAME}" ||
|
|
echo "___Nothing to commit___"
|
|
- git push origin gh-pages --force
|
|
after_script:
|
|
- rm -rf .git/ ./*
|
|
|
|
#### stage: deploy
|
|
|
|
deploy-polkasync-kusama:
|
|
stage: deploy
|
|
rules:
|
|
# former .rules-build
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
when: never
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
variables:
|
|
POLKADOT_CI_COMMIT_NAME: "${CI_COMMIT_REF_NAME}"
|
|
POLKADOT_CI_COMMIT_REF: "${CI_COMMIT_SHORT_SHA}"
|
|
allow_failure: true
|
|
trigger: "parity/infrastructure/parity-testnet"
|
|
|
|
simnet-tests:
|
|
stage: deploy
|
|
image: "docker.io/paritytech/simnet:${SIMNET_REF}"
|
|
<<: *kubernetes-env
|
|
rules:
|
|
- if: $CI_PIPELINE_SOURCE == "schedule"
|
|
- if: $CI_COMMIT_REF_NAME == "master"
|
|
- if: $CI_COMMIT_REF_NAME =~ /^[0-9]+$/ # PRs
|
|
- if: $CI_COMMIT_REF_NAME == "rococo-v1"
|
|
needs:
|
|
- job: publish-polkadot-image
|
|
- job: publish-adder-collator-image
|
|
# `parachains.env` brings here `$PARACHAINS_IMAGE_NAME` and `$PARACHAINS_IMAGE_TAG`
|
|
# (`$EXTRATAG` here, # i.e. `2643-0.8.29-5f689e0a-6b24dc54`).
|
|
# `collator.env` brings here `$COLLATOR_IMAGE_NAME` and `$COLLATOR_IMAGE_TAG`
|
|
# For local tests with docker `$PARACHAINS_IMAGE_TAG` and `$COLLATOR_IMAGE_TAG`
|
|
# can be replaced with `master` tag.
|
|
|
|
# SIMNET_REF is a gitlab variable
|
|
before_script:
|
|
- echo "Simnet Tests Config
|
|
${SIMNET_IMAGE_NAME} ${SIMNET_REF}
|
|
${PARACHAINS_IMAGE_NAME} ${PARACHAINS_IMAGE_TAG}
|
|
${COLLATOR_IMAGE_NAME} ${COLLATOR_IMAGE_TAG}"
|
|
script:
|
|
- /home/nonroot/simnet/gurke/scripts/run-test-environment-manager.sh
|
|
--github-remote-dir="https://github.com/paritytech/polkadot/tree/master/simnet_tests"
|
|
--config="simnet_tests/configs/simple_rococo_testnet.toml"
|
|
--image="${PARACHAINS_IMAGE_NAME}:${PARACHAINS_IMAGE_TAG}"
|
|
--image-2="${COLLATOR_IMAGE_NAME}:${COLLATOR_IMAGE_TAG}"
|
|
--image-simnet="docker.io/paritytech/simnet:${SIMNET_REF}"
|
|
allow_failure: true
|
|
retry: 2
|
|
tags:
|
|
- parity-simnet
|