-
Notifications
You must be signed in to change notification settings - Fork 1.4k
CI and Infrastructure
An Azure instance runs our CI pipeline. Our Azure pipelines configuration is found at the root of the repository, e.g. azure-pipelines.yml
Jobs are specified in the pipelines config. The status and results of jobs are reported as Github Checks. The status and results of individual steps for each job are visible on azure ( usually directly linked to in Github Checks ).
Jobs can be added and modified in the pipelines config file. Checkout the Azure Pipelines Doc for more info.
The CI pipeline get triggered to run on main
, dev/*
or rel/*
branches when new commits get pushed to or PRs are opened targeting those branches.
A lot of the pipeline jobs make use of Cake Tasks defined in build/build.cake.
Cake Tasks are invoked through build/build.ps1 in the pipelines config, and the various tasks can be ran from powershell using the Target option, for example .\build.ps1 -Target UpdateHeaders
.
Note: It is recommended that the build scripts are invoked from the build directory.
Cake tasks can be added to the cake file, either to be executed directly from the pipelines config or to be invoked manually.
Also any task can be added as a dependency to another Task.
When .\build.ps1
is ran (without any options), it runs the Task "Default" and thus all its dependencies.
This task if not typically used in the build pipeline, but it is useful for locally running a most of the CI pipeline locally in order to test changes locally without having to wait on the CI Server.
The CI pipeline performs five tasks when triggered to run on a branch.
Various formatting checks are run very early on in the CI pipeline.
Currently we verify that all *.cs
files contain the .NET Foundation license at the top of the file and we check all *.xaml
with XAML Styler.
All our projects are built - this includes libraries, tests, and the Sample app. While this step is primarily used to feed into the package build process, it also makes sure that there are not compilation issues with the libraries, as well no compilation issues with the sample app. This helps make sure that the sample app is always an accurate example of using the libraries.
Once all the libraries are built, our tests are ran - see Testing.
The libraries are packaged into NuGet packages and automatically published to our Azure Feeds - see Preview Packages.
We perform analysis on the changes in the size of packages, as well as how much the sizes of apps using these packages change.
Fork the repo and Send the PR ππ
Any changes to the wiki made directly here on GitHub will be overwritten by the wiki repo commits
- Home π
- Welcome π
- Windows Community Toolkit π§°
- Features π¬
- Principles βοΈ
- Roadmap πΊ
- .NET Foundation
- Why Microsoft supports this project
- License π
- Sample App π±
- Getting Started π
- NuGet Packages π¦
- Preview Packages π
- Toolkit Labs π§ͺ
- Questions β
- Discussions π₯
- Submitting an Issue βοΈ
- Good First Issue π
- Help Wanted π
- Bug Fixes π
- Feature Requests π«
- Create and Submit PullRequest π
- Documentation π
- Review PR π
- Avoid Roadblocks π§
- Quick Start β‘
- Required Dependencies π
- Coding Style and Conventions β
- Testing π§ͺ
- Sample Development π±
- Accessibility Guideline βΏ
- Building XAML Controls π
- Fabric Bot Services π€
- CI and Infrastructure πΎ
- How the Project is Organized ποΈ
- Join the Toolkit Organization πͺ
- Hall of Fame π