In this blog, I am sharing the key points which I noted while learning the basics of database unit testing for SQL Server.
Installation:
- tSQLtmust be installed on the SQL Server database.
- Download the .zip file from its website.
- 
Unzip that file, there will be mainly 3 SQL files.
- SetClrEnabled.sql
- tSQLt.class.sql
- Example.sql
 
- First Enable CLR from the first file.
- Second, set the database trustworthy from the script given in given link. Link - https://tsqlt.org/user-guide/quick-start/#InstallToDevDb
- Third, run tSQLt.class.sql
- These 3 steps will install tSQLton your database.
Creating a Test Class
- A Test Class is basically a database schema with some special
   properties applied so that tSQLtcan recognize them as a test class.
- A Test Class can contain many Test Cases. (Note: A Test Case is nothing but a Stored Procedure.)
- To create a Test Class, we must run below command.
EXEC tSQLt.NewTestClass 'MyTestClass'; 
GOCreating a Test Case
- Creating a test case is easy. You only need to create a stored procedure on your test class schema.
- The procedure name must begin with "test".
Running Test Cases
- 
RunAll - RunAll executes all test cases on all test classes. 
- i.e EXEC tSQLt.RunAll;
 
- i.e 
- 
Run - Run is a versatile procedure for executing test cases. It can
   be called in three ways: 	
- With a test class name
- With a qualified test case name (i.e. the schema name and the test case name)
- With no parameter
 
- Creating a Test Class, Test Case & Running them all - https://tsqlt.org/130/creating-and-running-test-cases-in-tsqlt
Important Points:
- Every individual test cases are wrapped in a transaction which is rolled back at the end of the test.
- How Test Cases are executed by tSQLt - https://tsqlt.org/user-guide/test-creation-and-execution/