forked from OpenCodeFoundation/asset-manager
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
2814d50
commit 29e6581
Showing
8 changed files
with
473 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
@ECHO OFF | ||
PowerShell -NoProfile -NoLogo -ExecutionPolicy unrestricted -Command "[System.Threading.Thread]::CurrentThread.CurrentCulture = ''; [System.Threading.Thread]::CurrentThread.CurrentUICulture = '';& '%~dp0build.ps1'%*; exit $LASTEXITCODE" | ||
PAUSE |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
#addin "Cake.Npm" | ||
|
||
/////////////////////////////////////////////////////////////////////////////// | ||
// ARGUMENTS | ||
/////////////////////////////////////////////////////////////////////////////// | ||
|
||
var target = Argument("target", "Default"); | ||
var configuration = Argument("configuration", "Release"); | ||
var solution = File("./asset-manager.sln"); | ||
|
||
|
||
/////////////////////////////////////////////////////////////////////////////// | ||
// SETUP / TEARDOWN | ||
/////////////////////////////////////////////////////////////////////////////// | ||
|
||
Setup(ctx => | ||
{ | ||
// Executed BEFORE the first task. | ||
Information("Running tasks..."); | ||
}); | ||
|
||
Teardown(ctx => | ||
{ | ||
// Executed AFTER the last task. | ||
Information("Finished running tasks."); | ||
}); | ||
|
||
/////////////////////////////////////////////////////////////////////////////// | ||
// TASKS | ||
/////////////////////////////////////////////////////////////////////////////// | ||
|
||
Task("Clean") | ||
.Does(() => { | ||
DotNetCoreClean(solution, | ||
new DotNetCoreCleanSettings | ||
{ | ||
Configuration = configuration | ||
} | ||
); | ||
}); | ||
|
||
Task("Restore") | ||
.Does(() => { | ||
DotNetCoreRestore(); | ||
}); | ||
|
||
Task("Build") | ||
.IsDependentOn("Clean") | ||
.IsDependentOn("Restore") | ||
.Does(() => { | ||
DotNetCoreBuild(solution, | ||
new DotNetCoreBuildSettings | ||
{ | ||
NoRestore = true, | ||
ArgumentCustomization = arg => arg.AppendSwitch("/p:DebugType","=","Full") | ||
} | ||
); | ||
}); | ||
|
||
Task("Test") | ||
.IsDependentOn("Build") | ||
.Does(() => { | ||
var projectFiles = GetFiles("./tests/**/*.csproj"); | ||
foreach(var file in projectFiles) | ||
{ | ||
DotNetCoreTest(file.FullPath, | ||
new DotNetCoreTestSettings | ||
{ | ||
NoBuild = true, | ||
ArgumentCustomization = args=>args.Append("/p:CollectCoverage=true /p:CoverletOutputFormat=opencover") | ||
} | ||
); | ||
} | ||
}); | ||
|
||
#tool "nuget:?package=OpenCover" | ||
Task("OpenCover") | ||
.IsDependentOn("Build") | ||
.Does(() => { | ||
var projectFiles = GetFiles("./tests/**/*.csproj"); | ||
foreach(var file in projectFiles) | ||
{ | ||
OpenCover(tool => { | ||
tool.DotNetCoreTest(file.FullPath, | ||
new DotNetCoreTestSettings | ||
{ | ||
NoBuild = true} | ||
); | ||
}, | ||
new FilePath("./" + file.GetDirectory() + "/coverage.xml"), | ||
new OpenCoverSettings{ | ||
OldStyle = true, | ||
Register = "user" | ||
} | ||
.WithFilter("+[AssetManager*]*")); | ||
|
||
} | ||
}); | ||
|
||
#tool "nuget:?package=ReportGenerator" | ||
Task("CodeCoverage") | ||
.Does(() => { | ||
if (IsRunningOnUnix()) | ||
{ | ||
Information("Linux! Running Coverlet for code coverage"); | ||
RunTarget("Test"); | ||
} else { | ||
Information("Windows! Running OpenCover"); | ||
RunTarget("OpenCover"); | ||
} | ||
|
||
ReportGenerator("./tests/*/coverage.xml", "reports", new ReportGeneratorSettings(){ | ||
HistoryDirectory = "reports/history" | ||
}); | ||
}); | ||
|
||
Task("Default") | ||
.IsDependentOn("Test"); | ||
|
||
|
||
RunTarget(target); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,234 @@ | ||
########################################################################## | ||
# This is the Cake bootstrapper script for PowerShell. | ||
# This file was downloaded from https://github.com/cake-build/resources | ||
# Feel free to change this file to fit your needs. | ||
########################################################################## | ||
|
||
<# | ||
.SYNOPSIS | ||
This is a Powershell script to bootstrap a Cake build. | ||
.DESCRIPTION | ||
This Powershell script will download NuGet if missing, restore NuGet tools (including Cake) | ||
and execute your Cake build script with the parameters you provide. | ||
.PARAMETER Script | ||
The build script to execute. | ||
.PARAMETER Target | ||
The build script target to run. | ||
.PARAMETER Configuration | ||
The build configuration to use. | ||
.PARAMETER Verbosity | ||
Specifies the amount of information to be displayed. | ||
.PARAMETER ShowDescription | ||
Shows description about tasks. | ||
.PARAMETER DryRun | ||
Performs a dry run. | ||
.PARAMETER Experimental | ||
Uses the nightly builds of the Roslyn script engine. | ||
.PARAMETER Mono | ||
Uses the Mono Compiler rather than the Roslyn script engine. | ||
.PARAMETER SkipToolPackageRestore | ||
Skips restoring of packages. | ||
.PARAMETER ScriptArgs | ||
Remaining arguments are added here. | ||
.LINK | ||
https://cakebuild.net | ||
#> | ||
|
||
[CmdletBinding()] | ||
Param( | ||
[string]$Script = "build.cake", | ||
[string]$Target, | ||
[string]$Configuration, | ||
[ValidateSet("Quiet", "Minimal", "Normal", "Verbose", "Diagnostic")] | ||
[string]$Verbosity, | ||
[switch]$ShowDescription, | ||
[Alias("WhatIf", "Noop")] | ||
[switch]$DryRun, | ||
[switch]$Experimental, | ||
[switch]$Mono, | ||
[switch]$SkipToolPackageRestore, | ||
[Parameter(Position=0,Mandatory=$false,ValueFromRemainingArguments=$true)] | ||
[string[]]$ScriptArgs | ||
) | ||
|
||
[Reflection.Assembly]::LoadWithPartialName("System.Security") | Out-Null | ||
function MD5HashFile([string] $filePath) | ||
{ | ||
if ([string]::IsNullOrEmpty($filePath) -or !(Test-Path $filePath -PathType Leaf)) | ||
{ | ||
return $null | ||
} | ||
|
||
[System.IO.Stream] $file = $null; | ||
[System.Security.Cryptography.MD5] $md5 = $null; | ||
try | ||
{ | ||
$md5 = [System.Security.Cryptography.MD5]::Create() | ||
$file = [System.IO.File]::OpenRead($filePath) | ||
return [System.BitConverter]::ToString($md5.ComputeHash($file)) | ||
} | ||
finally | ||
{ | ||
if ($file -ne $null) | ||
{ | ||
$file.Dispose() | ||
} | ||
} | ||
} | ||
|
||
function GetProxyEnabledWebClient | ||
{ | ||
$wc = New-Object System.Net.WebClient | ||
$proxy = [System.Net.WebRequest]::GetSystemWebProxy() | ||
$proxy.Credentials = [System.Net.CredentialCache]::DefaultCredentials | ||
$wc.Proxy = $proxy | ||
return $wc | ||
} | ||
|
||
Write-Host "Preparing to run build script..." | ||
|
||
if(!$PSScriptRoot){ | ||
$PSScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent | ||
} | ||
|
||
$TOOLS_DIR = Join-Path $PSScriptRoot "tools" | ||
$ADDINS_DIR = Join-Path $TOOLS_DIR "Addins" | ||
$MODULES_DIR = Join-Path $TOOLS_DIR "Modules" | ||
$NUGET_EXE = Join-Path $TOOLS_DIR "nuget.exe" | ||
$CAKE_EXE = Join-Path $TOOLS_DIR "Cake/Cake.exe" | ||
$NUGET_URL = "https://dist.nuget.org/win-x86-commandline/latest/nuget.exe" | ||
$PACKAGES_CONFIG = Join-Path $TOOLS_DIR "packages.config" | ||
$PACKAGES_CONFIG_MD5 = Join-Path $TOOLS_DIR "packages.config.md5sum" | ||
$ADDINS_PACKAGES_CONFIG = Join-Path $ADDINS_DIR "packages.config" | ||
$MODULES_PACKAGES_CONFIG = Join-Path $MODULES_DIR "packages.config" | ||
|
||
# Make sure tools folder exists | ||
if ((Test-Path $PSScriptRoot) -and !(Test-Path $TOOLS_DIR)) { | ||
Write-Verbose -Message "Creating tools directory..." | ||
New-Item -Path $TOOLS_DIR -Type directory | out-null | ||
} | ||
|
||
# Make sure that packages.config exist. | ||
if (!(Test-Path $PACKAGES_CONFIG)) { | ||
Write-Verbose -Message "Downloading packages.config..." | ||
try { | ||
$wc = GetProxyEnabledWebClient | ||
$wc.DownloadFile("https://cakebuild.net/download/bootstrapper/packages", $PACKAGES_CONFIG) } catch { | ||
Throw "Could not download packages.config." | ||
} | ||
} | ||
|
||
# Try find NuGet.exe in path if not exists | ||
if (!(Test-Path $NUGET_EXE)) { | ||
Write-Verbose -Message "Trying to find nuget.exe in PATH..." | ||
$existingPaths = $Env:Path -Split ';' | Where-Object { (![string]::IsNullOrEmpty($_)) -and (Test-Path $_ -PathType Container) } | ||
$NUGET_EXE_IN_PATH = Get-ChildItem -Path $existingPaths -Filter "nuget.exe" | Select -First 1 | ||
if ($NUGET_EXE_IN_PATH -ne $null -and (Test-Path $NUGET_EXE_IN_PATH.FullName)) { | ||
Write-Verbose -Message "Found in PATH at $($NUGET_EXE_IN_PATH.FullName)." | ||
$NUGET_EXE = $NUGET_EXE_IN_PATH.FullName | ||
} | ||
} | ||
|
||
# Try download NuGet.exe if not exists | ||
if (!(Test-Path $NUGET_EXE)) { | ||
Write-Verbose -Message "Downloading NuGet.exe..." | ||
try { | ||
$wc = GetProxyEnabledWebClient | ||
$wc.DownloadFile($NUGET_URL, $NUGET_EXE) | ||
} catch { | ||
Throw "Could not download NuGet.exe." | ||
} | ||
} | ||
|
||
# Save nuget.exe path to environment to be available to child processed | ||
$ENV:NUGET_EXE = $NUGET_EXE | ||
|
||
# Restore tools from NuGet? | ||
if(-Not $SkipToolPackageRestore.IsPresent) { | ||
Push-Location | ||
Set-Location $TOOLS_DIR | ||
|
||
# Check for changes in packages.config and remove installed tools if true. | ||
[string] $md5Hash = MD5HashFile($PACKAGES_CONFIG) | ||
if((!(Test-Path $PACKAGES_CONFIG_MD5)) -Or | ||
($md5Hash -ne (Get-Content $PACKAGES_CONFIG_MD5 ))) { | ||
Write-Verbose -Message "Missing or changed package.config hash..." | ||
Remove-Item * -Recurse -Exclude packages.config,nuget.exe | ||
} | ||
|
||
Write-Verbose -Message "Restoring tools from NuGet..." | ||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$TOOLS_DIR`"" | ||
|
||
if ($LASTEXITCODE -ne 0) { | ||
Throw "An error occurred while restoring NuGet tools." | ||
} | ||
else | ||
{ | ||
$md5Hash | Out-File $PACKAGES_CONFIG_MD5 -Encoding "ASCII" | ||
} | ||
Write-Verbose -Message ($NuGetOutput | out-string) | ||
|
||
Pop-Location | ||
} | ||
|
||
# Restore addins from NuGet | ||
if (Test-Path $ADDINS_PACKAGES_CONFIG) { | ||
Push-Location | ||
Set-Location $ADDINS_DIR | ||
|
||
Write-Verbose -Message "Restoring addins from NuGet..." | ||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$ADDINS_DIR`"" | ||
|
||
if ($LASTEXITCODE -ne 0) { | ||
Throw "An error occurred while restoring NuGet addins." | ||
} | ||
|
||
Write-Verbose -Message ($NuGetOutput | out-string) | ||
|
||
Pop-Location | ||
} | ||
|
||
# Restore modules from NuGet | ||
if (Test-Path $MODULES_PACKAGES_CONFIG) { | ||
Push-Location | ||
Set-Location $MODULES_DIR | ||
|
||
Write-Verbose -Message "Restoring modules from NuGet..." | ||
$NuGetOutput = Invoke-Expression "&`"$NUGET_EXE`" install -ExcludeVersion -OutputDirectory `"$MODULES_DIR`"" | ||
|
||
if ($LASTEXITCODE -ne 0) { | ||
Throw "An error occurred while restoring NuGet modules." | ||
} | ||
|
||
Write-Verbose -Message ($NuGetOutput | out-string) | ||
|
||
Pop-Location | ||
} | ||
|
||
# Make sure that Cake has been installed. | ||
if (!(Test-Path $CAKE_EXE)) { | ||
Throw "Could not find Cake.exe at $CAKE_EXE" | ||
} | ||
|
||
|
||
|
||
# Build Cake arguments | ||
$cakeArguments = @("$Script"); | ||
if ($Target) { $cakeArguments += "-target=$Target" } | ||
if ($Configuration) { $cakeArguments += "-configuration=$Configuration" } | ||
if ($Verbosity) { $cakeArguments += "-verbosity=$Verbosity" } | ||
if ($ShowDescription) { $cakeArguments += "-showdescription" } | ||
if ($DryRun) { $cakeArguments += "-dryrun" } | ||
if ($Experimental) { $cakeArguments += "-experimental" } | ||
if ($Mono) { $cakeArguments += "-mono" } | ||
$cakeArguments += $ScriptArgs | ||
|
||
# Start Cake | ||
Write-Host "Running build script..." | ||
&$CAKE_EXE $cakeArguments | ||
exit $LASTEXITCODE |
Oops, something went wrong.