Commit b839e74f authored by Adam Hegyi's avatar Adam Hegyi

Merge branch 'ab/schema-cleanup' into 'master'

Remove schema compatibility fixes for PG 9.6

See merge request gitlab-org/gitlab!33840
parents 607fabd8 44355f91
SET search_path=public; SET search_path=public;
CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;
CREATE EXTENSION IF NOT EXISTS pg_trgm WITH SCHEMA public; CREATE EXTENSION IF NOT EXISTS pg_trgm WITH SCHEMA public;
CREATE TABLE public.abuse_reports ( CREATE TABLE public.abuse_reports (
......
...@@ -12,27 +12,15 @@ module Gitlab ...@@ -12,27 +12,15 @@ module Gitlab
def clean(io) def clean(io)
structure = original_schema.dup structure = original_schema.dup
# Postgres compat fix for PG 9.6 (which doesn't support (AS datatype) syntax for sequences)
structure.gsub!(/CREATE SEQUENCE [^.]+\.\S+\n(\s+AS integer\n)/) { |m| m.gsub(Regexp.last_match[1], '') }
# Also a PG 9.6 compatibility fix, see below.
structure.gsub!(/^CREATE EXTENSION IF NOT EXISTS plpgsql.*/, '')
structure.gsub!(/^COMMENT ON EXTENSION.*/, '')
# Remove noise # Remove noise
structure.gsub!(/^COMMENT ON EXTENSION.*/, '')
structure.gsub!(/^SET.+/, '') structure.gsub!(/^SET.+/, '')
structure.gsub!(/^SELECT pg_catalog\.set_config\('search_path'.+/, '') structure.gsub!(/^SELECT pg_catalog\.set_config\('search_path'.+/, '')
structure.gsub!(/^--.*/, "\n") structure.gsub!(/^--.*/, "\n")
structure.gsub!(/\n{3,}/, "\n\n")
io << "SET search_path=public;\n\n" structure = "SET search_path=public;\n" + structure
# Adding plpgsql explicitly is again a compatibility fix for PG 9.6 structure.gsub!(/\n{3,}/, "\n\n")
# In more recent versions of pg_dump, the extension isn't explicitly dumped anymore.
# We use PG 9.6 still on CI and for schema checks - here this is still the case.
io << <<~SQL.strip
CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;
SQL
io << structure io << structure
......
...@@ -48,7 +48,6 @@ CREATE TABLE public.abuse_reports ( ...@@ -48,7 +48,6 @@ CREATE TABLE public.abuse_reports (
-- --
CREATE SEQUENCE public.abuse_reports_id_seq CREATE SEQUENCE public.abuse_reports_id_seq
AS integer
START WITH 1 START WITH 1
INCREMENT BY 1 INCREMENT BY 1
NO MINVALUE NO MINVALUE
......
SET search_path=public; SET search_path=public;
CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;
CREATE EXTENSION IF NOT EXISTS pg_trgm WITH SCHEMA public; CREATE EXTENSION IF NOT EXISTS pg_trgm WITH SCHEMA public;
CREATE TABLE public.abuse_reports ( CREATE TABLE public.abuse_reports (
......
...@@ -15,10 +15,6 @@ describe Gitlab::Database::SchemaCleaner do ...@@ -15,10 +15,6 @@ describe Gitlab::Database::SchemaCleaner do
expect(subject).not_to include('COMMENT ON EXTENSION') expect(subject).not_to include('COMMENT ON EXTENSION')
end end
it 'includes the plpgsql extension' do
expect(subject).to include('CREATE EXTENSION IF NOT EXISTS plpgsql WITH SCHEMA pg_catalog;')
end
it 'sets the search_path' do it 'sets the search_path' do
expect(subject.split("\n").first).to eq('SET search_path=public;') expect(subject.split("\n").first).to eq('SET search_path=public;')
end end
......
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