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
47
48
49
50
|
# Check that cluster administration works as non-root if the invoker has
# sufficient permissions on directories.
use strict;
use lib 't';
use TestLib;
my $version = $MAJORS[-1];
my $oldversion = $MAJORS[0];
use Test::More tests => 22;
use PgCommon;
my $testuser = 'postgres';
# pg_createcluster and pg_ctlcluster
is ((exec_as $testuser, "pg_createcluster $version main --start"), 0,
"pg_createcluster succeeds as user $testuser with appropriate owner permissions");
like_program_out $testuser, 'pg_lsclusters -h', 0, qr/^$version\s+main.*online/m;
like_program_out 'postgres', 'psql -Atl', 0, qr/template1.*UTF8/;
# pg_dropcluster
is ((exec_as $testuser, "pg_dropcluster $version main --stop"), 0,
"pg_dropcluster succeeds as user $testuser with appropriate directory owner permissions");
# pg_upgradecluster
SKIP: {
skip 'Only one major version installed, skipping pg_upgradecluster tests', 8 if ($oldversion eq $version);
is ((exec_as $testuser, "pg_createcluster $oldversion main --start"), 0,
"pg_createcluster succeeds as user $testuser with appropriate group permissions");
my $outref;
is ((exec_as $testuser, "pg_upgradecluster -v $version $oldversion main", $outref, 0), 0,
"pg_upgradecluster succeeds as user $testuser");
like $$outref, qr/Starting upgraded cluster/, 'pg_upgradecluster reported cluster startup';
like $$outref, qr/Success. Please check/, 'pg_upgradecluster reported successful operation';
like_program_out $testuser, 'pg_lsclusters -h', 0,
qr/^$oldversion\s+main.*down.*\n^$version\s+main.*online/m;
# clean up
is ((exec_as $testuser, "pg_dropcluster $oldversion main"), 0);
is ((exec_as $testuser, "pg_dropcluster $version main --stop"), 0);
}
check_clean;
# vim: filetype=perl
|