各种测试,特别是 src/bin
下的客户端程序测试,使用 Perl TAP 工具,并使用 Perl 测试程序 prove
运行。您可以通过设置 make
变量 PROVE_FLAGS
将命令行选项传递给 prove
,例如
make -C src/bin check PROVE_FLAGS='--timer'
有关更多信息,请参阅 prove
的手册页。
可以使用 make
变量 PROVE_TESTS
定义相对于调用 prove
以运行指定测试子集(而不是默认的 t/*.pl
)的 Makefile
的空格分隔路径列表。例如
make check PROVE_TESTS='t/001_test1.pl t/003_test3.pl'
TAP 测试需要 Perl 模块 IPC::Run
。此模块可从 CPAN 或操作系统包中获取。它们还需要 PostgreSQL 使用选项 --enable-tap-tests
进行配置。
一般来说,如果你说 make installcheck
,TAP 测试将在先前安装的安装树中测试可执行文件,或者如果你说 make check
,将从当前源代码构建新的本地安装树。在任何一种情况下,它们都将初始化一个本地实例(数据目录)并在其中临时运行一个服务器。其中一些测试运行多个服务器。因此,这些测试可能相当耗费资源。
重要的是要意识到,即使你说 make installcheck
,TAP 测试也会启动测试服务器;这与传统的非 TAP 测试基础设施不同,后者希望在这种情况下使用已经运行的测试服务器。一些 PostgreSQL 子目录同时包含传统风格和 TAP 风格的测试,这意味着 make installcheck
将产生来自临时服务器和已经运行的测试服务器的混合结果。
数据目录根据测试文件名命名,如果测试失败,将保留这些目录。如果设置了环境变量 PG_TEST_NOCLEAN
,无论测试状态如何,都将保留数据目录。例如,在运行 pg_dump 测试时,无论测试结果如何,都保留数据目录
PG_TEST_NOCLEAN=1 make -C src/bin/pg_dump check
此环境变量还可防止删除测试的临时目录。
测试套件中的许多操作使用 180 秒超时,在速度较慢的主机上可能导致负载引起的超时。将环境变量 PG_TEST_TIMEOUT_DEFAULT
设置为较高的数字将更改默认值以避免这种情况。