From d6c90b29cf61c752959bcd00f3becfd4ca6d7d2b Mon Sep 17 00:00:00 2001 From: "Rodney Littles, II" Date: Fri, 11 Jan 2019 16:05:42 -0600 Subject: [PATCH 1/3] (GH-32) Added Environment Variable check to ShouldDeployAppCenter - Changed TFBuilderPublishTestResultData to return FilePath[] --- Xamarin.Recipe/Content/azuredevops.cake | 2 +- Xamarin.Recipe/Content/parameters.cake | 7 ++++++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/Xamarin.Recipe/Content/azuredevops.cake b/Xamarin.Recipe/Content/azuredevops.cake index 26d693c..4e380de 100644 --- a/Xamarin.Recipe/Content/azuredevops.cake +++ b/Xamarin.Recipe/Content/azuredevops.cake @@ -74,7 +74,7 @@ BuildParameters.Tasks.PublishAzureDevOpsTestResultsTask = Task("Publish-AzureDev Configuration = BuildParameters.Configuration, TestRunTitle = "Unit Tests", TestRunner = TFTestRunnerType.XUnit, - TestResultsFiles = new string[] { BuildParameters.Paths.Files.TestResultsFilePath.ToString() } + TestResultsFiles = new [] { BuildParameters.Paths.Files.TestResultsFilePath } }; BuildSystem.TFBuild.Commands.PublishTestResults(testResultsData); diff --git a/Xamarin.Recipe/Content/parameters.cake b/Xamarin.Recipe/Content/parameters.cake index c950258..aa55e99 100644 --- a/Xamarin.Recipe/Content/parameters.cake +++ b/Xamarin.Recipe/Content/parameters.cake @@ -151,7 +151,12 @@ public static class BuildParameters SetBuildPaths(BuildPaths.GetPaths(context)); - ShouldDeployAppCenter = ((!IsLocalBuild && !IsPullRequest && (IsMainBranch || IsReleaseBranch || IsDevBranch || IsHotFixBranch || IsTagged)) || shouldDeployAppCenter); + ShouldDeployAppCenter = (((!IsLocalBuild && !IsPullRequest && (IsMainBranch || IsReleaseBranch || IsDevBranch || IsHotFixBranch || IsTagged)) && + ((context.EnvironmentVariable(Environment.AppCenterTokenVariable) != null) && + (context.EnvironmentVariable(Environment.AppCenterAppNameVariable) != null) && + (context.EnvironmentVariable(Environment.AppCenterGroupVariable) != null) && + (context.EnvironmentVariable(Environment.AppCenterOwnerVariable) != null))) || + shouldDeployAppCenter); ShouldRunxUnit = shouldRunxUnit ?? !IsDotNetCoreBuild; From 70b7ae9069f4373f556681179fa09015de707b6e Mon Sep 17 00:00:00 2001 From: RLittlesII Date: Fri, 11 Jan 2019 17:50:36 -0600 Subject: [PATCH 2/3] (GH-33) Added ShouldPublishCodeCoverage criteria to Publish Code Coverage Task --- Xamarin.Recipe/Content/azuredevops.cake | 1 + Xamarin.Recipe/Content/parameters.cake | 12 ++++++++++-- Xamarin.Recipe/Content/toolsettings.cake | 6 ++---- 3 files changed, 13 insertions(+), 6 deletions(-) diff --git a/Xamarin.Recipe/Content/azuredevops.cake b/Xamarin.Recipe/Content/azuredevops.cake index 4e380de..9584f75 100644 --- a/Xamarin.Recipe/Content/azuredevops.cake +++ b/Xamarin.Recipe/Content/azuredevops.cake @@ -83,6 +83,7 @@ BuildParameters.Tasks.PublishAzureDevOpsTestResultsTask = Task("Publish-AzureDev BuildParameters.Tasks.PublishAzureDevOpsCodeCoverageTask = Task("Publish-AzureDevOps-Code-Coverage") .WithCriteria(() => BuildParameters.IsRunningOnAzureDevOps) + .WithCriteria(() => ToolSettings.AzureDevOpsPublishCodeCoverageData != null) .IsDependentOn("Publish-AzureDevOps-Test-Results") .Does(() => { diff --git a/Xamarin.Recipe/Content/parameters.cake b/Xamarin.Recipe/Content/parameters.cake index aa55e99..2729d9d 100644 --- a/Xamarin.Recipe/Content/parameters.cake +++ b/Xamarin.Recipe/Content/parameters.cake @@ -21,19 +21,20 @@ public static class BuildParameters public static bool IsTagged { get; private set; } public static bool IsPublishBuild { get; private set; } public static bool IsReleaseBuild { get; private set; } - public static bool ShouldRunGitVersion { get; private set; } - public static string AppCenterApiKey { get; private set; } public static bool IsDotNetCoreBuild { get; set; } public static bool IsiOSBuild { get; set; } public static bool IsAndroidBuild { get; set; } public static bool IsNuGetBuild { get; set; } public static bool TransifexEnabled { get; set; } public static bool PrepareLocalRelease { get; set; } + + public static bool ShouldRunGitVersion { get; private set; } public static bool ShouldDeployAppCenter { get; private set; } public static bool ShouldRunFastlaneDeliver { get; private set; } public static bool ShouldRunFastlaneMatch { get; private set; } public static bool ShouldCopyImages { get; private set; } public static bool ShouldRunxUnit { get; private set; } + public static BuildVersion Version { get; private set; } public static BuildPaths Paths { get; private set; } public static BuildTasks Tasks { get; set; } @@ -45,6 +46,7 @@ public static class BuildParameters public static FilePath AndroidManifest { get; private set; } public static FilePath IOSProjectPath { get; private set; } public static FilePath PlistFilePath { get; private set; } + public static string AppCenterApiKey { get; private set; } public static string Platform { get; private set; } public static DirectoryPath TestDirectoryPath { get; private set; } public static FilePath IntegrationTestScriptPath { get; private set; } @@ -204,6 +206,12 @@ public static class BuildParameters context.Information("IOSProjectPath: {0}", IOSProjectPath); context.Information("\n"); + context.Information("ShouldPublishCodeCoverage: {0}", ShouldPublishCodeCoverage); + context.Information("\n"); + + context.Information("ShouldDeployAppCenter: {0}", ShouldDeployAppCenter); + context.Information("\n"); + context.Information("ShouldRunFastlaneMatch: {0}", ShouldRunFastlaneMatch); context.Information("ShouldRunFastlaneDeliver: {0}", ShouldRunFastlaneDeliver); context.Information("\n"); diff --git a/Xamarin.Recipe/Content/toolsettings.cake b/Xamarin.Recipe/Content/toolsettings.cake index 0bfaede..5f5e04e 100644 --- a/Xamarin.Recipe/Content/toolsettings.cake +++ b/Xamarin.Recipe/Content/toolsettings.cake @@ -44,7 +44,7 @@ public static class ToolSettings Func xUnitSettings = null, Action fastlaneDeliverConfigurator = null, Action fastlaneMatchConfigurator = null, - Action azureDevOpsPublishCodeCoverageData = null + Action azureDevOpsPublishCodeCoverageData = default(Action) ) { context.Information("Setting up tools..."); @@ -76,7 +76,7 @@ public static class ToolSettings XUnitSettings = xUnitSettings ?? _xUnitSettings; FastlaneDeliverConfigurator = fastlaneDeliverConfigurator ?? _defaultDeliverConfiguration; FastlaneMatchConfigurator = fastlaneMatchConfigurator ?? _defaultMatchConfiguration; - AzureDevOpsPublishCodeCoverageData = azureDevOpsPublishCodeCoverageData ?? _defaultPublishCodeCoverageData; + AzureDevOpsPublishCodeCoverageData = azureDevOpsPublishCodeCoverageData; } private static Func _defaultDotNetTestSettings = () => new DotNetCoreTestSettings @@ -97,8 +97,6 @@ public static class ToolSettings NoAppDomain = true }; - private static Action _defaultPublishCodeCoverageData = data => { data = new TFBuildPublishCodeCoverageData(); }; - private static Action _defaultDeliverConfiguration = cfg => { cfg = new FastlaneDeliverConfiguration(); }; private static Action _defaultMatchConfiguration = cfg => { cfg = new FastlaneMatchConfiguration(); }; From d8a0ce6de93db75e9bee35ef2a0a88ad52f5ff43 Mon Sep 17 00:00:00 2001 From: RLittlesII Date: Fri, 11 Jan 2019 19:17:32 -0600 Subject: [PATCH 3/3] (GH-34) Added Cake.Figlet - Added addins.cake --- Xamarin.Recipe/Content/addins.cake | 9 +++++++++ Xamarin.Recipe/Content/android.cake | 2 -- Xamarin.Recipe/Content/appcenter.cake | 2 -- Xamarin.Recipe/Content/build.cake | 4 +++- Xamarin.Recipe/Content/fastlane.cake | 2 -- Xamarin.Recipe/Content/ios.cake | 2 -- Xamarin.Recipe/Content/parameters.cake | 3 --- 7 files changed, 12 insertions(+), 12 deletions(-) create mode 100644 Xamarin.Recipe/Content/addins.cake diff --git a/Xamarin.Recipe/Content/addins.cake b/Xamarin.Recipe/Content/addins.cake new file mode 100644 index 0000000..8a0f57b --- /dev/null +++ b/Xamarin.Recipe/Content/addins.cake @@ -0,0 +1,9 @@ +/////////////////////////////////////////////////////////////////////////////// +// ADDINS +/////////////////////////////////////////////////////////////////////////////// + +#addin nuget:?package=Cake.AndroidAppManifest&version=1.1.0 +#addin nuget:?package=Cake.AppCenter&version=1.1.0 +#addin nuget:?package=Cake.Fastlane&version=0.4.1 +#addin nuget:?package=Cake.Figlet&version=1.0.0 +#addin nuget:?package=Cake.Plist&version=0.4.0 \ No newline at end of file diff --git a/Xamarin.Recipe/Content/android.cake b/Xamarin.Recipe/Content/android.cake index 0e49de9..7b6dd0b 100644 --- a/Xamarin.Recipe/Content/android.cake +++ b/Xamarin.Recipe/Content/android.cake @@ -1,5 +1,3 @@ -#addin nuget:?package=Cake.AndroidAppManifest&version=1.1.0 - BuildParameters.Tasks.AndroidArchiveTask = Task("Android-Archive") .IsDependentOn("Android-Build") .IsDependentOn("Copy-Apk"); diff --git a/Xamarin.Recipe/Content/appcenter.cake b/Xamarin.Recipe/Content/appcenter.cake index c6e32d9..364102d 100644 --- a/Xamarin.Recipe/Content/appcenter.cake +++ b/Xamarin.Recipe/Content/appcenter.cake @@ -1,5 +1,3 @@ -#addin nuget:?package=Cake.AppCenter&version=1.1.0 - BuildParameters.Tasks.AppCenterTask = Task("AppCenter") .WithCriteria(() => BuildParameters.ShouldDeployAppCenter); diff --git a/Xamarin.Recipe/Content/build.cake b/Xamarin.Recipe/Content/build.cake index ddc9763..cb0dd2a 100644 --- a/Xamarin.Recipe/Content/build.cake +++ b/Xamarin.Recipe/Content/build.cake @@ -7,7 +7,9 @@ /////////////////////////////////////////////////////////////////////////////// Setup(context => -{ +{ + Information(Figlet(BuildParameters.Title)); + // Executed BEFORE the first task. Information("Running tasks..."); diff --git a/Xamarin.Recipe/Content/fastlane.cake b/Xamarin.Recipe/Content/fastlane.cake index c22ee13..60a3f16 100644 --- a/Xamarin.Recipe/Content/fastlane.cake +++ b/Xamarin.Recipe/Content/fastlane.cake @@ -1,5 +1,3 @@ -#addin nuget:?package=Cake.Fastlane&version=0.4.1 - BuildParameters.Tasks.FastlaneTask = Task("Fastlane"); BuildParameters.Tasks.FastlaneDeliverTask = diff --git a/Xamarin.Recipe/Content/ios.cake b/Xamarin.Recipe/Content/ios.cake index 50d6979..43acf6f 100644 --- a/Xamarin.Recipe/Content/ios.cake +++ b/Xamarin.Recipe/Content/ios.cake @@ -1,5 +1,3 @@ -#addin nuget:?package=Cake.Plist&version=0.4.0 - BuildParameters.Tasks.iOSArchiveTask = Task("iOS-Archive") .WithCriteria(() => BuildParameters.IsRunningOnUnix) .IsDependentOn("iPhone-Build") diff --git a/Xamarin.Recipe/Content/parameters.cake b/Xamarin.Recipe/Content/parameters.cake index 2729d9d..e5ec26a 100644 --- a/Xamarin.Recipe/Content/parameters.cake +++ b/Xamarin.Recipe/Content/parameters.cake @@ -206,9 +206,6 @@ public static class BuildParameters context.Information("IOSProjectPath: {0}", IOSProjectPath); context.Information("\n"); - context.Information("ShouldPublishCodeCoverage: {0}", ShouldPublishCodeCoverage); - context.Information("\n"); - context.Information("ShouldDeployAppCenter: {0}", ShouldDeployAppCenter); context.Information("\n");