mirror of
https://github.com/postgres/postgres.git
synced 2025-06-11 20:28:21 +03:00
Add a test case for a316a3bc
a316a3bc
fixed the code in build_simpl_rel() that propagates
RelOptInfo.userid from parent to child rels so that it works
correctly for the child rels of a UNION ALL subquery rel, though
no tests were added in that commit. So do so here.
As noted in the discussion, coming up with a test case in the core
regression suite for this fix has turned out to be tricky, so the
test case is added to the postgres_fdw's suite instead.
postgresGetForeignRelSize()'s use of user mapping for the user
specified in RelOptInfo.userid makes it relatively easier to craft
a test case around.
Discussion: https://postgr.es/m/CA%2BHiwqH91GaFNXcXbLAM9L%3DzBwUmSyv699Mtv3i1_xtk9Xec_A%40mail.gmail.com
Backpatch-through: 16
This commit is contained in:
@ -714,6 +714,29 @@ SELECT t1.c1, t2.c2 FROM v4 t1 LEFT JOIN ft5 t2 ON (t1.c1 = t2.c1) ORDER BY t1.c
|
||||
SELECT t1.c1, t2.c2 FROM v4 t1 LEFT JOIN ft5 t2 ON (t1.c1 = t2.c1) ORDER BY t1.c1, t2.c1 OFFSET 10 LIMIT 10;
|
||||
ALTER VIEW v4 OWNER TO regress_view_owner;
|
||||
|
||||
-- ====================================================================
|
||||
-- Check that userid to use when querying the remote table is correctly
|
||||
-- propagated into foreign rels present in subqueries under an UNION ALL
|
||||
-- ====================================================================
|
||||
CREATE ROLE regress_view_owner_another;
|
||||
ALTER VIEW v4 OWNER TO regress_view_owner_another;
|
||||
GRANT SELECT ON ft4 TO regress_view_owner_another;
|
||||
ALTER FOREIGN TABLE ft4 OPTIONS (ADD use_remote_estimate 'true');
|
||||
-- The following should query the remote backing table of ft4 as user
|
||||
-- regress_view_owner_another, the view owner, though it fails as expected
|
||||
-- due to the lack of a user mapping for that user.
|
||||
EXPLAIN (VERBOSE, COSTS OFF) SELECT * FROM v4;
|
||||
-- Likewise, but with the query under an UNION ALL
|
||||
EXPLAIN (VERBOSE, COSTS OFF) SELECT * FROM (SELECT * FROM v4 UNION ALL SELECT * FROM v4);
|
||||
-- Should not get that error once a user mapping is created
|
||||
CREATE USER MAPPING FOR regress_view_owner_another SERVER loopback OPTIONS (password_required 'false');
|
||||
EXPLAIN (VERBOSE, COSTS OFF) SELECT * FROM v4;
|
||||
EXPLAIN (VERBOSE, COSTS OFF) SELECT * FROM (SELECT * FROM v4 UNION ALL SELECT * FROM v4);
|
||||
DROP USER MAPPING FOR regress_view_owner_another SERVER loopback;
|
||||
DROP OWNED BY regress_view_owner_another;
|
||||
DROP ROLE regress_view_owner_another;
|
||||
ALTER FOREIGN TABLE ft4 OPTIONS (SET use_remote_estimate 'false');
|
||||
|
||||
-- cleanup
|
||||
DROP OWNED BY regress_view_owner;
|
||||
DROP ROLE regress_view_owner;
|
||||
|
Reference in New Issue
Block a user