|
6 | 6 | import os
|
7 | 7 | import unittest
|
8 | 8 | import signal
|
| 9 | +import time |
9 | 10 |
|
10 | 11 | from .helpers.ptrack_helpers import ProbackupTest, ProbackupException
|
11 | 12 | from testgres import StartNodeException
|
|
20 | 21 | skip_test = True
|
21 | 22 |
|
22 | 23 |
|
| 24 | +class SimpleAuthTest(ProbackupTest, unittest.TestCase): |
| 25 | + |
| 26 | + # @unittest.skip("skip") |
| 27 | + def test_backup_via_unpriviledged_user(self): |
| 28 | + """ |
| 29 | + Make node, create unpriviledged user, try to |
| 30 | + run a backups without EXECUTE rights on |
| 31 | + certain functions |
| 32 | + """ |
| 33 | + fname = self.id().split('.')[3] |
| 34 | + node = self.make_simple_node( |
| 35 | + base_dir="{0}/{1}/node".format(module_name, fname), |
| 36 | + set_replication=True, |
| 37 | + initdb_params=['--data-checksums'], |
| 38 | + pg_options={'wal_level': 'replica', 'max_wal_senders': '2'} |
| 39 | + ) |
| 40 | + backup_dir = os.path.join(self.tmp_path, module_name, fname, 'backup') |
| 41 | + self.init_pb(backup_dir) |
| 42 | + self.add_instance(backup_dir, 'node', node) |
| 43 | + self.set_archiving(backup_dir, 'node', node) |
| 44 | + node.start() |
| 45 | + |
| 46 | + node.safe_psql("postgres", "CREATE ROLE backup with LOGIN") |
| 47 | + |
| 48 | + try: |
| 49 | + self.backup_node( |
| 50 | + backup_dir, 'node', node, options=['-U', 'backup']) |
| 51 | + self.assertEqual( |
| 52 | + 1, 0, |
| 53 | + "Expecting Error due to missing grant on EXECUTE.") |
| 54 | + except ProbackupException as e: |
| 55 | + self.assertIn( |
| 56 | + "ERROR: query failed: ERROR: permission denied " |
| 57 | + "for function pg_start_backup", e.message, |
| 58 | + '\n Unexpected Error Message: {0}\n CMD: {1}'.format( |
| 59 | + repr(e.message), self.cmd)) |
| 60 | + |
| 61 | + node.safe_psql( |
| 62 | + "postgres", |
| 63 | + "GRANT EXECUTE ON FUNCTION" |
| 64 | + " pg_start_backup(text, boolean, boolean) TO backup;") |
| 65 | + |
| 66 | + time.sleep(1) |
| 67 | + try: |
| 68 | + self.backup_node( |
| 69 | + backup_dir, 'node', node, options=['-U', 'backup']) |
| 70 | + self.assertEqual( |
| 71 | + 1, 0, |
| 72 | + "Expecting Error due to missing grant on EXECUTE.") |
| 73 | + except ProbackupException as e: |
| 74 | + self.assertIn( |
| 75 | + "ERROR: query failed: ERROR: permission denied for function " |
| 76 | + "pg_create_restore_point\nquery was: " |
| 77 | + "SELECT pg_catalog.pg_create_restore_point($1)", e.message, |
| 78 | + '\n Unexpected Error Message: {0}\n CMD: {1}'.format( |
| 79 | + repr(e.message), self.cmd)) |
| 80 | + |
| 81 | + node.safe_psql( |
| 82 | + "postgres", |
| 83 | + "GRANT EXECUTE ON FUNCTION" |
| 84 | + " pg_create_restore_point(text) TO backup;") |
| 85 | + |
| 86 | + time.sleep(1) |
| 87 | + |
| 88 | + try: |
| 89 | + self.backup_node( |
| 90 | + backup_dir, 'node', node, options=['-U', 'backup']) |
| 91 | + self.assertEqual( |
| 92 | + 1, 0, |
| 93 | + "Expecting Error due to missing grant on EXECUTE.") |
| 94 | + except ProbackupException as e: |
| 95 | + self.assertIn( |
| 96 | + "ERROR: query failed: ERROR: permission denied " |
| 97 | + "for function pg_stop_backup", e.message, |
| 98 | + '\n Unexpected Error Message: {0}\n CMD: {1}'.format( |
| 99 | + repr(e.message), self.cmd)) |
| 100 | + |
| 101 | + if self.get_version(node) < self.version_to_num('10.0'): |
| 102 | + node.safe_psql( |
| 103 | + "postgres", |
| 104 | + "GRANT EXECUTE ON FUNCTION pg_stop_backup(boolean) TO backup") |
| 105 | + else: |
| 106 | + node.safe_psql( |
| 107 | + "postgres", |
| 108 | + "GRANT EXECUTE ON FUNCTION " |
| 109 | + "pg_stop_backup(boolean, boolean) TO backup") |
| 110 | + |
| 111 | + self.backup_node( |
| 112 | + backup_dir, 'node', node, options=['-U', 'backup']) |
| 113 | + |
| 114 | + # Clean after yourself |
| 115 | + self.del_test_dir(module_name, fname) |
| 116 | + |
| 117 | + |
23 | 118 | class AuthTest(unittest.TestCase):
|
24 | 119 | pb = None
|
25 | 120 | node = None
|
|
0 commit comments