Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
40 changes: 32 additions & 8 deletions build/ci-pipeline.yml
Original file line number Diff line number Diff line change
@@ -1,12 +1,20 @@
# DESCRIPTION:
# Builds, tests, and packages the solution for the main branch.
# DESCRIPTION:
# Builds, tests, and packages the solution for the main branch.

name: $(SourceBranchName)-$(Date:yyyyMMdd)$(Rev:-r)
trigger: none

parameters:
- name: buildCriticalOnly
displayName: 'Build Critical Versions Only (skip R4B/R5)'
type: boolean
default: false

variables:
- template: ci-variables.yml
- template: build-variables.yml
- name: buildCriticalOnly
value: ${{ parameters.buildCriticalOnly }}

stages:
# *********************** Setup ***********************
Expand Down Expand Up @@ -124,17 +132,18 @@ stages:
steps:
- template: ./jobs/analyze.yml

- stage: DockerBuild
- stage: DockerBuild
displayName: 'Build images'
dependsOn:
- UpdateVersion
variables:
assemblySemFileVer: $[stageDependencies.UpdateVersion.Semver.outputs['SetVariablesFromGitVersion.assemblySemFileVer']]
jobs:
- template: ./jobs/docker-build-all.yml
parameters:
parameters:
tag: $(ImageTag)
buildPlatform: $(publicDockerImagePlatforms)
buildCriticalOnly: ${{ parameters.buildCriticalOnly }}

# *********************** Stu3 ***********************
- stage: redeployStu3
Expand Down Expand Up @@ -217,30 +226,33 @@ stages:
# *********************** R4B ***********************
- stage: redeployR4B
displayName: 'Redeploy R4B CosmosDB Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
jobs:
- template: ./jobs/redeploy-webapp.yml
parameters:
parameters:
version: R4B
webAppName: $(DeploymentEnvironmentNameR4B)
subscription: $(ConnectedServiceName)
imageTag: $(ImageTag)

- stage: redeployR4BSql
displayName: 'Redeploy R4B SQL Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
jobs:
- template: ./jobs/redeploy-webapp.yml
parameters:
parameters:
version: R4B
webAppName: $(DeploymentEnvironmentNameR4BSql)
subscription: $(ConnectedServiceName)
imageTag: $(ImageTag)

- stage: testR4B
displayName: 'Run R4B Tests'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- BuildArtifacts
- redeployR4B
Expand All @@ -256,30 +268,33 @@ stages:
# *********************** R5 ***********************
- stage: redeployR5
displayName: 'Redeploy R5 CosmosDB Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
jobs:
- template: ./jobs/redeploy-webapp.yml
parameters:
parameters:
version: R5
webAppName: $(DeploymentEnvironmentNameR5)
subscription: $(ConnectedServiceName)
imageTag: $(ImageTag)

- stage: redeployR5Sql
displayName: 'Redeploy R5 SQL Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
jobs:
- template: ./jobs/redeploy-webapp.yml
parameters:
parameters:
version: R5
webAppName: $(DeploymentEnvironmentNameR5Sql)
subscription: $(ConnectedServiceName)
imageTag: $(ImageTag)

- stage: testR5
displayName: 'Run R5 Tests'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- BuildArtifacts
- redeployR5
Expand Down Expand Up @@ -313,6 +328,15 @@ stages:
# *********************** Finalize ***********************
- stage: DockerAddTag
displayName: 'Docker add main tag'
# Run only if all required tests succeed (all 4 when buildCriticalOnly=false, only Stu3/R4 when buildCriticalOnly=true)
condition: |
and(
succeeded(),
or(
and(eq(variables.buildCriticalOnly, false), succeeded('testStu3'), succeeded('testR4'), succeeded('testR4B'), succeeded('testR5')),
and(eq(variables.buildCriticalOnly, true), succeeded('testStu3'), succeeded('testR4'))
)
)
dependsOn:
- testStu3
- testR4
Expand Down
31 changes: 18 additions & 13 deletions build/jobs/docker-build-all.yml
Original file line number Diff line number Diff line change
@@ -1,33 +1,38 @@
# DESCRIPTION:
# DESCRIPTION:
# Builds and pushes images for all supported FHIR versions

parameters:
- name: tag
type: string
- name: buildPlatform
type: string
- name: buildCriticalOnly
type: boolean
default: false

jobs:
- template: docker-build-push.yml
parameters:
parameters:
version: "R4"
tag: ${{parameters.tag}}
buildPlatform: ${{parameters.buildPlatform}}

- template: docker-build-push.yml
parameters:
version: "R4B"
tag: ${{parameters.tag}}
buildPlatform: ${{parameters.buildPlatform}}
- ${{ if eq(parameters.buildCriticalOnly, false) }}:
- template: docker-build-push.yml
parameters:
version: "R4B"
tag: ${{parameters.tag}}
buildPlatform: ${{parameters.buildPlatform}}

- template: docker-build-push.yml
parameters:
parameters:
version: "Stu3"
tag: ${{parameters.tag}}
buildPlatform: ${{parameters.buildPlatform}}

- template: docker-build-push.yml
parameters:
version: "R5"
tag: ${{parameters.tag}}
buildPlatform: ${{parameters.buildPlatform}}
- ${{ if eq(parameters.buildCriticalOnly, false) }}:
- template: docker-build-push.yml
parameters:
version: "R5"
tag: ${{parameters.tag}}
buildPlatform: ${{parameters.buildPlatform}}
41 changes: 32 additions & 9 deletions build/pr-pipeline.yml
Original file line number Diff line number Diff line change
@@ -1,11 +1,19 @@
# DESCRIPTION:
# Builds, tests, and packages the solution for all PR requests.
# DESCRIPTION:
# Builds, tests, and packages the solution for all PR requests.

trigger: none

parameters:
- name: buildCriticalOnly
displayName: 'Build Critical Versions Only (skip R4B/R5)'
type: boolean
default: false

variables:
- template: pr-variables.yml
- template: build-variables.yml
- name: buildCriticalOnly
value: ${{ parameters.buildCriticalOnly }}

stages:
- stage: UpdateVersion
Expand Down Expand Up @@ -95,17 +103,18 @@ stages:
steps:
- template: ./jobs/analyze.yml

- stage: DockerBuild
- stage: DockerBuild
displayName: 'Build images'
dependsOn:
- UpdateVersion
variables:
assemblySemFileVer: $[stageDependencies.UpdateVersion.Semver.outputs['SetVariablesFromGitVersion.assemblySemFileVer']]
jobs:
- template: ./jobs/docker-build-all.yml
parameters:
parameters:
tag: $(ImageTag)
buildPlatform: $(testDockerImagePlatforms)
buildCriticalOnly: ${{ parameters.buildCriticalOnly }}

- stage: provisionEnvironment
displayName: Provision Environment
Expand Down Expand Up @@ -284,13 +293,14 @@ stages:

- stage: deployR4B
displayName: 'Deploy R4B CosmosDB Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
- setupEnvironment
- createNsp
jobs:
- template: ./jobs/provision-deploy.yml
parameters:
parameters:
version: R4B
webAppName: $(DeploymentEnvironmentNameR4B)
appServicePlanName: '$(appServicePlanName)-cosmos'
Expand All @@ -303,13 +313,14 @@ stages:

- stage: deployR4BSql
displayName: 'Deploy R4B SQL Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
- setupEnvironment
- deploySqlServer
jobs:
- template: ./jobs/provision-deploy.yml
parameters:
parameters:
version: R4B
sql: true
webAppName: $(DeploymentEnvironmentNameR4BSql)
Expand All @@ -326,13 +337,14 @@ stages:

- stage: deployR5
displayName: 'Deploy R5 CosmosDB Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
- setupEnvironment
- createNsp
jobs:
- template: ./jobs/provision-deploy.yml
parameters:
parameters:
version: R5
webAppName: $(DeploymentEnvironmentNameR5)
appServicePlanName: '$(appServicePlanName)-cosmos'
Expand All @@ -345,13 +357,14 @@ stages:

- stage: deployR5Sql
displayName: 'Deploy R5 SQL Site'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- DockerBuild
- setupEnvironment
- deploySqlServer
jobs:
- template: ./jobs/provision-deploy.yml
parameters:
parameters:
version: R5
sql: true
webAppName: $(DeploymentEnvironmentNameR5Sql)
Expand Down Expand Up @@ -398,6 +411,7 @@ stages:

- stage: testR4B
displayName: 'Run R4B Tests'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- BuildArtifacts
- setupEnvironment
Expand All @@ -413,6 +427,7 @@ stages:

- stage: testR5
displayName: 'Run R5 Tests'
condition: eq(variables.buildCriticalOnly, false)
dependsOn:
- BuildArtifacts
- setupEnvironment
Expand Down Expand Up @@ -446,12 +461,20 @@ stages:

- stage: cleanup
displayName: 'Cleanup Azure Environment'
# Run only if all required tests succeed (all 4 when buildCriticalOnly=false, only Stu3/R4 when buildCriticalOnly=true)
condition: |
and(
succeeded(),
or(
and(eq(variables.buildCriticalOnly, false), eq(dependencies.testStu3.result, 'Succeeded'), eq(dependencies.testR4.result, 'Succeeded'), eq(dependencies.testR4B.result, 'Succeeded'), eq(dependencies.testR5.result, 'Succeeded')),
and(eq(variables.buildCriticalOnly, true), eq(dependencies.testStu3.result, 'Succeeded'), eq(dependencies.testR4.result, 'Succeeded'))
)
)
dependsOn:
- testStu3
- testR4
- testR4B
- testR5
condition: succeeded()
jobs:
- template: ./jobs/cleanup.yml

Loading
Loading