From 77d3c9d1f2b05c3d11866d5a251a47c654245393 Mon Sep 17 00:00:00 2001 From: Daniel Cazzulino Date: Mon, 10 May 2021 15:02:06 -0300 Subject: [PATCH] Populate RepositoryBranch automatically Support most popular CI systems. Fixes #57 --- .../NuGetizer.PackageMetadata.targets | 28 +++++++++++++++++++ src/NuGetizer.Tests/given_sourcelink.cs | 9 ++++-- 2 files changed, 35 insertions(+), 2 deletions(-) diff --git a/src/NuGetizer.Tasks/NuGetizer.PackageMetadata.targets b/src/NuGetizer.Tasks/NuGetizer.PackageMetadata.targets index c6b68611..f763f170 100644 --- a/src/NuGetizer.Tasks/NuGetizer.PackageMetadata.targets +++ b/src/NuGetizer.Tasks/NuGetizer.PackageMetadata.targets @@ -21,6 +21,34 @@ Copyright (c) .NET Foundation. All rights reserved. true + + + + pr$(GITHUB_REF.Replace('refs/pull/', '').Replace('/merge', '')) + $(GITHUB_REF.Replace('refs/heads/', '').Replace('refs/tags/', '')) + + $(BUILD_SOURCEBRANCH.Replace('refs/heads/', '').Replace('refs/tags/', '')) + + pr$(APPVEYOR_PULL_REQUEST_NUMBER) + $(APPVEYOR_REPO_TAG_NAME) + $(APPVEYOR_REPO_BRANCH) + + pr$(TRAVIS_PULL_REQUEST) + $(TRAVIS_BRANCH) + + pr$(CIRCLE_PR_NUMBER) + $(CIRCLE_TAG) + $(CIRCLE_BRANCH) + + $(CI_COMMIT_TAG) + pr$(CI_MERGE_REQUEST_IID) + pr$(CI_EXTERNAL_PULL_REQUEST_IID) + $(CI_COMMIT_BRANCH) + + pr$(BUDDY_EXECUTION_PULL_REQUEST_NO) + $(BUDDY_EXECUTION_TAG) + $(BUDDY_EXECUTION_BRANCH) + diff --git a/src/NuGetizer.Tests/given_sourcelink.cs b/src/NuGetizer.Tests/given_sourcelink.cs index b0ce2707..7b0af204 100644 --- a/src/NuGetizer.Tests/given_sourcelink.cs +++ b/src/NuGetizer.Tests/given_sourcelink.cs @@ -1,4 +1,5 @@ -using Xunit; +using System; +using Xunit; using Xunit.Abstractions; namespace NuGetizer @@ -12,6 +13,9 @@ public class given_sourcelink [Fact] public void when_getting_metadata_then_adds_repository_info() { + if (string.IsNullOrEmpty(Environment.GetEnvironmentVariable("GITHUB_REF"))) + Environment.SetEnvironmentVariable("GITHUB_REF", "refs/heads/main"); + var result = Builder.BuildProject(@" @@ -26,13 +30,14 @@ public void when_getting_metadata_then_adds_repository_info() "GetPackageMetadata", output); result.AssertSuccess(output); - + Assert.Single(result.Items); var metadata = result.Items[0]; Assert.Equal("git", metadata.GetMetadata("RepositoryType")); Assert.Equal(ThisAssembly.Project.PrivateRepositoryUrl, metadata.GetMetadata("RepositoryUrl")); Assert.NotEmpty(metadata.GetMetadata("RepositoryCommit")); + Assert.NotEmpty(metadata.GetMetadata("RepositoryBranch")); } [Fact]