[Cake] 0.C#Make自動化構建-簡介

来源:http://www.cnblogs.com/linianhui/archive/2017/05/06/cake-overview.html
-Advertisement-
Play Games

0. Cake是什麼? Cake是C# Make的縮寫,是一個基於C# DSL的自動化構建系統。它可以用來編譯代碼,複製文件以及文件夾,運行單元測試,壓縮文件以及構建Nuget包等等。 熟悉大名鼎鼎的Make的小伙伴,應該已經知道Cake大致是個什麼樣的工具了,Cake具有以下幾個特點: 1. 一個 ...


0. Cake是什麼?

Cake是C# Make的縮寫,是一個基於C# DSL的自動化構建系統。它可以用來編譯代碼,複製文件以及文件夾,運行單元測試,壓縮文件以及構建Nuget包等等。

熟悉大名鼎鼎的Make的小伙伴,應該已經知道Cake大致是個什麼樣的工具了,Cake具有以下幾個特點:

  1. 方便編寫:使用基於C#的DSL,非常易於編寫自動化的腳本。
  2. 跨平臺: 基於Roslyn和Mono來編譯我們寫的自動化腳本,使得它可以運行在windows,linux,mac上。
  3. 可靠的:可以建立在自己的機器上,也可以建立在像AppVeyor,TeamCity,TFS,VSTS或Jenkins這樣的CI系統上,都可以以相同的方式運行。
  4. 豐富的工具集:支持MSBuild,MSTest,xUnit,NUnit,Nuget,ILMerge,Wix和SignTool等等,以及支持豐富的插件(Cake Addins)。
  5. 開源:基於MIT開放源代碼(Cake on Github),並且是.NET 基金會支持的一個項目(Cake on dotnet foundation)。

1. 一個簡單的DEMO

筆者在Github上創建了一個簡單的DEMO(cake.demo),下麵簡單的介紹,項目非常簡單,一個類庫項目,一個測試項目,如下:

1.1 下載引導腳本

首先第一步下載一個基於Powershell的引導腳本文件build.ps1,這個文件並不是必須的,你可以直接用調用cake腳本文件),在項目所在的目錄下運行: Invoke-WebRequest http://cakebuild.net/download/bootstrapper/windows -OutFile build.ps1 

備註:當前筆者是基於windows平臺,開發環境是vs 2017 community:

linux : curl -Lsfo build.sh http://cakebuild.net/download/bootstrapper/linux

mac  : curl -Lsfo build.sh http://cakebuild.net/download/bootstrapper/osx

1.2 創建Cake腳本

添加一個文本文件build.cake(文件名隨意,筆者懶調整build.ps1中指定的cake腳本文件而已。完整文件:https://github.com/linianhui/cake.demo/blob/master/build.cake)

這一步我們用Cake來build以下我們上面的cake.demo這個項目。文件內容如下:

 1 /// args
 2 var target = Argument("target", "default");
 3 
 4 
 5 /// build task
 6 Task("build")
 7     .Does(() =>
 8 {
 9     MSBuild("./cake.demo.sln", new MSBuildSettings{
10         Verbosity = Verbosity.Minimal
11     });
12 });
13 
14 
15 Task("default")
16     .IsDependentOn("build");
17 
18 
19 /// run task
20 RunTarget(target);

腳本可以說是非常簡單易懂,相信有C#基礎的應該非常容易理解。

  1. 首先,創建了一個參數target(名字和build.ps1中指定的參數名一致),預設值是“default”。
  2. 其次,創建了一個名為build的Task,這個task調用MSBuild來build我們的項目。
  3. 然後,創建了一個名為default的task,它什麼都沒乾,只是標識說我依賴一個為build的task,含義就是在運行default的task之前,會先運行build的task。
  4. 最後,用RunTarget來運行指定名字的task。

OK,我們來運行一下build.ps1(初次運行它會下載cake所需的一些文件,這些文件會存放於build.ps1中指定的文件夾,預設是tools文件夾,感興趣的可以看一看build.ps1裡面幹了什麼)。咦,運行出錯了!

原因是我的一個Demo.Tests這個項目引用了xUnit的包,MSBuild沒能正確的還原nuget包,這不知道算不算一個bug,筆者之前用 Cake的MSBuild來build vs2015的項目的時候是沒有問題的,當前環境只安裝了VS2017。不過也正好,我們再用Cake來寫一個還原nuget包的task。

1 /// nuget task
2 Task("restore-nuget-packages")
3     .Does(() =>
4 {
5     NuGetRestore("./cake.demo.sln");
6 });

再運行一次:

這次可以了。

然後我們再依次的添加幾個task,清理build的文件:

1 Task("clean")
2     .Does(() =>
3 {
4     CleanDirectories("./src/*/bin");
5     CleanDirectories("./test/*/bin");
6 });

運行單元測試:

1 /// unit-test task
2 Task("unit-test")
3     .IsDependentOn("build")
4     .Does(() =>
5 {
6     XUnit2("./test/*/bin/*/*.Tests.dll");
7 });

然後運行一下:

1.3 build.ps1

在前面我們提到這個文件並不是必須的文件,而是用它來下載Cake所需要的相關文件,以及設置預設的Cake配置。再者,我們可以通過它來簡化對Cake的調用,比如上面列出來的幾個task,我們可以通過傳遞參數給build.ps1,來運行我們指定的task(預設運行了default嘛)。比如:

僅清理項目的build生成的文件。

2. 總結

得益於Cake基於C#DSL來編寫腳本,相比寫Powershell或者其他的腳本來完成自動化構建,使得C#開發人員非常容易上手。

其次Cake基於Roslyn和Mono,使得它可以提供跨平臺的自動化構建,也可以運行在各種常用的CI系統之上。

再者Cake提供了豐富的內建工具集以及插件(Cake Addins),可以滿足我們絕大部分的自動化構建需求,比如,編譯,測試,打包,部署等等。

例如前些日子我的一個web的demo項目(https://github.com/linianhui/Ids3.demo)使用cake來部署iis站點。

3. 參考資料

Make

C# Make

Cake Addins

Cake on Github

Cake on dotnet foundation

cake.demo

http://cakebuild.net/docs/tutorials/getting-started

http://cakebuild.net/docs/resources/videos

https://github.com/cake-build/example

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我遇到問題產生的原因:資料庫表的某個欄位為不能為空。在修改實體屬性的時候,實體對應的表中不能為空的欄位為null。 詳情: 資料庫: c #: 錯誤代碼: 正確代碼: ...
  • 最近由於工作需要,做一個C#的簡單程式。學習了一些基礎東西先記下來。 主要有: 1.生成初始框架 2.打亂順序 3.游戲部分,點擊按鈕後與空白部分交換的只是Text和Visible部分 ...
  • 前端應用程式 ASP.NET Zero包含可以作為您的公共網站或應用程式著陸頁的起點的前端頁面。首次運行項目時,您會看到主頁如下所示: 這裡有兩頁:主頁和關於。這些頁面的內容只是占位符和演示目的。您可以根據需要完全刪除內容並構建頁面。此外,你應該改變的標誌與貴公司的標誌。 請參閱 metronic前 ...
  • 後端應用程式 這是用戶名和密碼輸入的實際應用程式。您將主要在此應用程式上添加您的業務需求。 應用文件夾 後端應用程式預設內置在專用區域,名為“ App ”,但可以在創建解決方案時確定。因此,所有控制器,視圖和模型都位於 Areas / App文件夾下。此外,相關腳本和樣式文件位於wwwroot / ...
  • ASP.NET Zero--開髮指南(Lyhcee 譯) 01. 前期介紹 02. 前期要求 03. 解決方案結構(層) 04. 前端應用程式 05. 後端應用程式 06.WEB.HOST應用程式 07.Migration控制台應用程式 08. 基礎設施 09. 基於令牌的認證&SWAGGER UI ...
  • 一、前言 我心中的插件系統應該是像Nop那樣(更牛逼的如Orchard,OSGI.NET),每個插件模塊不只是一堆實現了某個業務介面的dll,然後採用反射或IOC技術來調用,而是一個完整的mvc小應用,我可以在後臺控制插件的安裝和禁用,目錄結構如下: 生成後放在站點根目錄下的Plugins文件夾中, ...
  • 今天分享一個 WPF 版的ColorDialog,該控制項源自 這裡,不過筆者已經該控制項做了大量的修改工作,以適應自己的產品需求,閑話少說,先看看效果圖: 1、DropDownCustomColorPicker 效果圖 先看原項目的(喜歡這種方式的,請到 這裡 下載源碼 ) 被筆者修改之後的效果圖: ...
  • 之前瞭解過索引器,當時還把索引器和屬性給記混了, 以為索引器就是屬性,下麵寫下索引器和屬性的區別,以及怎麼使用索引器 先說明一點,這裡的索引器和資料庫中的索引不一樣,雖然都是找元素。 索引器和屬性的區別: 屬性是以名稱來標識,而索引器是以函數的形式來標識(但是索引器不能完全理解為函數); 索引器可以... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...