-
Notifications
You must be signed in to change notification settings - Fork 116
Build and test
This document summarizes how to build and test FinOps toolkit solutions.
On this page:
- βοΈ Building tools
- π€ Lint tests
- π€ PS -WhatIf / az validate
- π Manually deployed + verified
- πͺ Unit tests
- π Integration tests
Automated tests in the FinOps toolkit use Pester, a PowerShell-based testing and mocking framework.
FinOps toolkit solutions are built using PowerShell. Each type of tool has its own nuances and actions that are performed as part of the build process. Refer to the following sections for details.
Templates (only FinOps hub as of May 2024) leverage a straightforward bicep build process. We generally publish all templates to the Azure Quickstart Templates repository which comes with a few additional requirements, so we do have a set of unique files to facilitate these requirements.
To build a single template, run:
cd "<repo-root>"
src/scripts/Build-Toolkit "<template-name>"
To build all templates and modules, simply remove the template name or run npm run build
, if you have NPM setup. To learn more about the build script, see Build-Toolkit.
To build and deploy templates, run:
cd "<repo-root>"
src/scripts/Deploy-Toolkit "<template-name>" -Build
For more local deployment options, see Deploy-Toolkit.
To learn more, see FinOps toolkit templates.
Workbooks include a standard deployment template that is generated as part of the build script. The build script also joins multiple workbooks into a single file for deployment to support hosted workbooks in the Azure Workbooks repository as well as self-managed workbooks in the toolkit.
Building and deploying workbooks uses the same PowerShell commands as templates. To build, run:
cd "<repo-root>"
src/scripts/Build-Toolkit "<workbook-name>-workbook"
To build and deploy, run:
cd "<repo-root>"
src/scripts/Deploy-Toolkit "<workbook-name>-workbook" -Build
The Build-Toolkit script calls an internal Build-Workbook script, which does all the work. You can also call this directly; however, we recommend running the Build-Toolkit script for a complete build process.
To learn more, see Workbook modules.
Bicep Registry modules support a custom "language" that enables reusing code across target scopes. Bicep Registry modules designed to support multiple scopes will generate multiple output folders for each module.
To build all bicep modules, run:
cd "<repo-root>"
src/scripts/Build-Toolkit
To build only a single module, run:
cd "<repo-root>"
src/scripts/Build-Bicep ..\bicep-registry\<module>
Bicep Registry modules include a main.test.bicep
file that includes all tests. To test Bicep Registry modules, run:
cd "<repo-root>"
src/scripts/Deploy-Toolkit "<module-name>" -Build -Test
To learn more, see Bicep Registry modules.
The build script for open data files generates the resource types file from Azure portal metadata and then generates PowerShell commands and tests for each file.
To build open data, run:
src/Build-OpenData
To learn more about open data, see Open data.
The PowerShell module generates a single module file from functions created in separate files.
To build the PowerShell module, run the following as an administrator:
cd "<repo-root>"
src/scripts/Build-PowerShell
To install the PowerShell module locally, run:
cd "<repo-root>"
Remove-Module FinOpsToolkit -ErrorAction SilentlyContinue
Import-Module -FullyQualifiedName src/powershell/FinOpsToolkit.psm1
The Build-PowerShell script calls an Invoke-Build task internally.
Note
We have a partial implementation of Invoke-Build but this has not been fully implemented, so there is a mix of custom scripts and Invoke-Build scripts. If anyone has experience in this area, we would love to get help centralizing on a single build system.
Power BI reports cannot be built automatically. Generating PBIT and PBIX files must be done manually:
- Open the desired Power BI report.
- Save the report as a
.pbix
file using the same name in thereleases
folder. - Remove unnecessary queries.
- Remove setup instructions for unnecessary parameters.
- Remove unnecessary parameters.
- Save the report again.
- Copy the first paragraph description from the main page.
- Save the report as a
.pbit
file using the copied description and add "To learn more, see https://aka.ms/ftk/".
Documentation does not currently require a build process. Documentation is automatically generated via GitHub Pages. To test documentation generation:
- Fork the FinOps toolkit repository.
- From your forked repo, go to Settings > Pages (in the left nav).
- Under Build and deployment, set the following:
- Source = Deploy from branch
- Branch = features/services
- Folder = /docs
- Wait 5m for everything to build (or go to Actions to track the deployment proactively).
- Go to (your-username).github.io/finops-toolkit in the browser to view the docs.
Linters are static code analysis tools that identify programming and stylistic errors or anti-patterns in source code. The FinOps toolkit uses the following linters:
Lint tests are run on bicep code during the build process. Simply build the target solution and resolve any lint errors written to the console.
To run PowerShell lint tests, run:
cd "<repo-root>"
src/scripts/Test-PowerShell -Lint
Running -WhatIf
or validate
is generally not a great way to confirm tools are working as desired. We do not recommend relying on this for any substantial changes.
To run -WhatIf
for a deployment, run:
cd "<repo-root>"
src/scripts/Deploy-Toolkit "<tool-name>" -Build -WhatIf
Manual verification is always expected; however, we do prefer automated tests. Unit test are preferred with integration tests next. Refer to the details above for how to build and deploy each type of tool.
Unit tests validate compartmentalized functionality without calling code outside the "unit" being tested. Mocking is used to avoid calling code outside the target code block.
To run PowerShell unit tests, run:
cd "<repo-root>"
src/scripts/Test-PowerShell
The Test-PowerShell script runs unit tests by default. To opt in to multiple types of tests, include -Unit
for the unit tests.
Integration tests validate a full stack of functionality, including all dependencies. Integration tests are typically simpler to implement but require cleanup.
To run PowerShell integration tests, run:
cd "<repo-root>"
src/scripts/Test-PowerShell -Integration
Have a question or suggestion? Start a discussion and let us know you think.
Find a doc bug? Update docs-wiki and submit a PR.
Getting started
Contributing
Engineering
Standard operating procedures