Avalonia/build.cake

445 строки
15 KiB
Plaintext
Исходник Обычный вид История

2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
// ADDINS
///////////////////////////////////////////////////////////////////////////////
#addin "nuget:?package=Polly&version=4.2.0"
#addin "nuget:?package=NuGet.Core&version=2.12.0"
2017-07-21 18:07:12 +03:00
#tool "nuget:?package=xunit.runner.console&version=2.2.0"
#tool "nuget:https://dotnet.myget.org/F/nuget-build/?package=NuGet.CommandLine&version=4.3.0-preview1-3980&prerelease"
#tool "nuget:?package=JetBrains.ReSharper.CommandLineTools&version=2017.1.20170613.162720"
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
// TOOLS
///////////////////////////////////////////////////////////////////////////////
2017-06-08 00:38:14 +03:00
#tool "nuget:?package=xunit.runner.console&version=2.2.0"
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
// USINGS
///////////////////////////////////////////////////////////////////////////////
using System;
using System.Collections;
2016-08-16 17:14:01 +03:00
using System.Collections.Generic;
using System.Linq;
using Polly;
using NuGet;
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
// SCRIPTS
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
#load "./parameters.cake"
#load "./packages.cake"
2017-02-04 19:41:25 +03:00
//////////////////////////////////////////////////////////////////////
2016-08-16 17:14:01 +03:00
// PARAMETERS
2017-02-04 19:41:25 +03:00
//////////////////////////////////////////////////////////////////////
2016-08-16 17:14:01 +03:00
2017-02-04 19:41:25 +03:00
Parameters parameters = new Parameters(Context);
Packages packages = new Packages(Context, parameters);
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
// SETUP
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
Setup(context =>
2016-08-16 17:14:01 +03:00
{
2017-02-04 19:41:25 +03:00
Information("Building version {0} of Avalonia ({1}, {2}, {3}) using version {4} of Cake.",
parameters.Version,
parameters.Platform,
parameters.Configuration,
parameters.Target,
typeof(ICakeContext).Assembly.GetName().Version.ToString());
2016-08-16 17:14:01 +03:00
2017-02-04 19:41:25 +03:00
if (parameters.IsRunningOnAppVeyor)
{
2017-02-04 19:41:25 +03:00
Information("Repository Name: " + BuildSystem.AppVeyor.Environment.Repository.Name);
Information("Repository Branch: " + BuildSystem.AppVeyor.Environment.Repository.Branch);
}
2017-02-04 19:41:25 +03:00
Information("Target: " + parameters.Target);
Information("Platform: " + parameters.Platform);
Information("Configuration: " + parameters.Configuration);
Information("IsLocalBuild: " + parameters.IsLocalBuild);
Information("IsRunningOnUnix: " + parameters.IsRunningOnUnix);
Information("IsRunningOnWindows: " + parameters.IsRunningOnWindows);
Information("IsRunningOnAppVeyor: " + parameters.IsRunningOnAppVeyor);
Information("IsPullRequest: " + parameters.IsPullRequest);
Information("IsMainRepo: " + parameters.IsMainRepo);
Information("IsMasterBranch: " + parameters.IsMasterBranch);
Information("IsTagged: " + parameters.IsTagged);
Information("IsReleasable: " + parameters.IsReleasable);
Information("IsMyGetRelease: " + parameters.IsMyGetRelease);
Information("IsNuGetRelease: " + parameters.IsNuGetRelease);
});
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
// TEARDOWN
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
Teardown(context =>
2016-08-16 17:14:01 +03:00
{
2017-02-04 19:41:25 +03:00
Information("Finished running tasks.");
});
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
// TASKS
///////////////////////////////////////////////////////////////////////////////
Task("Clean")
.Does(() =>
{
2017-02-04 19:41:25 +03:00
CleanDirectories(parameters.BuildDirs);
CleanDirectory(parameters.ArtifactsDir);
CleanDirectory(parameters.NugetRoot);
CleanDirectory(parameters.ZipRoot);
CleanDirectory(parameters.BinRoot);
CleanDirectory(parameters.TestsRoot);
2016-08-16 17:14:01 +03:00
});
2017-02-04 19:41:25 +03:00
2016-08-16 17:14:01 +03:00
Task("Restore-NuGet-Packages")
.IsDependentOn("Clean")
2017-03-08 19:28:55 +03:00
.WithCriteria(parameters.IsRunningOnWindows)
2016-08-16 17:14:01 +03:00
.Does(() =>
{
var maxRetryCount = 5;
2017-05-26 17:00:06 +03:00
var toolTimeout = 2d;
2016-08-16 17:14:01 +03:00
Policy
.Handle<Exception>()
.Retry(maxRetryCount, (exception, retryCount, context) => {
if (retryCount == maxRetryCount)
{
throw exception;
}
else
{
Verbose("{0}", exception);
toolTimeout+=0.5;
}})
.Execute(()=> {
2017-03-08 20:14:48 +03:00
NuGetRestore(parameters.MSBuildSolution, new NuGetRestoreSettings {
ToolTimeout = TimeSpan.FromMinutes(toolTimeout)
});
2016-08-16 17:14:01 +03:00
});
});
2017-03-08 19:28:55 +03:00
void DotNetCoreBuild()
{
DotNetCoreRestore("samples\\ControlCatalog.NetCore");
DotNetBuild("samples\\ControlCatalog.NetCore");
2017-03-08 19:28:55 +03:00
}
Task("DotNetCoreBuild")
.IsDependentOn("Clean")
.Does(() => DotNetCoreBuild());
2016-08-16 17:14:01 +03:00
Task("Build")
.IsDependentOn("Restore-NuGet-Packages")
.Does(() =>
{
2017-02-04 19:41:25 +03:00
if(parameters.IsRunningOnWindows)
2016-08-16 17:14:01 +03:00
{
2017-02-04 19:41:25 +03:00
MSBuild(parameters.MSBuildSolution, settings => {
settings.SetConfiguration(parameters.Configuration);
settings.WithProperty("Platform", "\"" + parameters.Platform + "\"");
2017-03-08 20:55:45 +03:00
settings.WithProperty("UseRoslynPathHack", "true");
2016-08-16 17:14:01 +03:00
settings.SetVerbosity(Verbosity.Minimal);
settings.WithProperty("Windows", "True");
2017-03-08 19:28:55 +03:00
settings.UseToolVersion(MSBuildToolVersion.VS2017);
2016-08-16 17:14:01 +03:00
settings.SetNodeReuse(false);
});
}
else
{
2017-03-08 19:28:55 +03:00
DotNetCoreBuild();
2016-08-16 17:14:01 +03:00
}
});
void RunCoreTest(string project, Parameters parameters, bool coreOnly = false)
{
if(!project.EndsWith(".csproj"))
project = System.IO.Path.Combine(project, System.IO.Path.GetFileName(project)+".csproj");
Information("Running tests from " + project);
DotNetCoreRestore(project);
var frameworks = new List<string>(){"netcoreapp1.1"};
if(parameters.IsRunningOnWindows)
frameworks.Add("net461");
foreach(var fw in frameworks)
{
if(!fw.StartsWith("netcoreapp") && coreOnly)
continue;
Information("Running for " + fw);
DotNetCoreTest(project,
2017-06-08 01:23:44 +03:00
new DotNetCoreTestSettings {
Configuration = parameters.Configuration,
Framework = fw
});
}
}
2017-03-08 19:28:55 +03:00
Task("Run-Net-Core-Unit-Tests")
.IsDependentOn("Clean")
2017-03-08 23:55:19 +03:00
.Does(() => {
RunCoreTest("./tests/Avalonia.Base.UnitTests", parameters, false);
2017-06-08 00:38:14 +03:00
RunCoreTest("./tests/Avalonia.Controls.UnitTests", parameters, false);
RunCoreTest("./tests/Avalonia.Input.UnitTests", parameters, false);
RunCoreTest("./tests/Avalonia.Interactivity.UnitTests", parameters, false);
RunCoreTest("./tests/Avalonia.Layout.UnitTests", parameters, false);
RunCoreTest("./tests/Avalonia.Markup.UnitTests", parameters, false);
2017-06-08 15:26:29 +03:00
RunCoreTest("./tests/Avalonia.Markup.Xaml.UnitTests", parameters, false);
2017-06-08 00:38:14 +03:00
RunCoreTest("./tests/Avalonia.Styling.UnitTests", parameters, false);
RunCoreTest("./tests/Avalonia.Visuals.UnitTests", parameters, false);
if(parameters.IsRunningOnWindows)
RunCoreTest("./tests/Avalonia.RenderTests/Avalonia.Skia.RenderTests.csproj", parameters, true);
2017-03-08 23:55:19 +03:00
});
2017-03-08 19:28:55 +03:00
2016-08-16 17:14:01 +03:00
Task("Run-Unit-Tests")
.IsDependentOn("Run-Net-Core-Unit-Tests")
2016-08-16 17:14:01 +03:00
.IsDependentOn("Build")
//.IsDependentOn("Run-Leak-Tests")
2017-02-04 19:41:25 +03:00
.WithCriteria(() => !parameters.SkipTests)
2016-08-16 17:14:01 +03:00
.Does(() =>
{
if(!parameters.IsRunningOnWindows)
return;
2017-03-08 19:28:55 +03:00
2016-09-14 01:20:40 +03:00
var unitTests = GetDirectories("./tests/Avalonia.*.UnitTests")
.Select(dir => System.IO.Path.GetFileName(dir.FullPath))
.Where( name => !name.Contains("Skia")) // Run in the Run-Net-Core-Unit-Tests target
.Where(name => parameters.IsRunningOnWindows ? true : !name.Contains("Direct2D"))
2017-02-04 19:41:25 +03:00
.Select(name => MakeAbsolute(File("./tests/" + name + "/bin/" + parameters.DirSuffix + "/" + name + ".dll")))
2016-09-14 01:20:40 +03:00
.ToList();
2016-08-16 17:14:01 +03:00
2017-02-04 19:41:25 +03:00
var toolPath = (parameters.IsPlatformAnyCPU || parameters.IsPlatformX86) ?
2016-08-16 17:14:01 +03:00
"./tools/xunit.runner.console/tools/xunit.console.x86.exe" :
"./tools/xunit.runner.console/tools/xunit.console.exe";
var xUnitSettings = new XUnit2Settings
2016-08-16 17:14:01 +03:00
{
ToolPath = toolPath,
Parallelism = ParallelismOption.None,
ShadowCopy = false
2016-08-16 17:14:01 +03:00
};
2017-02-04 19:41:25 +03:00
xUnitSettings.NoAppDomain = !parameters.IsRunningOnWindows;
2016-08-16 17:14:01 +03:00
foreach(var test in unitTests.Where(testFile => FileExists(testFile)))
2016-08-16 17:14:01 +03:00
{
2017-02-04 19:41:25 +03:00
CopyDirectory(test.GetDirectory(), parameters.TestsRoot);
}
var testsInDirectoryToRun = new List<FilePath>();
2017-02-04 19:41:25 +03:00
if(parameters.IsRunningOnWindows)
{
testsInDirectoryToRun.AddRange(GetFiles("./artifacts/tests/*Tests.dll"));
}
else
{
testsInDirectoryToRun.AddRange(GetFiles("./artifacts/tests/*.UnitTests.dll"));
}
XUnit2(testsInDirectoryToRun, xUnitSettings);
2016-08-16 17:14:01 +03:00
});
Task("Copy-Files")
.IsDependentOn("Run-Unit-Tests")
.Does(() =>
{
2017-02-04 19:41:25 +03:00
CopyFiles(packages.BinFiles, parameters.BinRoot);
});
Task("Zip-Files")
.IsDependentOn("Copy-Files")
.Does(() =>
{
2017-02-04 19:41:25 +03:00
Zip(parameters.BinRoot, parameters.ZipCoreArtifacts);
2017-02-04 19:41:25 +03:00
Zip(parameters.ZipSourceControlCatalogDesktopDirs,
parameters.ZipTargetControlCatalogDesktopDirs,
GetFiles(parameters.ZipSourceControlCatalogDesktopDirs.FullPath + "/*.dll") +
2017-05-11 19:14:58 +03:00
GetFiles(parameters.ZipSourceControlCatalogDesktopDirs.FullPath + "/*.config") +
2017-05-11 15:23:29 +03:00
GetFiles(parameters.ZipSourceControlCatalogDesktopDirs.FullPath + "/*.so") +
GetFiles(parameters.ZipSourceControlCatalogDesktopDirs.FullPath + "/*.dylib") +
2017-02-04 19:41:25 +03:00
GetFiles(parameters.ZipSourceControlCatalogDesktopDirs.FullPath + "/*.exe"));
});
2016-08-16 17:14:01 +03:00
Task("Create-NuGet-Packages")
2017-01-31 20:47:00 +03:00
.IsDependentOn("Run-Unit-Tests")
2017-05-26 17:00:06 +03:00
.IsDependentOn("Inspect")
2016-08-16 17:14:01 +03:00
.Does(() =>
{
2017-02-04 19:41:25 +03:00
foreach(var nuspec in packages.NuspecNuGetSettings)
2016-08-16 17:14:01 +03:00
{
NuGetPack(nuspec);
}
});
Task("Publish-MyGet")
.IsDependentOn("Create-NuGet-Packages")
2017-02-04 19:41:25 +03:00
.WithCriteria(() => !parameters.IsLocalBuild)
.WithCriteria(() => !parameters.IsPullRequest)
.WithCriteria(() => parameters.IsMainRepo)
.WithCriteria(() => parameters.IsMasterBranch)
.WithCriteria(() => parameters.IsMyGetRelease)
2016-08-16 17:14:01 +03:00
.Does(() =>
{
var apiKey = EnvironmentVariable("MYGET_API_KEY");
if(string.IsNullOrEmpty(apiKey))
{
throw new InvalidOperationException("Could not resolve MyGet API key.");
}
var apiUrl = EnvironmentVariable("MYGET_API_URL");
if(string.IsNullOrEmpty(apiUrl))
{
throw new InvalidOperationException("Could not resolve MyGet API url.");
}
2017-02-04 19:41:25 +03:00
foreach(var nupkg in packages.NugetPackages)
2016-08-16 17:14:01 +03:00
{
NuGetPush(nupkg, new NuGetPushSettings {
Source = apiUrl,
ApiKey = apiKey
});
}
})
.OnError(exception =>
{
Information("Publish-MyGet Task failed, but continuing with next Task...");
});
Task("Publish-NuGet")
.IsDependentOn("Create-NuGet-Packages")
2017-02-04 19:41:25 +03:00
.WithCriteria(() => !parameters.IsLocalBuild)
.WithCriteria(() => !parameters.IsPullRequest)
.WithCriteria(() => parameters.IsMainRepo)
.WithCriteria(() => parameters.IsNuGetRelease)
2016-08-16 17:14:01 +03:00
.Does(() =>
{
var apiKey = EnvironmentVariable("NUGET_API_KEY");
if(string.IsNullOrEmpty(apiKey))
{
throw new InvalidOperationException("Could not resolve NuGet API key.");
}
var apiUrl = EnvironmentVariable("NUGET_API_URL");
if(string.IsNullOrEmpty(apiUrl))
{
throw new InvalidOperationException("Could not resolve NuGet API url.");
}
2017-02-04 19:41:25 +03:00
foreach(var nupkg in packages.NugetPackages)
2016-08-16 17:14:01 +03:00
{
NuGetPush(nupkg, new NuGetPushSettings {
ApiKey = apiKey,
Source = apiUrl
});
}
})
.OnError(exception =>
{
Information("Publish-NuGet Task failed, but continuing with next Task...");
});
2017-07-21 18:07:12 +03:00
Task("Run-Leak-Tests")
.WithCriteria(parameters.IsRunningOnWindows)
.IsDependentOn("Build")
.Does(() =>
{
DotNetCoreRestore("tests\\Avalonia.LeakTests\\toolproject\\tool.csproj");
DotNetBuild("tests\\Avalonia.LeakTests\\toolproject\\tool.csproj", settings => settings.SetConfiguration("Release"));
var report = "tests\\Avalonia.LeakTests\\bin\\Release\\report.xml";
if(System.IO.File.Exists(report))
System.IO.File.Delete(report);
var proc = System.Diagnostics.Process.Start(new System.Diagnostics.ProcessStartInfo
{
FileName="tests\\Avalonia.LeakTests\\toolproject\\bin\\dotMemoryUnit.exe",
2017-07-21 18:07:12 +03:00
Arguments="-targetExecutable=\"tools\\xunit.runner.console\\tools\\xunit.console.x86.exe\" -returnTargetExitCode -- tests\\Avalonia.LeakTests\\bin\\Release\\Avalonia.LeakTests.dll -xml tests\\Avalonia.LeakTests\\bin\\Release\\report.xml ",
UseShellExecute = false,
});
var st = System.Diagnostics.Stopwatch.StartNew();
while(!proc.HasExited && !System.IO.File.Exists(report))
{
if(st.Elapsed.TotalSeconds>60)
{
Error("Timed out, probably a bug in dotMemoryUnit");
proc.Kill();
throw new Exception("dotMemory issue");
}
proc.WaitForExit(100);
}
try{
proc.Kill();
}catch{}
var doc = System.Xml.Linq.XDocument.Load(report);
if(doc.Root.Descendants("assembly").Any(x=>x.Attribute("failed").Value.ToString() != "0"))
{
throw new Exception("Tests failed");
}
});
2017-05-26 17:00:06 +03:00
Task("Inspect")
.WithCriteria(parameters.IsRunningOnWindows)
.IsDependentOn("Restore-NuGet-Packages")
.Does(() =>
{
var badIssues = new []{"PossibleNullReferenceException"};
var whitelist = new []{"tests", "src\\android", "src\\ios",
"src\\windows\\avalonia.designer", "src\\avalonia.htmlrenderer\\external",
"src\\markup\\avalonia.markup.xaml\\portablexaml\\portable.xaml.github"};
2017-05-26 17:00:06 +03:00
Information("Running code inspections");
StartProcess("tools\\JetBrains.ReSharper.CommandLineTools\\tools\\inspectcode.exe",
new ProcessSettings{ Arguments = "--output=artifacts\\inspectcode.xml --profile=Avalonia.sln.DotSettings Avalonia.sln" });
2017-05-26 17:00:06 +03:00
Information("Analyzing report");
var doc = XDocument.Parse(System.IO.File.ReadAllText("artifacts\\inspectcode.xml"));
2017-05-26 17:00:06 +03:00
var failBuild = false;
foreach(var xml in doc.Descendants("Issue"))
{
var typeId = xml.Attribute("TypeId").Value.ToString();
if(badIssues.Contains(typeId))
{
var file = xml.Attribute("File").Value.ToString().ToLower();
if(whitelist.Any(wh => file.StartsWith(wh)))
continue;
var line = xml.Attribute("Line").Value.ToString();
Error(typeId + " - " + file + " on line " + line);
failBuild = true;
}
}
if(failBuild)
throw new Exception("Issues found");
});
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
// TARGETS
///////////////////////////////////////////////////////////////////////////////
Task("Package")
.IsDependentOn("Create-NuGet-Packages");
Task("Default").Does(() =>
{
if(parameters.IsRunningOnWindows)
RunTarget("Package");
else
RunTarget("Run-Net-Core-Unit-Tests");
});
2016-08-16 17:14:01 +03:00
Task("AppVeyor")
.IsDependentOn("Zip-Files")
2016-08-16 17:14:01 +03:00
.IsDependentOn("Publish-MyGet")
.IsDependentOn("Publish-NuGet");
Task("Travis")
2017-03-08 23:55:19 +03:00
.IsDependentOn("Run-Net-Core-Unit-Tests");
2016-08-16 17:14:01 +03:00
///////////////////////////////////////////////////////////////////////////////
// EXECUTE
///////////////////////////////////////////////////////////////////////////////
2017-02-04 19:41:25 +03:00
RunTarget(parameters.Target);