From 5fdd5000fd0493ba9e2ad881a200cc9c0fa10e0f Mon Sep 17 00:00:00 2001 From: Marcin Jastrzebski Date: Thu, 8 Apr 2021 19:28:54 -0700 Subject: [PATCH 1/4] docs --- docs/cicd-with-bicep.md | 87 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 87 insertions(+) diff --git a/docs/cicd-with-bicep.md b/docs/cicd-with-bicep.md index 3433abf82db..562c9032f1b 100644 --- a/docs/cicd-with-bicep.md +++ b/docs/cicd-with-bicep.md @@ -152,4 +152,91 @@ stages: csmFile: '$(Pipeline.Workspace)/drop/main.json' csmParametersFile: '$(Pipeline.Workspace)/drop/parameters.json' deploymentMode: 'Incremental' +``` + +## Build with MSBuild +If your existing CI pipeline heavily relies on MSBuild, you can use our MSBuild task and CLI packages to compile your .bicep files into ARM templates. + +This functionality relies on the following NuGet packages: +| Package Name | Description | +|:-|-| +| `Azure.Bicep.MSBuild` | Cross-platform MSBuild task to invoke the Bicep CLI to compile .bicep files into ARM templates | +| `Azure.Bicep.CommandLine.win-x64` | Bicep CLI for Windows | +| `Azure.Bicep.CommandLine.linux-x64` | Bicep CLI for Linux | +| `Azure.Bicep.CommandLine.osx-x64` | Bicep CLI for OSX | + +### `Azure.Bicep.CommandLine.*` packages +When referenced in a project file via a `PackageReference`, the `Azure.Bicep.CommandLine.*` packages set the `BicepPath` property to the full path of the Bicep executable for the platform. The reference to this package may be omitted if Bicep CLI is installed through other means and the `BicepPath` environment variable or MSBuild property are set accordingly. + +### `Azure.Bicep.MSBuild` package +When referenced in a project file via a `PackageReference`, the `Azure.Bicep.MSBuild` package imports the `Bicep` task used to invoke the Bicep CLI and convert its output into MSBuild errors and the `BicepCompile` target used to simplify the usage of the `Bicep` task. By default the `BicepCompile` runs after the `Build` target and will compile all `@(Bicep)` items and place the output in `$(OutputPath)` with the same file name and the `.json` extension. + +The following will compile `one.bicep` and `two.bicep` files in the same directory as the project file and placed the compiled `one.json` and `two.json` in the `$(OutputPath)`. +```msbuild + + + + +``` + +You can override the output path per file using the `OutputFile` metadata on `Bicep` items. The following will recursively find all `main.bicep` files and place the compiled `.json` files in `$(OutputPath)` under a sub-directory with the same name in `$(OutputPath)`: +```msbuild + + + +``` + +Additional customizations can be performed by setting one of the following properties in your project: +| Property Name | Default Value | Description | +|:-|:-|:-| +| `BicepCompileAfterTargets` | `Build` | Used as `AfterTargets` value for the `BicepCompile` target. Change the value to override the scheduling of the `BicepCompile` target in your project. | +| `BicepCompileDependsOn` | None | Used as `DependsOnTargets` value for the `BicepCompile` target. This can be set to targets that you want `BicepCompile` target to depend on. | +| `BicepCompileBeforeTargets` | None | Used as `BeforeTargets` value for the `BicepCompile` target. | +| `BicepOutputPath` | `$(OutputPath)` | Set this to override the default output path for the compiled ARM template. `OutputFile` metadata on `Bicep` items takes precedence over this value. | + +The `Azure.Bicep.MSBuild` requires the `BicepPath` property to be set either in order to function. You may set it by referencing the appropriate `Azure.Bicep.CommandLine.*` package for your OS or manually by installing the Bicep CLI and setting the `BicepPath` environment variable or MSBuild property. The examples below assume Windows. + +### C# Project file (.csproj) example +> Replace `__PACKAGE_VERSION__` with the latest version of the Bicep NuGet packages. + +```msbuild + + + + netstandard2.1 + + + + + + + + + + + + + + + +``` + +### NoTargets SDK example +> Replace `__PACKAGE_VERSION__` with the latest version of the Bicep NuGet packages. + +```msbuild + + + net472 + + + + + + + + + + + ``` \ No newline at end of file From 5999116f4f35297daaab1536c2b1b930bd9e3923 Mon Sep 17 00:00:00 2001 From: Marcin Jastrzebski Date: Fri, 9 Apr 2021 19:14:44 -0700 Subject: [PATCH 2/4] updated and validated --- docs/cicd-with-bicep.md | 101 +++++++++++++++++++++++++++++++++------- 1 file changed, 85 insertions(+), 16 deletions(-) diff --git a/docs/cicd-with-bicep.md b/docs/cicd-with-bicep.md index 562c9032f1b..8e06017ce60 100644 --- a/docs/cicd-with-bicep.md +++ b/docs/cicd-with-bicep.md @@ -1,19 +1,19 @@ # Adding Bicep to a CI/CD pipeline +## Build and Deploy with CI/CD As your Bicep practice matures, you will want to check-in your Bicep code into source control and kick off a pipeline or workflow, which would do the following: - 1. Build your Bicep file into an ARM Template 1. Deploy the generated ARM template With the current Azure CLI 2.20 now installed in GitHub and also on Azure DevOps, Bicep CLI can be automatically triggerd by using `az bicep build` command and an explicit task to download Bicep CLI is no more needed. -The two examples below illustrates this. It assumes the following prerequisite: +The two examples below illustrate this. They assume the following prerequisites: * The Bicep file you want to transpile and deploy is called `main.bicep` and exists in the root of the repo * The parameters file you want to use is called `parameters.json` and exists in the root of the repo * You are deploying the transpiled ARM Template to a resource group. Deploying to another scope like a subscription requires a different CLI command. -## GitHub Workflow +### GitHub Workflow ```yaml @@ -68,7 +68,7 @@ jobs: az account show az deployment group create -f ./main.json -g ${{ env.AZURE_RESOURCE_GROUP }} ``` -## Azure DevOps Pipeline +### Azure DevOps Pipeline ```yaml trigger: @@ -196,23 +196,22 @@ Additional customizations can be performed by setting one of the following prope The `Azure.Bicep.MSBuild` requires the `BicepPath` property to be set either in order to function. You may set it by referencing the appropriate `Azure.Bicep.CommandLine.*` package for your OS or manually by installing the Bicep CLI and setting the `BicepPath` environment variable or MSBuild property. The examples below assume Windows. -### C# Project file (.csproj) example -> Replace `__PACKAGE_VERSION__` with the latest version of the Bicep NuGet packages. +### SDK-based .csproj example +The following contains a default Console App SDK-based C# project file that was modified to additionally compile Bicep files into ARM templates. This type of project will work with the classic .net framework, .net core, and .net 5. + +> Replace `__LATEST_VERSION__` with the latest version of the Bicep NuGet packages. ```msbuild - - netstandard2.1 + Exe + netcoreapp3.1 - - - - - + + @@ -222,7 +221,8 @@ The `Azure.Bicep.MSBuild` requires the `BicepPath` property to be set either in ``` ### NoTargets SDK example -> Replace `__PACKAGE_VERSION__` with the latest version of the Bicep NuGet packages. +The following contains a project that compiles Bicep files into ARM templates using the NoTargets SDK. This allows creation of standalone projects that compile only Bicep files. +> Replace `__LATEST_VERSION__` with the latest version of the Bicep NuGet packages. ```msbuild @@ -231,12 +231,81 @@ The `Azure.Bicep.MSBuild` requires the `BicepPath` property to be set either in - - + + +``` + +### Classic .csproj example +The following contains an example of how to build Bicep files inside a classic .csproj file (not SDK-based). Only use this if the previous examples do not work for you. +> Replace `__LATEST_VERSION__` with the latest version of the Bicep NuGet packages. + +```msbuild + + + + + Debug + AnyCPU + {7E4E9C45-3EBE-419D-9E45-BCF7CA61961E} + Exe + ClassicFramework + ClassicFramework + v4.7.2 + 512 + true + true + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + + + + + + + + + + + + + + + + + + + __LATEST_VERSION__ + + + __LATEST_VERSION__ + + + + ``` \ No newline at end of file From 29b33f9faf1442a2e79f79a77b0456d18cdfc527 Mon Sep 17 00:00:00 2001 From: Marcin Jastrzebski Date: Fri, 9 Apr 2021 19:44:41 -0700 Subject: [PATCH 3/4] added missing asset to the script --- scripts/UploadSignedReleaseArtifacts.ps1 | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/scripts/UploadSignedReleaseArtifacts.ps1 b/scripts/UploadSignedReleaseArtifacts.ps1 index 94fa60e1b24..79efdf9eb6e 100644 --- a/scripts/UploadSignedReleaseArtifacts.ps1 +++ b/scripts/UploadSignedReleaseArtifacts.ps1 @@ -82,6 +82,10 @@ $artifacts = @( @{ assetName = "Azure.Bicep.MSBuild.$buildVersion.nupkg"; relativePath = "Azure.Bicep.MSBuild.$buildVersion.nupkg"; + }, + @{ + assetName = "Azure.Bicep.MSBuild.$buildVersion.snupkg"; + relativePath = "Azure.Bicep.MSBuild.$buildVersion.snupkg"; } ); zipAssets = @( From 9ab902e55d79b9825f57a2a54eb3b3d9aa72552c Mon Sep 17 00:00:00 2001 From: Marcin Jastrzebski Date: Fri, 9 Apr 2021 19:48:25 -0700 Subject: [PATCH 4/4] fixed syntax highlights --- docs/cicd-with-bicep.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/docs/cicd-with-bicep.md b/docs/cicd-with-bicep.md index 8e06017ce60..97eb54319f3 100644 --- a/docs/cicd-with-bicep.md +++ b/docs/cicd-with-bicep.md @@ -201,7 +201,7 @@ The following contains a default Console App SDK-based C# project file that was > Replace `__LATEST_VERSION__` with the latest version of the Bicep NuGet packages. -```msbuild +```xml Exe @@ -224,7 +224,7 @@ The following contains a default Console App SDK-based C# project file that was The following contains a project that compiles Bicep files into ARM templates using the NoTargets SDK. This allows creation of standalone projects that compile only Bicep files. > Replace `__LATEST_VERSION__` with the latest version of the Bicep NuGet packages. -```msbuild +```xml net472 @@ -245,7 +245,7 @@ The following contains a project that compiles Bicep files into ARM templates us The following contains an example of how to build Bicep files inside a classic .csproj file (not SDK-based). Only use this if the previous examples do not work for you. > Replace `__LATEST_VERSION__` with the latest version of the Bicep NuGet packages. -```msbuild +```xml