2017-01-19 18:00:00 +01:00
|
|
|
--
|
|
|
|
-- SUBSCRIPTION
|
|
|
|
--
|
|
|
|
CREATE ROLE regress_subscription_user LOGIN SUPERUSER;
|
2017-03-08 04:44:59 +01:00
|
|
|
CREATE ROLE regress_subscription_user_dummy LOGIN NOSUPERUSER;
|
2017-01-19 18:00:00 +01:00
|
|
|
SET SESSION AUTHORIZATION 'regress_subscription_user';
|
|
|
|
-- fail - no publications
|
|
|
|
CREATE SUBSCRIPTION testsub CONNECTION 'foo';
|
|
|
|
ERROR: syntax error at or near ";"
|
|
|
|
LINE 1: CREATE SUBSCRIPTION testsub CONNECTION 'foo';
|
|
|
|
^
|
|
|
|
-- fail - no connection
|
|
|
|
CREATE SUBSCRIPTION testsub PUBLICATION foo;
|
|
|
|
ERROR: syntax error at or near "PUBLICATION"
|
|
|
|
LINE 1: CREATE SUBSCRIPTION testsub PUBLICATION foo;
|
|
|
|
^
|
|
|
|
set client_min_messages to error;
|
2017-03-04 05:25:34 +01:00
|
|
|
-- fail - cannot do CREATE SUBSCRIPTION CREATE SLOT inside transaction block
|
|
|
|
BEGIN;
|
|
|
|
CREATE SUBSCRIPTION testsub CONNECTION 'testconn' PUBLICATION testpub WITH (CREATE SLOT);
|
|
|
|
ERROR: CREATE SUBSCRIPTION ... CREATE SLOT cannot run inside a transaction block
|
|
|
|
COMMIT;
|
2017-01-19 18:00:00 +01:00
|
|
|
CREATE SUBSCRIPTION testsub CONNECTION 'testconn' PUBLICATION testpub;
|
|
|
|
ERROR: invalid connection string syntax: missing "=" after "testconn" in connection info string
|
|
|
|
|
|
|
|
CREATE SUBSCRIPTION testsub CONNECTION 'dbname=doesnotexist' PUBLICATION testpub WITH (DISABLED, NOCREATE SLOT);
|
|
|
|
reset client_min_messages;
|
|
|
|
\dRs+
|
|
|
|
List of subscriptions
|
|
|
|
Name | Owner | Enabled | Publication | Conninfo
|
|
|
|
---------+---------------------------+---------+-------------+---------------------
|
|
|
|
testsub | regress_subscription_user | f | {testpub} | dbname=doesnotexist
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
ALTER SUBSCRIPTION testsub SET PUBLICATION testpub2, testpub3;
|
|
|
|
\dRs
|
|
|
|
List of subscriptions
|
|
|
|
Name | Owner | Enabled | Publication
|
|
|
|
---------+---------------------------+---------+---------------------
|
|
|
|
testsub | regress_subscription_user | f | {testpub2,testpub3}
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
ALTER SUBSCRIPTION testsub CONNECTION 'dbname=doesnotexist2';
|
|
|
|
ALTER SUBSCRIPTION testsub SET PUBLICATION testpub, testpub1;
|
|
|
|
\dRs+
|
|
|
|
List of subscriptions
|
|
|
|
Name | Owner | Enabled | Publication | Conninfo
|
|
|
|
---------+---------------------------+---------+--------------------+----------------------
|
|
|
|
testsub | regress_subscription_user | f | {testpub,testpub1} | dbname=doesnotexist2
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
BEGIN;
|
|
|
|
ALTER SUBSCRIPTION testsub ENABLE;
|
|
|
|
\dRs
|
|
|
|
List of subscriptions
|
|
|
|
Name | Owner | Enabled | Publication
|
|
|
|
---------+---------------------------+---------+--------------------
|
|
|
|
testsub | regress_subscription_user | t | {testpub,testpub1}
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
ALTER SUBSCRIPTION testsub DISABLE;
|
|
|
|
\dRs
|
|
|
|
List of subscriptions
|
|
|
|
Name | Owner | Enabled | Publication
|
|
|
|
---------+---------------------------+---------+--------------------
|
|
|
|
testsub | regress_subscription_user | f | {testpub,testpub1}
|
|
|
|
(1 row)
|
|
|
|
|
|
|
|
COMMIT;
|
2017-03-08 04:44:59 +01:00
|
|
|
-- fail - must be owner of subscription
|
|
|
|
SET ROLE regress_subscription_user_dummy;
|
|
|
|
ALTER SUBSCRIPTION testsub RENAME TO testsub_dummy;
|
|
|
|
ERROR: must be owner of subscription testsub
|
|
|
|
RESET ROLE;
|
2017-03-03 16:47:04 +01:00
|
|
|
ALTER SUBSCRIPTION testsub RENAME TO testsub_foo;
|
|
|
|
\dRs
|
|
|
|
List of subscriptions
|
|
|
|
Name | Owner | Enabled | Publication
|
|
|
|
-------------+---------------------------+---------+--------------------
|
|
|
|
testsub_foo | regress_subscription_user | f | {testpub,testpub1}
|
|
|
|
(1 row)
|
|
|
|
|
2017-03-15 21:52:12 +01:00
|
|
|
-- rename back to keep the rest simple
|
|
|
|
ALTER SUBSCRIPTION testsub_foo RENAME TO testsub;
|
2017-03-04 05:25:34 +01:00
|
|
|
-- fail - cannot do DROP SUBSCRIPTION DROP SLOT inside transaction block
|
|
|
|
BEGIN;
|
|
|
|
DROP SUBSCRIPTION testsub DROP SLOT;
|
|
|
|
ERROR: DROP SUBSCRIPTION ... DROP SLOT cannot run inside a transaction block
|
|
|
|
COMMIT;
|
|
|
|
BEGIN;
|
2017-03-15 21:52:12 +01:00
|
|
|
DROP SUBSCRIPTION testsub NODROP SLOT;
|
2017-03-04 05:25:34 +01:00
|
|
|
COMMIT;
|
2017-01-19 18:00:00 +01:00
|
|
|
RESET SESSION AUTHORIZATION;
|
|
|
|
DROP ROLE regress_subscription_user;
|
2017-03-08 04:44:59 +01:00
|
|
|
DROP ROLE regress_subscription_user_dummy;
|