summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/bin/pg_dump/pg_dump_sort.c13
-rw-r--r--src/test/regress/expected/privileges.out5
-rw-r--r--src/test/regress/sql/privileges.sql7
3 files changed, 25 insertions, 0 deletions
diff --git a/src/bin/pg_dump/pg_dump_sort.c b/src/bin/pg_dump/pg_dump_sort.c
index 09799c98f66..90c493731e6 100644
--- a/src/bin/pg_dump/pg_dump_sort.c
+++ b/src/bin/pg_dump/pg_dump_sort.c
@@ -414,6 +414,19 @@ DOTypeNameCompare(const void *p1, const void *p2)
return cmpval;
}
}
+ else if (obj1->objType == DO_DEFAULT_ACL)
+ {
+ DefaultACLInfo *daclobj1 = *(DefaultACLInfo *const *) p1;
+ DefaultACLInfo *daclobj2 = *(DefaultACLInfo *const *) p2;
+
+ /*
+ * Sort by defaclrole, per pg_default_acl_role_nsp_obj_index. The
+ * (namespace, name) match (defaclnamespace, defaclobjtype).
+ */
+ cmpval = strcmp(daclobj1->defaclrole, daclobj2->defaclrole);
+ if (cmpval != 0)
+ return cmpval;
+ }
else if (obj1->objType == DO_PUBLICATION_REL)
{
PublicationRelInfo *probj1 = *(PublicationRelInfo *const *) p1;
diff --git a/src/test/regress/expected/privileges.out b/src/test/regress/expected/privileges.out
index bf8eb24c2a3..1e301270aea 100644
--- a/src/test/regress/expected/privileges.out
+++ b/src/test/regress/expected/privileges.out
@@ -2634,6 +2634,11 @@ DROP USER regress_priv_user6;
DROP USER regress_priv_user7;
DROP USER regress_priv_user8; -- does not exist
ERROR: role "regress_priv_user8" does not exist
+-- leave some default ACLs for pg_upgrade's dump-restore test input.
+ALTER DEFAULT PRIVILEGES FOR ROLE pg_signal_backend
+ REVOKE INSERT ON TABLES FROM pg_signal_backend;
+ALTER DEFAULT PRIVILEGES FOR ROLE pg_read_all_settings
+ REVOKE INSERT ON TABLES FROM pg_read_all_settings;
-- permissions with LOCK TABLE
CREATE USER regress_locktable_user;
CREATE TABLE lock_table (a int);
diff --git a/src/test/regress/sql/privileges.sql b/src/test/regress/sql/privileges.sql
index a54756a8b58..9a6b70b5b73 100644
--- a/src/test/regress/sql/privileges.sql
+++ b/src/test/regress/sql/privileges.sql
@@ -1661,6 +1661,13 @@ DROP USER regress_priv_user7;
DROP USER regress_priv_user8; -- does not exist
+-- leave some default ACLs for pg_upgrade's dump-restore test input.
+ALTER DEFAULT PRIVILEGES FOR ROLE pg_signal_backend
+ REVOKE INSERT ON TABLES FROM pg_signal_backend;
+ALTER DEFAULT PRIVILEGES FOR ROLE pg_read_all_settings
+ REVOKE INSERT ON TABLES FROM pg_read_all_settings;
+
+
-- permissions with LOCK TABLE
CREATE USER regress_locktable_user;
CREATE TABLE lock_table (a int);