我正在尝试设计一个单元测试,以确保消息大于一定数量的字符。我的代码是:
EXEC tSQLt.NewTestClass 'TestMarketingEnoughRows';
GO
CREATE OR ALTER PROCEDURE TestMarketing.[test that API_GetStandardDisclaimerText tests to make sure that the message is long enough]
AS
BEGIN
DROP TABLE IF EXISTS #Actual;
CREATE TABLE #Actual
(
Note NVARCHAR(MAX),
NoteWithHTML XML
);
INSERT #Actual
(
Note,
NoteWithHTML
)
EXEC Marketing.API_GetStandardDisclaimerText @Username = 'AnyValue', -- varchar(100)
@OneParagraphPerRow = 0; -- bit
SELECT LEN(Note),
LEN(CAST(NoteWithHTML AS NVARCHAR(MAX)))
FROM #Actual;
DECLARE @ArbitaryNumberOfCharacters INT = 15000;
DECLARE @ThisShouldEqualOne BIT =
(
SELECT CASE
WHEN LEN(Note) > @ArbitraryNumberOfCharacters
AND LEN(CAST(NoteWithHTML AS NVARCHAR(MAX))) > @ArbitraryNumberOfCharacters THEN
1
ELSE
0
END
FROM #Actual
);
EXEC tSQLt.AssertEquals @Expected = @ThisShouldEqualOne, -- sql_variant
@Actual = @ArbitaryNumberOfCharacters, -- sql_variant
@Message = N'test mctestyface'; -- nvarchar(max)
END;
GO
EXEC tSQLt.Run 'TestMarketingEnoughRows';
我收到以下错误:
消息 137,级别 15,状态 2,API_GetStandardDisclaimerText 测试以确保消息足够长的过程测试,第 25 行 [批处理开始第 3 行] 必须声明标量变量“@ArbitraryNumberOfCharacters”。消息 137,级别 15,状态 2,API_GetStandardDisclaimerText 测试以确保消息足够长的过程测试,第 33 行 [批处理开始第 3 行] 必须声明标量变量“@ThisShouldEqualOne”。
我很茫然,因为我已经声明了变量并且我似乎没有给出类型错误?stackoverflow 上有关此主题的其他帖子似乎对我没有帮助。