与我之前的问题相反,我将尝试给出我的要求。
我正在尝试找到一些适合以下内容的框架/方法/“事物”:
- 能够使用 C# 编写自动化测试,最好用 Visual Studio 编写。
- 测试应该像用户一样驱动 Web 浏览器并与 SUT 交互。
- 测试应该能够在数据库中设置测试场景。
- 测试应该能够断言用户交互在 DB 中具有预期的效果。
- 测试完成后,它应该能够回滚它在数据库中所做的所有更改。
我的第一次尝试是使用 NUnit 测试来驱动 Selenium(以及之前的 Watin),但我在使用 TransactionScope 回滚 Selenium 驱动的浏览器在数据库中所做的更改时遇到了一些问题(检查上面的链接)。
有没有人在“现实世界”中做过这样的事情?我通过谷歌找到了一些参考资料,但还没有找到任何具体的例子来说明如何实现这一点。如果我要进行单元测试,就不会有任何问题。在那种情况下,TransactionScope 就足够了。
编辑: R. Harvey 向我指出了这个问题,这与我的情况几乎相同。
然而,这个问题几乎是相同的。我的应用程序是一系列服务的一部分,它们都访问同一组数据库表。所需的测试数据量不允许有效使用 drop/create-scripts,那么是否有一些替代解决方案?
我们使用的是 SQL Server 2005,而且我对数据库魔法不是很精通,所以如果除了 drop/create 之外还有其他方法可以使用 sql 脚本,那么这可能是一个选择。
编辑2:
根据答案和一些额外的头疼问题,我们将为开发人员寻找更轻量级的数据库来执行单元、集成和功能测试。这使我们能够使用 sql 脚本来设置和拆除测试。