Commit 8c161553 authored by Alvaro Herrera's avatar Alvaro Herrera

For REASSIGN OWNED for foreign user mappings

As reported in bug #13809 by Alexander Ashurkov, the code for REASSIGN
OWNED hadn't gotten word about user mappings.  Deal with them in the
same way default ACLs do, which is to ignore them altogether; they are
handled just fine by DROP OWNED.  The other foreign object cases are
already handled correctly by both commands.

Also add a REASSIGN OWNED statement to foreign_data test to exercise the
foreign data objects.  (The changes are just before the "cleanup" phase,
so it shouldn't remove any existing live test.)

Reported by Alexander Ashurkov, then independently by Jaime Casanova.
parent dccf8e9e
...@@ -43,6 +43,7 @@ ...@@ -43,6 +43,7 @@
#include "catalog/pg_ts_config.h" #include "catalog/pg_ts_config.h"
#include "catalog/pg_ts_dict.h" #include "catalog/pg_ts_dict.h"
#include "catalog/pg_type.h" #include "catalog/pg_type.h"
#include "catalog/pg_user_mapping.h"
#include "commands/alter.h" #include "commands/alter.h"
#include "commands/dbcommands.h" #include "commands/dbcommands.h"
#include "commands/collationcmds.h" #include "commands/collationcmds.h"
...@@ -1389,6 +1390,10 @@ shdepReassignOwned(List *roleids, Oid newrole) ...@@ -1389,6 +1390,10 @@ shdepReassignOwned(List *roleids, Oid newrole)
*/ */
break; break;
case UserMappingRelationId:
/* ditto */
break;
case ForeignServerRelationId: case ForeignServerRelationId:
AlterForeignServerOwner_oid(sdepForm->objid, newrole); AlterForeignServerOwner_oid(sdepForm->objid, newrole);
break; break;
......
...@@ -1743,6 +1743,14 @@ ERROR: foreign table "no_table" does not exist ...@@ -1743,6 +1743,14 @@ ERROR: foreign table "no_table" does not exist
DROP FOREIGN TABLE IF EXISTS no_table; DROP FOREIGN TABLE IF EXISTS no_table;
NOTICE: foreign table "no_table" does not exist, skipping NOTICE: foreign table "no_table" does not exist, skipping
DROP FOREIGN TABLE foreign_schema.foreign_table_1; DROP FOREIGN TABLE foreign_schema.foreign_table_1;
-- REASSIGN OWNED/DROP OWNED of foreign objects
REASSIGN OWNED BY regress_test_role TO regress_test_role2;
DROP OWNED BY regress_test_role2;
ERROR: cannot drop desired object(s) because other objects depend on them
DETAIL: user mapping for regress_test_role on server s5 depends on server s5
HINT: Use DROP ... CASCADE to drop the dependent objects too.
DROP OWNED BY regress_test_role2 CASCADE;
NOTICE: drop cascades to user mapping for regress_test_role on server s5
-- Cleanup -- Cleanup
DROP SCHEMA foreign_schema CASCADE; DROP SCHEMA foreign_schema CASCADE;
DROP ROLE regress_test_role; -- ERROR DROP ROLE regress_test_role; -- ERROR
...@@ -1750,14 +1758,8 @@ ERROR: role "regress_test_role" cannot be dropped because some objects depend o ...@@ -1750,14 +1758,8 @@ ERROR: role "regress_test_role" cannot be dropped because some objects depend o
DETAIL: privileges for server s4 DETAIL: privileges for server s4
privileges for foreign-data wrapper foo privileges for foreign-data wrapper foo
owner of user mapping for regress_test_role on server s6 owner of user mapping for regress_test_role on server s6
owner of user mapping for regress_test_role on server s5
owner of server s5
owner of server t2
DROP SERVER s5 CASCADE;
NOTICE: drop cascades to user mapping for regress_test_role on server s5
DROP SERVER t1 CASCADE; DROP SERVER t1 CASCADE;
NOTICE: drop cascades to user mapping for public on server t1 NOTICE: drop cascades to user mapping for public on server t1
DROP SERVER t2;
DROP USER MAPPING FOR regress_test_role SERVER s6; DROP USER MAPPING FOR regress_test_role SERVER s6;
-- This test causes some order dependent cascade detail output, -- This test causes some order dependent cascade detail output,
-- so switch to terse mode for it. -- so switch to terse mode for it.
......
...@@ -679,12 +679,15 @@ DROP FOREIGN TABLE no_table; -- ERROR ...@@ -679,12 +679,15 @@ DROP FOREIGN TABLE no_table; -- ERROR
DROP FOREIGN TABLE IF EXISTS no_table; DROP FOREIGN TABLE IF EXISTS no_table;
DROP FOREIGN TABLE foreign_schema.foreign_table_1; DROP FOREIGN TABLE foreign_schema.foreign_table_1;
-- REASSIGN OWNED/DROP OWNED of foreign objects
REASSIGN OWNED BY regress_test_role TO regress_test_role2;
DROP OWNED BY regress_test_role2;
DROP OWNED BY regress_test_role2 CASCADE;
-- Cleanup -- Cleanup
DROP SCHEMA foreign_schema CASCADE; DROP SCHEMA foreign_schema CASCADE;
DROP ROLE regress_test_role; -- ERROR DROP ROLE regress_test_role; -- ERROR
DROP SERVER s5 CASCADE;
DROP SERVER t1 CASCADE; DROP SERVER t1 CASCADE;
DROP SERVER t2;
DROP USER MAPPING FOR regress_test_role SERVER s6; DROP USER MAPPING FOR regress_test_role SERVER s6;
-- This test causes some order dependent cascade detail output, -- This test causes some order dependent cascade detail output,
-- so switch to terse mode for it. -- so switch to terse mode for it.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment