HiveBrain v1.2.0
Get Started
← Back to all entries
patternsqlMinor

Verify all Stored Procedures

Submitted by: @import:stackexchange-dba··
0
Viewed 0 times
storedallproceduresverify

Problem

How can I verify all stored procedures in a SQL Server database? I need to verify if all stored procedures still work, after some tables/views etc. have been deleted or changed.

Solution

No, there is no built-in way to do this within SQL Server. As Marian stated, you could recompile all of your procedures to be sure they're still valid, but this doesn't prove they'll still work (and don't forget that deferred name resolution makes this validation less than stellar anyway). However you can use other tools such as SQL Server Data Tools (SSDT) to help facilitate unit testing.

Just like changes to your application, if you change your schema, you need to test those changes. How automated you make your unit testing depends on the complexity of your schema, the consuming application(s), and the number of permutations possible for stored procedure outcomes (including both explicit input of different parameters or different parameter values, and implicit input such as time of day, state of the system, specific data at rest, etc.). You have to keep in mind that in some cases you will expect the stored procedure output to stay the same, but in others you will actually expect it to be different.

Some potentially helpful links (a couple culled from a question on SO geared to testing a single stored procedure):

  • TSQLUnit for unit tests



  • T.S.T. the T-SQL Test Tool

Context

StackExchange Database Administrators Q#31684, answer score: 5

Revisions (0)

No revisions yet.