psake 是一个集成了 PowerShell 的用来创建自动化脚本的工具,其 2.01 版本集成了 PowerShell2.0 。Ayende Rahien 正使用它来创建 Rhino 工具。psake 项目的拥有者 James Kovacs 向我们解释了该工具最新版本的改进之处:
psake 最新版本通过使用构建脚本中的 PowerShell 语法,避免了与可执行的 XML 文件相关的尖括号标识 (<>)。psake 借鉴了 rake(即 Ruby 中的 make) 和 bake(即 Boo 中的 make) 的语法结构,但它更容易用来编写脚本,因为它还利用了使用者已知的命令行编程知识。
除了兼容 PS2.0 之外,psake2.01 还被改写成了一个 PS 模块,这样做的主要好处是:
- 所创建编译的脚本不需要知道 psake 安装在哪里,它们只需要调用 Invoke-psake 方法就可以执行了;
- 封装性:不再需要全局变量,因为除了显示地导出之外,对于某个模块来说它们可以被视为私有的;
- 如果需要的话,可以卸载模块来除去内存中所有的代码和变量。
2.01 版本的其他改进之处还有:
- 采用了与之前不同的编码风格;
- 使用 Try/Catch 代替"Trap"语句;
- 除去了"exec"函数;
- 现在使用者可以为一项任务定义前置和后置动作;
- 现在使用者可以定义任务名称的格式;
- 现在使用者可以定义一个"TaskSetup"方法,此方法将在每个任务开始之前被执行(从 NUnit 中借鉴而来);
- 现在使用者可以定义一个"TaskTearDown"方法,此方法将在每个任务结束之后被执行(也是从 NUnit 中借鉴而来);
- 创建了名为"psake_buildSucceeded"的全局变量,当编译成功后此变量将被设置为 true。脚本可以通过检查此变量,来判断是否编译成功;
- 在 Run-Psake 时还加入了一个"$noexit"开关变量,当此开关打开时任何函数执行结束前都不会调用 exit() 方法,这样使用者就可以在 PS 窗口不被关闭的条件下,通过命令行来测试你所创建的脚本了。(此处默认的操作是,当一个脚本运行失败时,它将会调用 exit(1) 方法,这样在调用的代码中就可以判定此脚本是成功或失败了)
- psake-buildTester.ps1 脚本必须做一些小改动才能调用 Invoke-psake 方法.
- 在.\examples 目录中加入了更多的示例来演示后置条件(POST conditions),前置和后置动作(PRE and POST Actions)以及其他(新特性)的用法。
Ayende Rahien 写了关于使用 psake 来创建他的 Rhino 工具 psake to build his Rhino Tools 的相关文章。这个项目起初使用了一种十分复杂的基于 NAnt 的编写工具,仅仅是最初的尝试,开发者就写出了海量的代码,这使得他们感到惊恐万分。经过对使用 Rake 或 Bake 来开发的可行性评估后,Rahien 转向使用 psake 并仅用了 50 行代码就解决了工作。
psake 可以在 GitHub 网站的 MIT License 页面下载.
查看英文原文: Simple Build Automation with psake
译者介绍:崇桦,澳大利亚悉尼大学计算机科学与通信技术学士,多年的海外留学工作经历。现于 iConnect China 任职 Team Leader,带领团队进行微软产品的开发与测试工作。有丰富的.NET 产品设计,软件开发经验,对项目管理,敏捷开发的有相当的研究。InfoQ 中文站内容团队,尤其是架构、SOA 和Ruby 社区需要您的参与,有意者请邮件至 editors【AT】cn.infoq.com 。
评论