单元测试,被用来测试你的“业务逻辑”,它们是在你的类里,独立于Symfony之外。因此,Symfony对你选择何种单元测试工具并不发表意见。不过,最受欢迎的工具还是PhpUnit和。

创建一个良好的功能测试绝非易事,以至一些开发者完全略过了这里。请不要无视功能测试!通过定义一些简单的功能测试,在部署程序之前,你可以快速地找到一些重大错误:

Best Practice

Best Practice

定义一个功能测试,至少检查一下你的程序页面是否可以被成功加载。

上述代码,检查了所有给定的URL被成功加载,这意味着HTTP响应的状态码(status code)应该是到之间。看上去似乎没什么用,但却体现出只要做出一点点的努力,功能测试就可以值回你的程序票价。

在计算机软件领域,这种类型的测试被称为smoke test),由“一些初级测试,为的是揭示一些足以影响到未来软件推出的简单错误” 所构成。

有些人可能会问,为什么前面的测试,不去使用sf系统的URL generator服务来生成url呢?

Best Practice

Best Practice

思考下面的功能测试代码,使用了服务来生成测试页面的URL:

  1. public function testBlogArchives()
  2. {
  3. $client = self::createClient();
  4. $client->request('GET', $url);
  5.  
  6. // ...

代码执行正确,但却有一个致命缺陷。如果某个开发者,错误地改变了路由的路径,则测试仍将通过,但原始的(旧的)URL却不能用了!这意味着任何收藏了那个URL的书签都将失效,你也会失去引擎的page ranking。(译注:此处意思是说,测试中使用确定的链接,意味着链接是永远确定的,就算有人为地改变了路由的路径,功能测试也将立即发现这种“改变”并且报错,这样就不会带来灾难性的后果,比如影响到用户或失去pr)

内置的功能测试client是很强大的,但却不能被用于页面中的js脚本测试。如果你需要测试js,请使用PHPUnit里面的类库。

当然,如果你使用的是重载前端框架,你应该首选纯正的前端测试工具。

可以考虑使用HautelookAliceBundle来为你的测试fixtures生成“真实的”数据,这些fixtures(假数据)是通过和Alice来得到的。