NukeBuildHelpers 2.6.1

This package has a SemVer 2.0.0 package version: 2.6.1+build.370.
dotnet add package NukeBuildHelpers --version 2.6.1
NuGet\Install-Package NukeBuildHelpers -Version 2.6.1
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="NukeBuildHelpers" Version="2.6.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NukeBuildHelpers --version 2.6.1
#r "nuget: NukeBuildHelpers, 2.6.1"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install NukeBuildHelpers as a Cake Addin
#addin nuget:?package=NukeBuildHelpers&version=2.6.1

// Install NukeBuildHelpers as a Cake Tool
#tool nuget:?package=NukeBuildHelpers&version=2.6.1

NukeBuildHelpers

NukeBuildHelpers is a C# project build automation tool built on top of NukeBuild. It supports both GitHub Actions and Azure Pipelines for CI/CD, enabling release management across multiple projects and environments within a single repository.

Features

  • Multi-project and Multi-environment Support: Handle releases for multiple projects and environments in a single repository.
  • CI/CD Integration: Generate GitHub Actions and Azure Pipelines workflows.
  • Automated Versioning: Interactive CLI for bumping project versions with validation.
  • Flexible Build Flow: Override abstract classes to create custom build flows.

Quick Start

Using the Repository Template

To quickly set up a new project, use the NukeBuildTemplate repository template:

  1. Clone the template repository.
  2. Follow the setup instructions in the template.

Installing via NuGet

If you already have a NukeBuild setup, you can install NukeBuildHelpers via NuGet:

dotnet add package NukeBuildHelpers

Usage

Creating Build Flows

To create custom build flows, override the abstract classes AppEntry or AppTestEntry.

Example AppEntry Implementation
namespace _build;

public class NugetBuildHelpers : AppEntry<Build>
{
    public override RunsOnType BuildRunsOn => RunsOnType.Ubuntu2204;
    public override RunsOnType PublishRunsOn => RunsOnType.Ubuntu2204;

    [SecretVariable("NUGET_AUTH_TOKEN")]
    readonly string? NuGetAuthToken;

    [SecretVariable("GITHUB_TOKEN")]
    readonly string? GithubToken;

    public override void Build(AppRunContext appRunContext)
    {
        // Build logic here
    }

    public override void Publish(AppRunContext appRunContext)
    {
        // Publish logic here
    }
}
Example AppTestEntry Implementation
namespace _build;

public class NugetBuildHelpersTest : AppTestEntry<Build>
{
    public override RunsOnType RunsOn => RunsOnType.WindowsLatest;
    public override Type[] AppEntryTargets => [typeof(NugetBuildHelpers)];

    public override void Run(AppTestRunContext appTestRunContext)
    {
        // Test logic here
    }
}

Generating Workflows

Generate GitHub and Azure Pipelines workflows using CLI commands:

# Generate GitHub workflow
build githubworkflow

# Generate Azure Pipelines workflow
build azureworkflow

These commands will generate azure-pipelines.yml and .github/workflows/nuke-cicd.yml respectively.

Bumping Project Version

Use the build bump command to interactively bump the project version:

build bump

CLI Subcommands

  • Fetch: Fetch git commits and tags.
  • Version: Show the current version from all releases.
  • Bump: Interactive, bump the version by validating and tagging.
  • BumpAndForget: Interactive, bump and forget the version by validating and tagging.
  • StatusWatch: Show the current version status from all releases.
  • Test: Run tests.
  • Build: Build the project.
  • Publish: Publish the project.
  • GithubWorkflow: Build the CI/CD workflow for GitHub.
  • AzureWorkflow: Build the CI/CD workflow for Azure.

Versioning and Status

  • The Version subcommand shows the current version from all releases. Example output from the subcommand:
╬══════════════════════╬═════════════╬════════════════════╬═════════════════════╬
║        App Id        ║ Environment ║   Bumped Version   ║      Published      ║
╬══════════════════════╬═════════════╬════════════════════╬═════════════════════╬
║ nuget_build_helpers  ║ prerelease  ║ 2.1.0-prerelease.1 ║ 2.0.0-prerelease.8* ║
║                      ║    main     ║ 2.0.0              ║         yes         ║
║----------------------║-------------║--------------------║---------------------║
║ nuget_build_helpers2 ║ prerelease  ║ 0.1.0-prerelease.2 ║         no          ║
║                      ║    main     ║ -                  ║         no          ║
╬══════════════════════╬═════════════╬════════════════════╬═════════════════════╬
  • The StatusWatch subcommand continuously monitors the version status. Example output from the subcommand:
╬══════════════════════╬═════════════╬════════════════════╬═══════════════╬
║        App Id        ║ Environment ║      Version       ║    Status     ║
╬══════════════════════╬═════════════╬════════════════════╬═══════════════╬
║ nuget_build_helpers  ║ prerelease  ║ 2.1.0-prerelease.2 ║   Published   ║
║                      ║    main     ║ 2.0.0              ║   Published   ║
║----------------------║-------------║--------------------║---------------║
║ nuget_build_helpers2 ║ prerelease  ║ 0.1.0-prerelease.2 ║  Run Failed   ║
║                      ║    main     ║ -                  ║ Not published ║
╬══════════════════════╬═════════════╬════════════════════╬═══════════════╬

Status types include:

  • Run Failed: The build encountered an error and did not complete successfully.
  • Published: The build was successfully published.
  • Publishing: The build is currently in the process of being published.
  • Waiting for Queue: The build is waiting in the queue to be processed.
  • Not Published: The build has not been published.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgements

  • NukeBuild for providing the foundation for this project.
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.6.1 91 6/4/2024
2.6.1-prerelease.1 20 6/4/2024
2.6.0 99 6/4/2024
2.6.0-prerelease.1 20 6/4/2024
2.5.0 87 6/3/2024
2.5.0-prerelease.4 31 6/3/2024
2.5.0-prerelease.3 13 6/3/2024
2.5.0-prerelease.2 22 6/3/2024
2.5.0-prerelease.1 26 6/3/2024
2.4.1 44 5/29/2024
2.4.0 58 5/29/2024
2.4.0-prerelease.2 28 5/29/2024
2.4.0-prerelease.1 27 5/27/2024
2.3.0 159 5/27/2024
2.3.0-prerelease.1 27 5/27/2024
2.2.0 27 5/27/2024
2.2.0-prerelease.1 27 5/27/2024
2.1.2 75 5/27/2024
2.1.1 31 5/27/2024
2.1.0 153 5/24/2024
2.1.0-prerelease.4 32 5/24/2024
2.1.0-prerelease.3 34 5/24/2024
2.1.0-prerelease.2 21 5/23/2024
2.1.0-prerelease.1 24 5/23/2024
2.0.0 39 5/23/2024
2.0.0-prerelease.8 80 5/22/2024
2.0.0-prerelease.7 38 5/22/2024
2.0.0-prerelease.5 29 5/22/2024
2.0.0-prerelease.4 30 5/22/2024
2.0.0-prerelease.3 31 5/22/2024
1.0.2 476 4/25/2024
1.0.1 580 4/20/2024
1.0.0 396 4/1/2024
0.8.4-prerelease.4 65 3/31/2024
0.8.4-prerelease.2 48 3/31/2024
0.8.4-prerelease.1 44 3/31/2024
0.8.3 146 3/26/2024
0.8.3-prerelease.1 42 3/26/2024
0.8.2 119 3/26/2024
0.8.2-prerelease.2 43 3/26/2024
0.8.2-prerelease.1 44 3/26/2024
0.8.1 133 3/25/2024
0.8.1-prerelease.3 43 3/25/2024
0.8.1-prerelease.1 43 3/25/2024
0.8.0 84 3/25/2024
0.8.0-prerelease.44 43 3/25/2024
0.8.0-prerelease.40 46 3/25/2024
0.8.0-prerelease.39 42 3/25/2024
0.8.0-prerelease.38 42 3/25/2024
0.8.0-prerelease.37 42 3/25/2024
0.8.0-prerelease.36 175 3/22/2024
0.8.0-prerelease.35 50 3/22/2024
0.8.0-prerelease.34 126 3/21/2024
0.8.0-prerelease.33 41 3/21/2024
0.8.0-prerelease.32 48 3/21/2024
0.8.0-prerelease.31 42 3/21/2024
0.8.0-prerelease.28 50 3/21/2024
0.8.0-prerelease.27 47 3/21/2024
0.8.0-prerelease.26 41 3/21/2024
0.8.0-prerelease.25 44 3/21/2024
0.8.0-prerelease.23 43 3/21/2024
0.8.0-prerelease.22 45 3/21/2024
0.8.0-prerelease.21 50 3/21/2024
0.8.0-prerelease.20 40 3/21/2024
0.8.0-prerelease.19 43 3/21/2024
0.8.0-prerelease.18 49 3/21/2024
0.8.0-prerelease.17 43 3/21/2024
0.8.0-prerelease.16 45 3/21/2024
0.8.0-prerelease.15 47 3/21/2024
0.8.0-prerelease.14 41 3/21/2024
0.8.0-prerelease.13 42 3/21/2024
0.8.0-prerelease.12 45 3/21/2024
0.8.0-prerelease.11 38 3/21/2024
0.8.0-prerelease.10 43 3/21/2024
0.8.0-prerelease.9 48 3/21/2024
0.8.0-prerelease.7 312 3/19/2024
0.8.0-prerelease.6 107 3/19/2024
0.8.0-prerelease.5 263 3/13/2024
0.8.0-prerelease.4 49 3/13/2024
0.8.0-prerelease.3 41 3/13/2024
0.8.0-prerelease.2 57 3/13/2024
0.8.0-prerelease.1 40 3/13/2024
0.7.0 102 3/13/2024
0.7.0-prerelease.1 46 3/13/2024
0.6.0-prerelease.1 41 3/12/2024
0.5.0-prerelease.26 37 3/12/2024
0.5.0-prerelease.25 37 3/12/2024
0.5.0-prerelease.24 87 3/11/2024
0.5.0-prerelease.23 48 3/10/2024
0.5.0-prerelease.22 40 3/10/2024
0.5.0-prerelease.20 82 3/10/2024
0.5.0-prerelease.19 43 3/10/2024
0.5.0-prerelease.18 80 3/10/2024
0.5.0-prerelease.17 59 3/10/2024
0.5.0-prerelease.16 44 3/10/2024
0.5.0-prerelease.15 38 3/10/2024
0.5.0-prerelease.14 43 3/10/2024
0.5.0-prerelease.13 37 3/10/2024
0.5.0-prerelease.12 44 3/10/2024
0.5.0-prerelease.11 46 3/9/2024
0.5.0-prerelease.9 50 3/9/2024
0.5.0-prerelease.7 165 3/8/2024
0.5.0-prerelease.6 48 3/8/2024
0.5.0-prerelease.5 46 3/8/2024
0.5.0-prerelease.4 52 3/8/2024
0.4.2 70 3/8/2024
0.4.1 67 3/8/2024
0.4.0 63 3/8/2024
0.4.0-prerelease.46 48 3/8/2024
0.4.0-prerelease.45 25 3/8/2024
0.4.0-prerelease.44 38 3/8/2024
0.4.0-prerelease.42 49 3/8/2024
0.4.0-prerelease.41 39 3/7/2024
0.4.0-prerelease.39 38 3/7/2024
0.4.0-prerelease.37 37 3/7/2024
0.4.0-prerelease.36 38 3/7/2024
0.4.0-prerelease.35 36 3/7/2024
0.4.0-prerelease.34 43 3/7/2024
0.4.0-prerelease.33 39 3/7/2024
0.4.0-prerelease.32 40 3/7/2024
0.4.0-prerelease.28 41 3/7/2024
0.4.0-prerelease.27 34 3/7/2024
0.4.0-prerelease.25 38 3/7/2024
0.4.0-prerelease.24 38 3/7/2024
0.4.0-prerelease.23 41 3/7/2024
0.4.0-prerelease.22 39 3/7/2024
0.4.0-prerelease.21 43 3/7/2024
0.4.0-prerelease.20 42 3/7/2024
0.4.0-prerelease.19 38 3/7/2024
0.4.0-prerelease.18 42 3/7/2024
0.4.0-prerelease.17 48 3/7/2024
0.4.0-prerelease.16 42 3/7/2024
0.4.0-prerelease.15 39 3/7/2024
0.4.0-prerelease.14 44 3/7/2024
0.4.0-prerelease.13 44 3/7/2024
0.3.0 83 3/5/2024
0.3.0-prerelease.3 49 3/5/2024
0.2.0 76 3/5/2024
0.1.0 91 3/5/2024
0.1.0-prerelease.22 46 3/5/2024
0.1.0-prerelease.19 38 3/5/2024
0.1.0-prerelease.18 41 3/5/2024
0.1.0-prerelease.17 41 3/5/2024
0.1.0-prerelease.13 47 3/5/2024
0.1.0-prerelease.12 48 3/5/2024
0.1.0-prerelease.10 49 3/5/2024
0.1.0-prerelease.9 48 3/5/2024
0.1.0-prerelease.8 47 3/5/2024
0.1.0-prerelease.7 49 3/5/2024
0.1.0-prerelease.5 49 3/5/2024
0.1.0-prerelease.4 41 3/5/2024
0.1.0-prerelease.3 47 3/5/2024
0.1.0-prerelease.2 45 3/5/2024
0.1.0-prerelease.1 132 12/13/2023
0.1.0-alpha.1 54 3/5/2024