summaryrefslogtreecommitdiff
path: root/src/bin/pg_test_timing/t/001_basic.pl
blob: 9912acc052a29f37d949ed8c442a2deef6ff0e7f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46

# Copyright (c) 2021-2025, PostgreSQL Global Development Group

use strict;
use warnings FATAL => 'all';

use PostgreSQL::Test::Utils;
use Test::More;

#########################################
# Basic checks

program_help_ok('pg_test_timing');
program_version_ok('pg_test_timing');
program_options_handling_ok('pg_test_timing');

#########################################
# Test invalid option combinations

command_fails_like(
	[ 'pg_test_timing', '--duration' => 'a' ],
	qr/\Qpg_test_timing: invalid argument for option --duration\E/,
	'pg_test_timing: invalid argument for option --duration');
command_fails_like(
	[ 'pg_test_timing', '--duration' => '0' ],
	qr/\Qpg_test_timing: --duration must be in range 1..4294967295\E/,
	'pg_test_timing: --duration must be in range');
command_fails_like(
	[ 'pg_test_timing', '--cutoff' => '101' ],
	qr/\Qpg_test_timing: --cutoff must be in range 0..100\E/,
	'pg_test_timing: --cutoff must be in range');

#########################################
# We obviously can't check for specific output, but we can
# do a simple run and make sure it produces something.

command_like(
	[ 'pg_test_timing', '--duration' => '1' ],
	qr/
\QTesting timing overhead for 1 second.\E.*
\QHistogram of timing durations:\E.*
\QObserved timing durations up to 99.9900%:\E
/sx,
	'pg_test_timing: sanity check');

done_testing();