|
| 1 | +# Tests for the EvalPlanQual mechanism involving foreign tables |
| 2 | + |
| 3 | +setup |
| 4 | +{ |
| 5 | + DO $d$ |
| 6 | + BEGIN |
| 7 | + EXECUTE $$CREATE SERVER loopback FOREIGN DATA WRAPPER postgres_fdw |
| 8 | + OPTIONS (dbname '$$||current_database()||$$', |
| 9 | + port '$$||current_setting('port')||$$' |
| 10 | + )$$; |
| 11 | + END; |
| 12 | + $d$; |
| 13 | + CREATE USER MAPPING FOR PUBLIC SERVER loopback; |
| 14 | + |
| 15 | + CREATE TABLE a (i int); |
| 16 | + CREATE TABLE b (i int); |
| 17 | + CREATE TABLE c (i int); |
| 18 | + CREATE FOREIGN TABLE fb (i int) SERVER loopback OPTIONS (table_name 'b'); |
| 19 | + CREATE FOREIGN TABLE fc (i int) SERVER loopback OPTIONS (table_name 'c'); |
| 20 | + |
| 21 | + INSERT INTO a VALUES (1); |
| 22 | + INSERT INTO b VALUES (1); |
| 23 | + INSERT INTO c VALUES (1); |
| 24 | +} |
| 25 | + |
| 26 | +teardown |
| 27 | +{ |
| 28 | + DROP TABLE a; |
| 29 | + DROP TABLE b; |
| 30 | + DROP TABLE c; |
| 31 | + DROP SERVER loopback CASCADE; |
| 32 | +} |
| 33 | + |
| 34 | +session s0 |
| 35 | +step s0_begin { BEGIN ISOLATION LEVEL READ COMMITTED; } |
| 36 | +step s0_update { UPDATE a SET i = i + 1; } |
| 37 | +step s0_commit { COMMIT; } |
| 38 | + |
| 39 | +session s1 |
| 40 | +step s1_begin { BEGIN ISOLATION LEVEL READ COMMITTED; } |
| 41 | +step s1_tuplock { |
| 42 | + -- Verify if the sub-select has a foreign-join plan |
| 43 | + EXPLAIN (VERBOSE, COSTS OFF) |
| 44 | + SELECT a.i, |
| 45 | + (SELECT 1 FROM fb, fc WHERE a.i = fb.i AND fb.i = fc.i) |
| 46 | + FROM a FOR UPDATE; |
| 47 | + SELECT a.i, |
| 48 | + (SELECT 1 FROM fb, fc WHERE a.i = fb.i AND fb.i = fc.i) |
| 49 | + FROM a FOR UPDATE; |
| 50 | +} |
| 51 | +step s1_commit { COMMIT; } |
| 52 | + |
| 53 | +# This test exercises EvalPlanQual with a SubLink sub-select (which should |
| 54 | +# be unaffected by any EPQ recheck behavior in the outer query). |
| 55 | +permutation s0_begin s0_update s1_begin s1_tuplock s0_commit s1_commit |
0 commit comments