使用 tSQLt 进行 SQL Server 单元测试

阅读数:869 2012 年 2 月 13 日

话题:测试语言 & 开发

tSQLt是一种用于在 SQL Server 中进行单元测试的免费开源框架。开发者可以编写 tSQLt 测试案例,从而基于生产数据创建虚拟的表和视图,然后将期望值与实际的测试结果进行比较。测试是用 T-SQL 编写的,因此可以直接在 SQL Server Management Studio 中创建。

使用 tSQLt,开发者就能够拥有测试案例本身创建的数据,而不需要基于生产数据库的副本或者需要单独维护的测试数据库来测试。所有测试都在事务中执行,这有助于减少清理的工作。tSQLt 测试可以逻辑分组到名为 test classes 的数据库 schema 中。

安装这个框架很简单;下载了 tsQLt之后,用户首先需要在数据库上启用 CLR。

EXEC sp_configure 'clr enabled', 1;
RECONFIGURE;

执行 tSQLt 文件夹中的 Example.sql 脚本会创建演示数据库。(想要把 tSQLt 安装到另一个数据库中,你需要运行 ALTER DATABASE,并加上 SET TRUSTWORTHY ON 声明)。

下一步是设置 test class,其中会包含多个测试案例。这也只是创建新的 schema:

EXEC tSQLt.NewTestClass 'AcceleratorTests';
GO

这些工作完成之后,就可以创建测试案例了;以下是一个示例。所有测试案例的名称都需要以“test”开头,并遵循 SQL Server 存储过程的命名规则。这个示例创建了一个测试表,然后插入数据,并调用了函数 GetStatusMessage。tSQLt 函数 AssertEquals 会根据期望值检查实际的结果,如果匹配的话,测试就通过了。

CREATE PROCEDURE [AcceleratorTests].[test status message includes the number of particles]
AS
BEGIN
  --Assemble: Fake the Particle table to make sure it is empty and that constraints will not be a problem
  EXEC tSQLt.FakeTable 'Accelerator.Particle';
  --          Put 3 test particles into the table
  INSERT INTO Accelerator.Particle (Id) VALUES (1);
  INSERT INTO Accelerator.Particle (Id) VALUES (2);
  INSERT INTO Accelerator.Particle (Id) VALUES (3);
  --Act: Call the GetStatusMessageFunction
  DECLARE @StatusMessage NVARCHAR(MAX);
  SELECT @StatusMessage = Accelerator.GetStatusMessage();

  --Assert: Make sure the status message is correct
  EXEC tSQLt.AssertEqualsString 'The Accelerator is prepared with 3 particles.', @StatusMessage;
END;

当执行这个测试案例的时候,结果会以文本形式显示(或者可以选择以 XML 格式输出):

+----------------------+
|Test Execution Summary|
+----------------------+

|No|Test Case Name                                                          |Result 
+--+------------------------------------------------------------------------+-------+
|1|[AcceleratorTests].[test status message includes the number of particles]|Success|
-------------------------------------------------------------------------------
Msg 50000, Level 16, State 10, Line 1
Test Case Summary: 1 test case(s) executed, 1 succeeded, 0 failed, 0 errored.
-------------------------------------------------------------------------------

一旦在测试类中创建了大量测试案例,我们就可以使用 EXEC tSQLt.RunAll 来批量运行。想要获得更多开始使用 tSQLt 的信息,你可以访问tSQLt 教程

如果你想要把 SQL 单元测试作为持续构建过程的一部分,那么可以把 tSQLt与 Cruise Control 集成。正如之前在 InfoQ 中曾经报道过的,有一个针对 tSQLt 的可视化界面叫做SQL Test。tSQLt 与 SQL Server 2005 SP2 及更高版本兼容。

查看英文原文:SQL Server Unit Testing with tSQLt