3 INSERT INTO config.upgrade_log (version) VALUES ('0526'); --miker
5 CREATE TABLE config.db_patch_dependencies (
6 db_patch TEXT PRIMARY KEY,
11 CREATE OR REPLACE FUNCTION evergreen.array_overlap_check (/* field */) RETURNS TRIGGER AS $$
17 EXECUTE 'SELECT COUNT(*) FROM '|| TG_TABLE_SCHEMA ||'.'|| TG_TABLE_NAME ||' WHERE '|| fld ||' && ($1).'|| fld INTO cnt USING NEW;
19 RAISE EXCEPTION 'Cannot insert duplicate array into field % of table %', fld, TG_TABLE_SCHEMA ||'.'|| TG_TABLE_NAME;
25 CREATE TRIGGER no_overlapping_sups
26 BEFORE INSERT OR UPDATE ON config.db_patch_dependencies
27 FOR EACH ROW EXECUTE PROCEDURE evergreen.array_overlap_check ('supersedes');
29 CREATE TRIGGER no_overlapping_deps
30 BEFORE INSERT OR UPDATE ON config.db_patch_dependencies
31 FOR EACH ROW EXECUTE PROCEDURE evergreen.array_overlap_check ('deprecates');
33 ALTER TABLE config.upgrade_log
34 ADD COLUMN applied_to TEXT;
36 CREATE TYPE evergreen_patch AS (patch TEXT);
38 -- List applied db patches that are deprecated by (and block the application of) my_db_patch
39 CREATE OR REPLACE FUNCTION evergreen.upgrade_list_applied_deprecates ( my_db_patch TEXT ) RETURNS SETOF evergreen_patch AS $$
40 SELECT DISTINCT l.version
41 FROM config.upgrade_log l
42 JOIN config.db_patch_dependencies d ON (l.version::TEXT[] && d.deprecates)
46 -- List applied db patches that are superseded by (and block the application of) my_db_patch
47 CREATE OR REPLACE FUNCTION evergreen.upgrade_list_applied_supersedes ( my_db_patch TEXT ) RETURNS SETOF evergreen_patch AS $$
48 SELECT DISTINCT l.version
49 FROM config.upgrade_log l
50 JOIN config.db_patch_dependencies d ON (l.version::TEXT[] && d.supersedes)
54 -- List applied db patches that deprecates (and block the application of) my_db_patch
55 CREATE OR REPLACE FUNCTION evergreen.upgrade_list_applied_deprecated ( my_db_patch TEXT ) RETURNS TEXT AS $$
57 FROM config.db_patch_dependencies
58 WHERE ARRAY[$1]::TEXT[] && deprecates
61 -- List applied db patches that supersedes (and block the application of) my_db_patch
62 CREATE OR REPLACE FUNCTION evergreen.upgrade_list_applied_superseded ( my_db_patch TEXT ) RETURNS TEXT AS $$
64 FROM config.db_patch_dependencies
65 WHERE ARRAY[$1]::TEXT[] && supersedes
68 -- Make sure that no deprecated or superseded db patches are currently applied
69 CREATE OR REPLACE FUNCTION evergreen.upgrade_verify_no_dep_conflicts ( my_db_patch TEXT ) RETURNS BOOL AS $$
71 FROM (SELECT * FROM evergreen.upgrade_list_applied_deprecates( $1 )
73 SELECT * FROM evergreen.upgrade_list_applied_supersedes( $1 )
75 SELECT * FROM evergreen.upgrade_list_applied_deprecated( $1 )
77 SELECT * FROM evergreen.upgrade_list_applied_superseded( $1 ))x
80 -- Raise an exception if there are, in fact, dep/sup confilct
81 CREATE OR REPLACE FUNCTION evergreen.upgrade_deps_block_check ( my_db_patch TEXT, my_applied_to TEXT ) RETURNS BOOL AS $$
86 IF NOT evergreen.upgrade_verify_no_dep_conflicts( my_db_patch ) THEN
87 SELECT STRING_AGG(patch, ', ') INTO deprecates FROM evergreen.upgrade_list_applied_deprecates(my_db_patch);
88 SELECT STRING_AGG(patch, ', ') INTO supersedes FROM evergreen.upgrade_list_applied_supersedes(my_db_patch);
90 Upgrade script % can not be applied:
91 applied deprecated scripts %
92 applied superseded scripts %
98 evergreen.upgrade_list_applied_deprecated(my_db_patch),
99 evergreen.upgrade_list_applied_superseded(my_db_patch);
102 INSERT INTO config.upgrade_log (version, applied_to) VALUES (my_db_patch, my_applied_to);