0

这个 pgTAP 测试

BEGIN;

CREATE OR REPLACE FUNCTION test.testXUnitStyle() RETURNS SETOF TEXT AS $$
    SELECT ok(4 * 5 = 20, 'math should work in postgres');
$$ LANGUAGE plpgsql;

SELECT * FROM runtests('test'::name);

给了我这个语法错误:

prove --ext .sql t/pgtap-xunit.sql  --source pgTAP --pgtap-option dbname=test
psql:t/pgtap-xunit.sql:5: ERROR:  syntax error at or near "SELECT"
LINE 2:     SELECT ok(4 * 5 = 20, 'math should work in postgres');
            ^
t/pgtap-xunit.sql .. Dubious, test returned 3 (wstat 768, 0x300)
No subtests run

Test Summary Report
-------------------
t/pgtap-xunit.sql (Wstat: 768 Tests: 0 Failed: 0)
  Non-zero exit status: 3
  Parse errors: No plan found in TAP output
Files=1, Tests=0,  0 wallclock secs ( 0.03 usr +  0.00 sys =  0.03 CPU)
Result: FAIL

但如果我将它更改LANGUAGE plpgsqlLANGUAGE sql它就可以了。

我需要做什么才能以 plpgsql 运行测试?

4

1 回答 1

1

PL/PgSQL 具有不同的结构。你不能只是复制一个 SQL 函数体,声明它language plpgsql,然后期望它工作。

独立运行,你会看到:

regress=> CREATE SCHEMA test;
CREATE SCHEMA
regress=> CREATE OR REPLACE FUNCTION test.testXUnitStyle() RETURNS SETOF TEXT AS $$
    SELECT ok(4 * 5 = 20, 'math should work in postgres');
$$ LANGUAGE plpgsql;
ERROR:  syntax error at or near "SELECT"
LINE 2:     SELECT ok(4 * 5 = 20, 'math should work in postgres');
            ^

如果您阅读 Pl/PgSQL 手册,您会很快理解原因:PL/PgSQL 的整体结构为[DECLARE ...] BEGIN ... END;. 您还必须使用PERFORM来运行查询并丢弃结果,或者RETURN QUERY如果您希望返回结果。因此,您可以将 PL/PgSQL 中的代码重写为:

CREATE OR REPLACE FUNCTION test.testXUnitStyle() RETURNS SETOF TEXT AS $$
BEGIN
    RETURN QUERY SELECT ok(4 * 5 = 20, 'math should work in postgres');
END;
$$ LANGUAGE plpgsql;
于 2014-01-22T00:59:47.357 回答