ci: Generalize the GitLab CI pipeline yaml (#23225)
* ci: Generalize the GitLab CI pipeline yaml * ci: Rename cloud_e4s_pipelines to the more general cloud_pipelines
This commit is contained in:
parent
2473e0cc82
commit
e3054c3318
@ -1,60 +1,125 @@
|
|||||||
stages: [generate, build]
|
stages: [ "generate", "build" ]
|
||||||
|
|
||||||
|
default:
|
||||||
|
image: { "name": "ghcr.io/scottwittenburg/ecpe4s-ubuntu18.04-runner-x86_64:2020-09-01", "entrypoint": [""] }
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# Job templates
|
||||||
|
########################################
|
||||||
|
|
||||||
|
.pr:
|
||||||
|
only:
|
||||||
|
- /^github\/pr[\d]+_.*$/
|
||||||
|
variables:
|
||||||
|
SPACK_PR_BRANCH: ${CI_COMMIT_REF_NAME}
|
||||||
|
SPACK_IS_PR_PIPELINE: "True"
|
||||||
|
|
||||||
|
.develop:
|
||||||
|
only:
|
||||||
|
- /^github\/develop$/
|
||||||
|
variables:
|
||||||
|
SPACK_IS_PR_PIPELINE: "False"
|
||||||
|
|
||||||
.generate:
|
.generate:
|
||||||
stage: generate
|
stage: generate
|
||||||
script:
|
script:
|
||||||
- . "./share/spack/setup-env.sh"
|
- . "./share/spack/setup-env.sh"
|
||||||
- spack --version
|
- spack --version
|
||||||
- cd share/spack/gitlab/cloud_e4s_pipelines/stacks/e4s
|
- cd share/spack/gitlab/cloud_pipelines/stacks/${SPACK_CI_STACK_NAME}
|
||||||
- spack env activate --without-view .
|
- spack env activate --without-view .
|
||||||
- spack ci generate --check-index-only
|
- spack ci generate --check-index-only
|
||||||
--output-file "${CI_PROJECT_DIR}/jobs_scratch_dir/e4s_pipeline.yml"
|
--output-file "${CI_PROJECT_DIR}/jobs_scratch_dir/cloud-ci-pipeline.yml"
|
||||||
artifacts:
|
artifacts:
|
||||||
paths:
|
paths:
|
||||||
- "${CI_PROJECT_DIR}/jobs_scratch_dir/e4s_pipeline.yml"
|
- "${CI_PROJECT_DIR}/jobs_scratch_dir/cloud-ci-pipeline.yml"
|
||||||
tags: ["spack", "public", "medium", "x86_64"]
|
tags: ["spack", "public", "medium", "x86_64"]
|
||||||
interruptible: true
|
interruptible: true
|
||||||
|
|
||||||
e4s-pr-generate:
|
.pr-generate:
|
||||||
only:
|
extends: [ ".pr", ".generate" ]
|
||||||
- /^github\/pr[\d]+_.*$/
|
|
||||||
extends: .generate
|
|
||||||
before_script:
|
|
||||||
- export SPACK_PR_BRANCH=${CI_COMMIT_REF_NAME}
|
|
||||||
- export SPACK_IS_PR_PIPELINE="True"
|
|
||||||
image: { "name": "ghcr.io/scottwittenburg/ecpe4s-ubuntu18.04-runner-x86_64:2020-09-01", "entrypoint": [""] }
|
|
||||||
|
|
||||||
e4s-develop-generate:
|
.develop-generate:
|
||||||
only:
|
extends: [ ".develop", ".generate" ]
|
||||||
- /^github\/develop$/
|
|
||||||
extends: .generate
|
|
||||||
image: { "name": "ghcr.io/scottwittenburg/ecpe4s-ubuntu18.04-runner-x86_64:2020-09-01", "entrypoint": [""] }
|
|
||||||
|
|
||||||
e4s-pr-build:
|
.build:
|
||||||
only:
|
|
||||||
- /^github\/pr[\d]+_.*$/
|
|
||||||
stage: build
|
stage: build
|
||||||
trigger:
|
|
||||||
include:
|
.pr-build:
|
||||||
- artifact: "jobs_scratch_dir/e4s_pipeline.yml"
|
extends: [ ".pr", ".build" ]
|
||||||
job: e4s-pr-generate
|
|
||||||
strategy: depend
|
|
||||||
variables:
|
variables:
|
||||||
AWS_ACCESS_KEY_ID: ${PR_MIRRORS_AWS_ACCESS_KEY_ID}
|
AWS_ACCESS_KEY_ID: ${PR_MIRRORS_AWS_ACCESS_KEY_ID}
|
||||||
AWS_SECRET_ACCESS_KEY: ${PR_MIRRORS_AWS_SECRET_ACCESS_KEY}
|
AWS_SECRET_ACCESS_KEY: ${PR_MIRRORS_AWS_SECRET_ACCESS_KEY}
|
||||||
SPACK_PR_BRANCH: ${CI_COMMIT_REF_NAME}
|
|
||||||
SPACK_IS_PR_PIPELINE: "True"
|
|
||||||
|
|
||||||
e4s-develop-build:
|
.develop-build:
|
||||||
only:
|
extends: [ ".develop", ".build" ]
|
||||||
- /^github\/develop$/
|
|
||||||
stage: build
|
|
||||||
trigger:
|
|
||||||
include:
|
|
||||||
- artifact: "jobs_scratch_dir/e4s_pipeline.yml"
|
|
||||||
job: e4s-develop-generate
|
|
||||||
strategy: depend
|
|
||||||
variables:
|
variables:
|
||||||
AWS_ACCESS_KEY_ID: ${MIRRORS_AWS_ACCESS_KEY_ID}
|
AWS_ACCESS_KEY_ID: ${MIRRORS_AWS_ACCESS_KEY_ID}
|
||||||
AWS_SECRET_ACCESS_KEY: ${MIRRORS_AWS_SECRET_ACCESS_KEY}
|
AWS_SECRET_ACCESS_KEY: ${MIRRORS_AWS_SECRET_ACCESS_KEY}
|
||||||
SPACK_SIGNING_KEY: ${PACKAGE_SIGNING_KEY}
|
SPACK_SIGNING_KEY: ${PACKAGE_SIGNING_KEY}
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# TEMPLATE FOR ADDING ANOTHER PIPELINE
|
||||||
|
########################################
|
||||||
|
#
|
||||||
|
# First add a new spack.yml defining the pipline to run in
|
||||||
|
# share/spack/gitlab/cloud_pipelines/stacks/my-super-cool-stack/spack.yaml
|
||||||
|
#
|
||||||
|
# Then add the following entries at the bottom of this file:
|
||||||
|
#
|
||||||
|
########################################
|
||||||
|
# My Super Cool Pipeline
|
||||||
|
########################################
|
||||||
|
# .my-super-cool-stack:
|
||||||
|
# variables:
|
||||||
|
# SPACK_CI_STACK_NAME: my-super-cool-stack
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-pr-generate:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".pr-generate"]
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-develop-generate:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".develop-generate"]
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-pr-build:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".pr-build" ]
|
||||||
|
# trigger:
|
||||||
|
# include:
|
||||||
|
# - artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
# job: my-super-cool-stack-pr-generate
|
||||||
|
# strategy: depend
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-develop-build:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".develop-build" ]
|
||||||
|
# trigger:
|
||||||
|
# include:
|
||||||
|
# - artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
# job: my-super-cool-stack-develop-generate
|
||||||
|
# strategy: depend
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# E4S pipeline
|
||||||
|
########################################
|
||||||
|
.e4s:
|
||||||
|
variables:
|
||||||
|
SPACK_CI_STACK_NAME: e4s
|
||||||
|
|
||||||
|
e4s-pr-generate:
|
||||||
|
extends: [ ".e4s", ".pr-generate"]
|
||||||
|
|
||||||
|
e4s-develop-generate:
|
||||||
|
extends: [ ".e4s", ".develop-generate"]
|
||||||
|
|
||||||
|
e4s-pr-build:
|
||||||
|
extends: [ ".e4s", ".pr-build" ]
|
||||||
|
trigger:
|
||||||
|
include:
|
||||||
|
- artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
job: e4s-pr-generate
|
||||||
|
strategy: depend
|
||||||
|
|
||||||
|
e4s-develop-build:
|
||||||
|
extends: [ ".e4s", ".develop-build" ]
|
||||||
|
trigger:
|
||||||
|
include:
|
||||||
|
- artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
job: e4s-develop-generate
|
||||||
|
strategy: depend
|
||||||
|
125
share/spack/gitlab/cloud_pipelines/.gitlab-ci.yml
Normal file
125
share/spack/gitlab/cloud_pipelines/.gitlab-ci.yml
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
stages: [ "generate", "build" ]
|
||||||
|
|
||||||
|
default:
|
||||||
|
image: { "name": "ghcr.io/scottwittenburg/ecpe4s-ubuntu18.04-runner-x86_64:2020-09-01", "entrypoint": [""] }
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# Job templates
|
||||||
|
########################################
|
||||||
|
|
||||||
|
.pr:
|
||||||
|
only:
|
||||||
|
- /^github\/pr[\d]+_.*$/
|
||||||
|
variables:
|
||||||
|
SPACK_PR_BRANCH: ${CI_COMMIT_REF_NAME}
|
||||||
|
SPACK_IS_PR_PIPELINE: "True"
|
||||||
|
|
||||||
|
.develop:
|
||||||
|
only:
|
||||||
|
- /^github\/develop$/
|
||||||
|
variables:
|
||||||
|
SPACK_IS_PR_PIPELINE: "False"
|
||||||
|
|
||||||
|
.generate:
|
||||||
|
stage: generate
|
||||||
|
script:
|
||||||
|
- . "./share/spack/setup-env.sh"
|
||||||
|
- spack --version
|
||||||
|
- cd share/spack/gitlab/cloud_pipelines/stacks/${SPACK_CI_STACK_NAME}
|
||||||
|
- spack env activate --without-view .
|
||||||
|
- spack ci generate --check-index-only
|
||||||
|
--output-file "${CI_PROJECT_DIR}/jobs_scratch_dir/cloud-ci-pipeline.yml"
|
||||||
|
artifacts:
|
||||||
|
paths:
|
||||||
|
- "${CI_PROJECT_DIR}/jobs_scratch_dir/cloud-ci-pipeline.yml"
|
||||||
|
tags: ["spack", "public", "medium", "x86_64"]
|
||||||
|
interruptible: true
|
||||||
|
|
||||||
|
.pr-generate:
|
||||||
|
extends: [ ".pr", ".generate" ]
|
||||||
|
|
||||||
|
.develop-generate:
|
||||||
|
extends: [ ".develop", ".generate" ]
|
||||||
|
|
||||||
|
.build:
|
||||||
|
stage: build
|
||||||
|
|
||||||
|
.pr-build:
|
||||||
|
extends: [ ".pr", ".build" ]
|
||||||
|
variables:
|
||||||
|
AWS_ACCESS_KEY_ID: ${PR_MIRRORS_AWS_ACCESS_KEY_ID}
|
||||||
|
AWS_SECRET_ACCESS_KEY: ${PR_MIRRORS_AWS_SECRET_ACCESS_KEY}
|
||||||
|
|
||||||
|
.develop-build:
|
||||||
|
extends: [ ".develop", ".build" ]
|
||||||
|
variables:
|
||||||
|
AWS_ACCESS_KEY_ID: ${MIRRORS_AWS_ACCESS_KEY_ID}
|
||||||
|
AWS_SECRET_ACCESS_KEY: ${MIRRORS_AWS_SECRET_ACCESS_KEY}
|
||||||
|
SPACK_SIGNING_KEY: ${PACKAGE_SIGNING_KEY}
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# TEMPLATE FOR ADDING ANOTHER PIPELINE
|
||||||
|
########################################
|
||||||
|
#
|
||||||
|
# First add a new spack.yml defining the pipline to run in
|
||||||
|
# share/spack/gitlab/cloud_pipelines/stacks/my-super-cool-stack/spack.yaml
|
||||||
|
#
|
||||||
|
# Then add the following entries at the bottom of this file:
|
||||||
|
#
|
||||||
|
########################################
|
||||||
|
# My Super Cool Pipeline
|
||||||
|
########################################
|
||||||
|
# .my-super-cool-stack:
|
||||||
|
# variables:
|
||||||
|
# SPACK_CI_STACK_NAME: my-super-cool-stack
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-pr-generate:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".pr-generate"]
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-develop-generate:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".develop-generate"]
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-pr-build:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".pr-build" ]
|
||||||
|
# trigger:
|
||||||
|
# include:
|
||||||
|
# - artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
# job: my-super-cool-stack-pr-generate
|
||||||
|
# strategy: depend
|
||||||
|
#
|
||||||
|
# my-super-cool-stack-develop-build:
|
||||||
|
# extends: [ ".my-super-cool-stack", ".develop-build" ]
|
||||||
|
# trigger:
|
||||||
|
# include:
|
||||||
|
# - artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
# job: my-super-cool-stack-develop-generate
|
||||||
|
# strategy: depend
|
||||||
|
|
||||||
|
########################################
|
||||||
|
# E4S pipeline
|
||||||
|
########################################
|
||||||
|
.e4s:
|
||||||
|
variables:
|
||||||
|
SPACK_CI_STACK_NAME: e4s
|
||||||
|
|
||||||
|
e4s-pr-generate:
|
||||||
|
extends: [ ".e4s", ".pr-generate"]
|
||||||
|
|
||||||
|
e4s-develop-generate:
|
||||||
|
extends: [ ".e4s", ".develop-generate"]
|
||||||
|
|
||||||
|
e4s-pr-build:
|
||||||
|
extends: [ ".e4s", ".pr-build" ]
|
||||||
|
trigger:
|
||||||
|
include:
|
||||||
|
- artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
job: e4s-pr-generate
|
||||||
|
strategy: depend
|
||||||
|
|
||||||
|
e4s-develop-build:
|
||||||
|
extends: [ ".e4s", ".develop-build" ]
|
||||||
|
trigger:
|
||||||
|
include:
|
||||||
|
- artifact: jobs_scratch_dir/cloud-ci-pipeline.yml
|
||||||
|
job: e4s-develop-generate
|
||||||
|
strategy: depend
|
@ -121,7 +121,7 @@ spack:
|
|||||||
script:
|
script:
|
||||||
- . "./share/spack/setup-env.sh"
|
- . "./share/spack/setup-env.sh"
|
||||||
- spack --version
|
- spack --version
|
||||||
- cd share/spack/gitlab/cloud_e4s_pipelines/stacks/e4s
|
- cd share/spack/gitlab/cloud_pipelines/stacks/e4s
|
||||||
- spack env activate --without-view .
|
- spack env activate --without-view .
|
||||||
- spack -d ci rebuild
|
- spack -d ci rebuild
|
||||||
mappings:
|
mappings:
|
||||||
@ -138,7 +138,7 @@ spack:
|
|||||||
before_script:
|
before_script:
|
||||||
- . "./share/spack/setup-env.sh"
|
- . "./share/spack/setup-env.sh"
|
||||||
- spack --version
|
- spack --version
|
||||||
- cd share/spack/gitlab/cloud_e4s_pipelines/stacks/e4s
|
- cd share/spack/gitlab/cloud_pipelines/stacks/e4s
|
||||||
- spack env activate --without-view .
|
- spack env activate --without-view .
|
||||||
image: { "name": "ghcr.io/scottwittenburg/ecpe4s-ubuntu18.04-runner-x86_64:2020-09-01", "entrypoint": [""] }
|
image: { "name": "ghcr.io/scottwittenburg/ecpe4s-ubuntu18.04-runner-x86_64:2020-09-01", "entrypoint": [""] }
|
||||||
tags: ["spack", "public", "medium", "x86_64"]
|
tags: ["spack", "public", "medium", "x86_64"]
|
Loading…
Reference in New Issue
Block a user