在上一篇C#Make自动化构建-简介中,简单的介绍了下Cake的脚本如何编写以及通过Powershell在本地运行Cake脚本。本篇在此基础上,介绍下如何在CI环境中使用Cake。
Cake的每一个Task都可以添加一项描述,用来解释它的用途。比如下面的示例:
1 Task("restore")
2 .Description("还原项目依赖")
3 .Does(() =>
4 {
5 DotNetCoreRestore(soluction);
6 });
然后Cake接收一个名为 ShowsDescription 的参数,运行Powershell或者bash的时候可以传递-ShowDescription来显示Task的信息。为了方便输入,我把ShowDescription改成了Help(仅更改了build.ps1中传递参数的名称)。
Cake目前有两个版本(参见Cake Releases):
mono cake.exe
dotnet cake.dll
我们直接下载这两个nuget包,然后用7z解压一下(nupkg文件为zip):
cake.0.26.1.nupkg解压后如下:
在windows下可以直接通过console窗口来运行它:
cake.coreclr.0.26.1.nupkg解压后如下:
可以通过dotnet cake.dll来运行它:
Cake脚本本身的跨平台(windows,linux,docker等)是借助于上面提到的cake.exe或cake.coreclr来实现的。基于这些,我们可以有如下的组合:
由于目前dotnet cli本身的不健全,缺少独立于*.csproj文件之外来安装nuget包的命令,故而使得安装cake.coreclr变得非常恶心。参见两种变通方法:
故而目前在window平台下选择1,在其他平台下选择3比较合适,在docker下可以构建一个mone+dotnet的混合环境的image(https://hub.docker.com/r/lnhcode/dotnet2-mono5/)。
好消息是目前.net core的每日构建版已经添加了 dotnet install 和 dotnet install tool 的命令(https://github.com/dotnet/cli/blob/master/src/dotnet/commands/dotnet-install/InstallCommandParser.cs),可以直接用来安装nuget包。这个新功能会随着.net core 2.1的正式发布而到来。到时候就可以统一借助dotnet cli来安装cake.coreclr了。
cake的目的在于一次编写,可以运行在不同的构建环境和构建工具中。同时可以把构建脚本纳入到源代码管理中,而不是编写在某一特定的ci/cd工具中。正如这篇文章https://www.thoughtworks.com/radar/techniques/programming-in-your-ci-cd-tool中的观点一样。
借助Github提供的很多免费的CI服务,我在https://github.com/linianhui/cake.example上接入了3个CI服务。
AppVeyor主要提供有windows的ci环境,我们只需要再github的项目根目录添加 appveyor.yml 文件,然后关联一下AppVeyor的服务即可。
1 version: 1.0.{build}
2 image: Visual Studio 2017
3 build: off
4 test_script:
5 - ps: ./build.ps1 -target test
上面的这个示例调用了build.ps1来运行测试https://ci.appveyor.com/project/linianhui/cake-example。
Travis提供有linux的ci环境,同样的我们添加一个 .travis.yml 文件然后关联Travis的服务即可。
1 language: csharp
2
3 os:
4 - linux
5
6 mono: latest
7
8 dotnet: 2.1.4
9
10 script:
11 - chmod +x ./build.sh
12 - ./build.sh -target=test
上面的这个示例的运行环境是linux,安装了mone和dotnet,然后调用了build.sh来运行测试https://travis-ci.org/linianhui/cake.example。
Circle提供有docker的环境,同样的添加一个 .circleci/config.yml 文件然后关联Circle的服务即可。
1 version: 2
2
3 jobs:
4 test:
5 docker:
6 - image: lnhcode/dotnet2-mono5
7 steps:
8 - checkout
9 - run: chmod +x ./build.sh
10 - run: ./build.sh -target=test
11
12 workflows:
13 version: 2
14 test:
15 jobs:
16 - test
上面的示例中我使用了自己定义的一个dotnet2-mono2的docker镜像,然后调用builds.sh来运行测试https://circleci.com/gh/linianhui/cake.example/tree/master。dotnet2-mono5的镜像位于:https://hub.docker.com/r/lnhcode/dotnet2-mono5/
以上简单的介绍了一下Cake的简介信息,和如何再不同的CI环境中使用Cake来维护一个相同的自动化构建的流程。如有错误,欢迎指正!
dotnet2-mono5 的dockerfile:https://github.com/linianhui/dockerfiles/blob/master/dotnet2-mono5/Dockerfile
本文示例代码:https://github.com/linianhui/cake.example
不要再CI/CD中编程:https://www.thoughtworks.com/radar/techniques/programming-in-your-ci-cd-tool