Skip to content

Commit

Permalink
WIP - Added Cake Build script
Browse files Browse the repository at this point in the history
  • Loading branch information
garywoodfine committed Aug 12, 2020
1 parent 64a51eb commit 96bbddc
Show file tree
Hide file tree
Showing 5 changed files with 205 additions and 24 deletions.
7 changes: 6 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# Threenine.Map
[![Build status](https://ci.appveyor.com/api/projects/status/5tm9exklhej7jhs9?svg=true)](https://ci.appveyor.com/project/garywoodfine/reflectmap) [![NuGet](http://img.shields.io/nuget/v/Threenine.Map.svg)](https://www.nuget.org/packages/Threenine.Map/) [![NuGet Downloads](http://img.shields.io/nuget/dt/Threenine.Map.svg?style=flat)](https://www.nuget.org/packages/Threenine.Map/) [![Twitter Follow](https://img.shields.io/twitter/follow/threenine39.svg?style=social?maxAge=2592000)](https://twitter.com/threenine39) [![Documentation Status](https://readthedocs.org/projects/threeninemap/badge/?version=latest)](http://threeninemap.readthedocs.io/en/latest/?badge=latest)
[![NuGet](http://img.shields.io/nuget/v/Threenine.Map.svg)](https://www.nuget.org/packages/Threenine.Map/) [![NuGet Downloads](http://img.shields.io/nuget/dt/Threenine.Map.svg?style=flat)](https://www.nuget.org/packages/Threenine.Map/) [![Twitter Follow](https://img.shields.io/twitter/follow/threenine39.svg?style=social?maxAge=2592000)](https://twitter.com/threenine39) [![Documentation Status](https://readthedocs.org/projects/threeninemap/badge/?version=latest)](http://threeninemap.readthedocs.io/en/latest/?badge=latest)

Want a simple way to create clean & simple configuration for AutoMapper?

Expand Down Expand Up @@ -29,6 +29,11 @@ We are currently compiling comprehensive documentation and examples of use of a

If you find there are aspects of the library that you are unsure of or would like further clarification, [report an issue](https://github.com/threenine/ReflectMap/issues) and we'll attempt to address is as soon as resource allows.

### Support This Project

If you have found this project helpful, either as a library that you use or as a learning tool, please consider buying the team a coffee:

<a href="https://www.buymeacoffee.com/XBhTJcRiC" target="_blank"><img src="https://www.buymeacoffee.com/assets/img/custom_images/orange_img.png" alt="Buy Me A Coffee" style="height: 41px !important;width: 174px !important" ></a>



Expand Down
7 changes: 0 additions & 7 deletions appveyor.yml

This file was deleted.

82 changes: 82 additions & 0 deletions build.cake
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
#tool "nuget:?package=JetBrains.dotCover.CommandLineTools&version=2020.1.4"
var target = Argument("Target", "Default");
var configuration = Argument("Configuration", "Release");

Information($"Running target {target} in configuration {configuration}");

var distDirectory = Directory("./build");
var packageDirectory = Directory("./package");
var temporaryFolder = Directory("./temp");
TaskSetup(setupContext =>
{
if(TeamCity.IsRunningOnTeamCity)
{
TeamCity.WriteStartBuildBlock(setupContext.Task.Description ?? setupContext.Task.Name);
}
});

TaskTeardown(teardownContext =>
{
if(TeamCity.IsRunningOnTeamCity)
{
TeamCity.WriteEndProgress(teardownContext.Task.Description ?? teardownContext.Task.Name);
}
});

Task("Clean")
.Description("Cleaning the solution directory")
.Does(() =>
{
CleanDirectory(distDirectory);
});

Task("Restore")
.Description("Restoring the solution dependencies")
.Does(() =>
{
DotNetCoreRestore();
});

Task("Build")
.Description("Building the Solution")
.Does(() =>
{

var buildSettings = new DotNetCoreBuildSettings {
Configuration = configuration,
ArgumentCustomization = args => args.Append("--no-restore"),
};
var projects = GetFiles("./**/*.csproj");

foreach(var project in projects)
{
Information("Building Project: " + project.ToString());
DotNetCoreBuild(project.ToString(), buildSettings);
}
});

Task("Test")
.Description("Running Unit Tests")
.Does(() =>
{
var projects = GetFiles("./tests/**/*.Tests.csproj");
foreach(var project in projects)
{
Information("Testing project " + project);
DotNetCoreTest(
project.ToString(),
new DotNetCoreTestSettings()
{
Configuration = configuration
});
}
});

Task("Default")
.Description("Default build task")
.IsDependentOn("Clean")
.IsDependentOn("Restore")
.IsDependentOn("Build")
.IsDependentOn("Test");

RunTarget(target);
117 changes: 117 additions & 0 deletions build.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
#!/usr/bin/env bash

##########################################################################
# This is the Cake bootstrapper script for Linux and OS X.
# This file was downloaded from https://github.com/cake-build/resources
# Feel free to change this file to fit your needs.
##########################################################################

# Define directories.
SCRIPT_DIR=$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )
TOOLS_DIR=$SCRIPT_DIR/tools
ADDINS_DIR=$TOOLS_DIR/Addins
MODULES_DIR=$TOOLS_DIR/Modules
NUGET_EXE=$TOOLS_DIR/nuget.exe
CAKE_EXE=$TOOLS_DIR/Cake/Cake.exe
PACKAGES_CONFIG=$TOOLS_DIR/packages.config
PACKAGES_CONFIG_MD5=$TOOLS_DIR/packages.config.md5sum
ADDINS_PACKAGES_CONFIG=$ADDINS_DIR/packages.config
MODULES_PACKAGES_CONFIG=$MODULES_DIR/packages.config

# Define md5sum or md5 depending on Linux/OSX
MD5_EXE=
if [[ "$(uname -s)" == "Darwin" ]]; then
MD5_EXE="md5 -r"
else
MD5_EXE="md5sum"
fi

# Define default arguments.
SCRIPT="build.cake"
CAKE_ARGUMENTS=()

# Parse arguments.
for i in "$@"; do
case $1 in
-s|--script) SCRIPT="$2"; shift ;;
--) shift; CAKE_ARGUMENTS+=("$@"); break ;;
*) CAKE_ARGUMENTS+=("$1") ;;
esac
shift
done

# Make sure the tools folder exist.
if [ ! -d "$TOOLS_DIR" ]; then
mkdir "$TOOLS_DIR"
fi

# Make sure that packages.config exist.
if [ ! -f "$TOOLS_DIR/packages.config" ]; then
echo "Downloading packages.config..."
curl -Lsfo "$TOOLS_DIR/packages.config" https://cakebuild.net/download/bootstrapper/packages
if [ $? -ne 0 ]; then
echo "An error occurred while downloading packages.config."
exit 1
fi
fi

# Download NuGet if it does not exist.
if [ ! -f "$NUGET_EXE" ]; then
echo "Downloading NuGet..."
curl -Lsfo "$NUGET_EXE" https://dist.nuget.org/win-x86-commandline/latest/nuget.exe
if [ $? -ne 0 ]; then
echo "An error occurred while downloading nuget.exe."
exit 1
fi
fi

# Restore tools from NuGet.
pushd "$TOOLS_DIR" >/dev/null
if [ ! -f "$PACKAGES_CONFIG_MD5" ] || [ "$( cat "$PACKAGES_CONFIG_MD5" | sed 's/\r$//' )" != "$( $MD5_EXE "$PACKAGES_CONFIG" | awk '{ print $1 }' )" ]; then
find . -type d ! -name . ! -name 'Cake.Bakery' | xargs rm -rf
fi

mono "$NUGET_EXE" install -ExcludeVersion
if [ $? -ne 0 ]; then
echo "Could not restore NuGet tools."
exit 1
fi

$MD5_EXE "$PACKAGES_CONFIG" | awk '{ print $1 }' >| "$PACKAGES_CONFIG_MD5"

popd >/dev/null

# Restore addins from NuGet.
if [ -f "$ADDINS_PACKAGES_CONFIG" ]; then
pushd "$ADDINS_DIR" >/dev/null

mono "$NUGET_EXE" install -ExcludeVersion
if [ $? -ne 0 ]; then
echo "Could not restore NuGet addins."
exit 1
fi

popd >/dev/null
fi

# Restore modules from NuGet.
if [ -f "$MODULES_PACKAGES_CONFIG" ]; then
pushd "$MODULES_DIR" >/dev/null

mono "$NUGET_EXE" install -ExcludeVersion
if [ $? -ne 0 ]; then
echo "Could not restore NuGet modules."
exit 1
fi

popd >/dev/null
fi

# Make sure that Cake has been installed.
if [ ! -f "$CAKE_EXE" ]; then
echo "Could not find Cake.exe at '$CAKE_EXE'."
exit 1
fi

# Start Cake
exec mono "$CAKE_EXE" $SCRIPT "${CAKE_ARGUMENTS[@]}"
16 changes: 0 additions & 16 deletions build.sln

This file was deleted.

0 comments on commit 96bbddc

Please sign in to comment.