|
23 | 23 | $node->safe_psql("postgres",
|
24 | 24 | "CREATE EXTENSION pg_prewarm;\n"
|
25 | 25 | . "CREATE TABLE test(c1 int);\n"
|
26 |
| - . "INSERT INTO test SELECT generate_series(1, 100);"); |
| 26 | + . "INSERT INTO test SELECT generate_series(1, 100);\n" |
| 27 | + . "CREATE INDEX test_idx ON test(c1);\n" |
| 28 | + . "CREATE ROLE test_user LOGIN;"); |
27 | 29 |
|
28 | 30 | # test read mode
|
29 | 31 | my $result =
|
|
42 | 44 | or $stderr =~ qr/prefetch is not supported by this build/),
|
43 | 45 | 'prefetch mode succeeded');
|
44 | 46 |
|
| 47 | +# test_user should be unable to prewarm table/index without privileges |
| 48 | +($cmdret, $stdout, $stderr) = |
| 49 | + $node->psql( |
| 50 | + "postgres", "SELECT pg_prewarm('test');", |
| 51 | + extra_params => [ '--username' => 'test_user' ]); |
| 52 | +ok($stderr =~ /permission denied for table test/, 'pg_prewarm failed as expected'); |
| 53 | +($cmdret, $stdout, $stderr) = |
| 54 | + $node->psql( |
| 55 | + "postgres", "SELECT pg_prewarm('test_idx');", |
| 56 | + extra_params => [ '--username' => 'test_user' ]); |
| 57 | +ok($stderr =~ /permission denied for index test_idx/, 'pg_prewarm failed as expected'); |
| 58 | + |
| 59 | +# test_user should be able to prewarm table/index with privileges |
| 60 | +$node->safe_psql("postgres", "GRANT SELECT ON test TO test_user;"); |
| 61 | +$result = |
| 62 | + $node->safe_psql( |
| 63 | + "postgres", "SELECT pg_prewarm('test');", |
| 64 | + extra_params => [ '--username' => 'test_user' ]); |
| 65 | +like($result, qr/^[1-9][0-9]*$/, 'pg_prewarm succeeded as expected'); |
| 66 | +$result = |
| 67 | + $node->safe_psql( |
| 68 | + "postgres", "SELECT pg_prewarm('test_idx');", |
| 69 | + extra_params => [ '--username' => 'test_user' ]); |
| 70 | +like($result, qr/^[1-9][0-9]*$/, 'pg_prewarm succeeded as expected'); |
| 71 | + |
45 | 72 | # test autoprewarm_dump_now()
|
46 | 73 | $result = $node->safe_psql("postgres", "SELECT autoprewarm_dump_now();");
|
47 | 74 | like($result, qr/^[1-9][0-9]*$/, 'autoprewarm_dump_now succeeded');
|
|
0 commit comments