Skip to content

Filtering

Filtering #8

Workflow file for this run

name: CI/CD
on:
workflow_dispatch:
push:
paths-ignore:
- 'README.md'
- '.github/**'
branches: [ main ]
pull_request:
paths-ignore:
- 'README.md'
- '.github/**'
defaults:
run:
shell: PowerShell
jobs:
Initialization:
runs-on: [ windows-latest ]
outputs:
telemetryScopeJson: ${{ steps.init.outputs.telemetryScopeJson }}
settings: ${{ steps.ReadSettings.outputs.SettingsJson }}
projects: ${{ steps.ReadSettings.outputs.ProjectsJson }}
projectCount: ${{ steps.ReadSettings.outputs.ProjectCount }}
environments: ${{ steps.ReadSettings.outputs.EnvironmentsJson }}
environmentCount: ${{ steps.ReadSettings.outputs.EnvironmentCount }}
githubRunner: ${{ steps.ReadSettings.outputs.GitHubRunnerJson }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Initialize the workflow
id: init
uses: microsoft/AL-Go-Actions/WorkflowInitialize@v0.1
with:
eventId: "DO0091"
- name: Read settings
id: ReadSettings
uses: microsoft/AL-Go-Actions/ReadSettings@v0.1
with:
parentTelemetryScopeJson: ${{ steps.init.outputs.telemetryScopeJson }}
getProjects: 'Y'
getEnvironments: '*'
CheckForUpdates:
runs-on: [ windows-latest ]
needs: [ Initialization ]
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Read settings
uses: microsoft/AL-Go-Actions/ReadSettings@v0.1
with:
parentTelemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}
get: TemplateUrl
- name: Check for updates to AL-Go system files
uses: microsoft/AL-Go-Actions/CheckForUpdates@v0.1
with:
parentTelemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}
templateUrl: ${{ env.TemplateUrl }}
Build:
needs: [ Initialization ]
runs-on: ${{ fromJson(needs.Initialization.outputs.githubRunner) }}
strategy:
matrix:
project: ${{ fromJson(needs.Initialization.outputs.projects) }}
fail-fast: false
name: Build ${{ matrix.project }}
outputs:
AppsArtifactsName: ${{ steps.calculateArtifactNames.outputs.AppsArtifactsName }}
TestAppsArtifactsName: ${{ steps.calculateArtifactNames.outputs.TestAppsArtifactsName }}
TestResultsArtifactsName: ${{ steps.calculateArtifactNames.outputs.TestResultsArtifactsName }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Read settings
uses: microsoft/AL-Go-Actions/ReadSettings@v0.1
with:
parentTelemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}
project: ${{ matrix.project }}
- name: Read secrets
uses: microsoft/AL-Go-Actions/ReadSecrets@v0.1
env:
secrets: ${{ toJson(secrets) }}
with:
parentTelemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}
settingsJson: ${{ env.Settings }}
secrets: 'licenseFileUrl,insiderSasToken,CodeSignCertificateUrl,CodeSignCertificatePassword,KeyVaultCertificateUrl,KeyVaultCertificatePassword,KeyVaultClientId'
- name: Run pipeline
uses: microsoft/AL-Go-Actions/RunPipeline@v0.1
with:
parentTelemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}
Project: ${{ matrix.project }}
settingsJson: ${{ env.Settings }}
SecretsJson: ${{ env.RepoSecrets }}
- name: Calculate Artifact names
id: calculateArtifactNames
if: success() || failure()
run: |
$settings = '${{ env.Settings }}' | ConvertFrom-Json
$project = '${{ matrix.project }}'
if ($project -eq ".") { $project = $settings.RepoName }
$AppsArtifactsName = "$project-Apps-$($settings.repoVersion).$($settings.appBuild).$($settings.appRevision)"
$TestAppsArtifactsName = "$project-TestApps-$($settings.repoVersion).$($settings.appBuild).$($settings.appRevision)"
$TestResultsArtifactsName = "$project-TestResults"
'AppsArtifactsName','TestAppsArtifactsName','TestResultsArtifactsName' | ForEach-Object {
$value = (Get-Variable -Name $_).Value
Write-Host "::set-output name=$_::$value"
Add-Content -Path $env:GITHUB_ENV -Value "$_=$value"
}
- name: Publish artifacts - apps
uses: actions/upload-artifact@v2
with:
name: ${{ env.appsArtifactsName }}
path: '${{ matrix.project }}/output/Apps/'
if-no-files-found: ignore
- name: Publish artifacts - test apps
uses: actions/upload-artifact@v2
with:
name: ${{ env.testAppsArtifactsName }}
path: '${{ matrix.project }}/output/TestApps/'
if-no-files-found: ignore
- name: Publish artifacts - test results
uses: actions/upload-artifact@v2
if: success() || failure()
with:
name: ${{ env.testResultsArtifactsName }}
path: '${{ matrix.project }}/TestResults.xml'
if-no-files-found: ignore
- name: Cleanup
if: always()
uses: microsoft/AL-Go-Actions/PipelineCleanup@v0.1
with:
parentTelemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}
Project: ${{ matrix.project }}
Deploy:
runs-on: [ windows-latest ]
needs: [ Initialization, Build ]
if: ${{ github.event_name != 'pull request' && needs.Initialization.outputs.environmentCount > 0 }}
strategy:
matrix:
environment: ${{ fromJson(needs.Initialization.outputs.environments) }}
fail-fast: false
name: Deploy to ${{ matrix.environment }}
environment:
name: ${{ matrix.environment }}
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Download artifacts
uses: actions/download-artifact@v2
with:
path: '${{ github.workspace }}\artifacts'
- name: EnvName
id: envName
run: |
$envName = '${{ matrix.environment }}'.split(' ')[0]
Write-Host "::set-output name=envName::$envName"
- name: Read settings
uses: microsoft/AL-Go-Actions/ReadSettings@v0.1
- name: Read secrets
uses: microsoft/AL-Go-Actions/ReadSecrets@v0.1
env:
secrets: ${{ toJson(secrets) }}
with:
settingsJson: ${{ env.Settings }}
secrets: '${{ steps.envName.outputs.envName }}-AuthContext,AuthContext'
- name: AuthContext
id: authContext
run: |
$authContext = [System.Environment]::GetEnvironmentVariable('${{ steps.envName.outputs.envName }}-AuthContext')
if ($authContext) {
Write-Host "Using ${{ steps.envName.outputs.envName }}-AuthContext secret"
}
else {
$authContext = [System.Environment]::GetEnvironmentVariable('AuthContext')
if ($authContext) {
Write-Host "Using AuthContext secret"
}
else {
Write-Host "::Error::No AuthContext provided"
exit 1
}
}
Write-Host "::set-output name=authContext::$authContext"
Write-Host "set-output name=authContext::$authContext"
- name: Deploy
uses: microsoft/AL-Go-Actions/Deploy@v0.1
env:
authContext: '${{ steps.authContext.outputs.authContext }}'
with:
type: 'CD'
projects: '${{ secrets.Projects }}'
environmentName: ${{ matrix.environment }}
artifacts: '${{ github.workspace }}\artifacts'
PostProcess:
if: always()
runs-on: [ windows-latest ]
needs: [ Initialization, Build, Deploy ]
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Finalize the workflow
id: PostProcess
uses: microsoft/AL-Go-Actions/WorkflowPostProcess@v0.1
with:
eventId: "DO0091"
telemetryScopeJson: ${{ needs.Initialization.outputs.telemetryScopeJson }}