2019-10-15 05:06:09 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-05-11 17:50:55 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
require 'rake'
|
|
|
|
|
|
|
|
describe 'gitlab:db namespace rake task' do
|
|
|
|
before :all do
|
|
|
|
Rake.application.rake_require 'active_record/railties/databases'
|
|
|
|
Rake.application.rake_require 'tasks/seed_fu'
|
|
|
|
Rake.application.rake_require 'tasks/gitlab/db'
|
|
|
|
|
|
|
|
# empty task as env is already loaded
|
|
|
|
Rake::Task.define_task :environment
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
# Stub out db tasks
|
|
|
|
allow(Rake::Task['db:migrate']).to receive(:invoke).and_return(true)
|
2020-03-22 11:09:49 -04:00
|
|
|
allow(Rake::Task['db:structure:load']).to receive(:invoke).and_return(true)
|
2016-05-11 17:50:55 -04:00
|
|
|
allow(Rake::Task['db:seed_fu']).to receive(:invoke).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'configure' do
|
2016-08-01 11:00:44 -04:00
|
|
|
it 'invokes db:migrate when schema has already been loaded' do
|
2018-06-27 17:09:06 -04:00
|
|
|
allow(ActiveRecord::Base.connection).to receive(:tables).and_return(%w[table1 table2])
|
2016-05-11 17:50:55 -04:00
|
|
|
expect(Rake::Task['db:migrate']).to receive(:invoke)
|
2020-03-22 11:09:49 -04:00
|
|
|
expect(Rake::Task['db:structure:load']).not_to receive(:invoke)
|
2016-05-11 17:50:55 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
2016-08-01 11:00:44 -04:00
|
|
|
it 'invokes db:shema:load and db:seed_fu when schema is not loaded' do
|
2016-05-15 10:59:49 -04:00
|
|
|
allow(ActiveRecord::Base.connection).to receive(:tables).and_return([])
|
2020-03-22 11:09:49 -04:00
|
|
|
expect(Rake::Task['db:structure:load']).to receive(:invoke)
|
2016-05-11 17:50:55 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).to receive(:invoke)
|
|
|
|
expect(Rake::Task['db:migrate']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
2018-06-27 16:42:22 -04:00
|
|
|
it 'invokes db:shema:load and db:seed_fu when there is only a single table present' do
|
|
|
|
allow(ActiveRecord::Base.connection).to receive(:tables).and_return(['default'])
|
2020-03-22 11:09:49 -04:00
|
|
|
expect(Rake::Task['db:structure:load']).to receive(:invoke)
|
2018-06-27 16:42:22 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).to receive(:invoke)
|
|
|
|
expect(Rake::Task['db:migrate']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.not_to raise_error
|
|
|
|
end
|
|
|
|
|
2016-08-01 11:00:44 -04:00
|
|
|
it 'does not invoke any other rake tasks during an error' do
|
2016-05-11 17:50:55 -04:00
|
|
|
allow(ActiveRecord::Base).to receive(:connection).and_raise(RuntimeError, 'error')
|
|
|
|
expect(Rake::Task['db:migrate']).not_to receive(:invoke)
|
2020-03-22 11:09:49 -04:00
|
|
|
expect(Rake::Task['db:structure:load']).not_to receive(:invoke)
|
2016-05-11 17:50:55 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.to raise_error(RuntimeError, 'error')
|
|
|
|
# unstub connection so that the database cleaner still works
|
|
|
|
allow(ActiveRecord::Base).to receive(:connection).and_call_original
|
|
|
|
end
|
|
|
|
|
2016-08-01 11:00:44 -04:00
|
|
|
it 'does not invoke seed after a failed schema_load' do
|
2016-05-15 10:59:49 -04:00
|
|
|
allow(ActiveRecord::Base.connection).to receive(:tables).and_return([])
|
2020-03-22 11:09:49 -04:00
|
|
|
allow(Rake::Task['db:structure:load']).to receive(:invoke).and_raise(RuntimeError, 'error')
|
|
|
|
expect(Rake::Task['db:structure:load']).to receive(:invoke)
|
2016-05-11 17:50:55 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).not_to receive(:invoke)
|
|
|
|
expect(Rake::Task['db:migrate']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.to raise_error(RuntimeError, 'error')
|
|
|
|
end
|
2018-09-11 21:41:14 -04:00
|
|
|
|
|
|
|
context 'SKIP_POST_DEPLOYMENT_MIGRATIONS environment variable set' do
|
2018-09-12 18:55:26 -04:00
|
|
|
let(:rails_paths) { { 'db' => ['db'], 'db/migrate' => ['db/migrate'] } }
|
2018-09-11 21:41:14 -04:00
|
|
|
|
|
|
|
before do
|
|
|
|
allow(ENV).to receive(:[]).and_call_original
|
|
|
|
allow(ENV).to receive(:[]).with('SKIP_POST_DEPLOYMENT_MIGRATIONS').and_return true
|
|
|
|
|
2018-09-12 18:55:26 -04:00
|
|
|
# Our environment has already been loaded, so we need to pretend like post_migrations were not
|
|
|
|
allow(Rails.application.config).to receive(:paths).and_return(rails_paths)
|
|
|
|
allow(ActiveRecord::Migrator).to receive(:migrations_paths).and_return(rails_paths['db/migrate'].dup)
|
2018-09-11 21:41:14 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'adds post deployment migrations before schema load if the schema is not already loaded' do
|
|
|
|
allow(ActiveRecord::Base.connection).to receive(:tables).and_return([])
|
2018-09-12 18:55:26 -04:00
|
|
|
expect(Gitlab::Database).to receive(:add_post_migrate_path_to_rails).and_call_original
|
2020-03-22 11:09:49 -04:00
|
|
|
expect(Rake::Task['db:structure:load']).to receive(:invoke)
|
2018-09-11 21:41:14 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).to receive(:invoke)
|
|
|
|
expect(Rake::Task['db:migrate']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.not_to raise_error
|
2018-09-12 18:55:26 -04:00
|
|
|
expect(rails_paths['db/migrate'].include?(File.join(Rails.root, 'db', 'post_migrate'))).to be(true)
|
|
|
|
end
|
2018-09-11 21:41:14 -04:00
|
|
|
|
2018-09-12 18:55:26 -04:00
|
|
|
it 'ignores post deployment migrations when schema has already been loaded' do
|
|
|
|
allow(ActiveRecord::Base.connection).to receive(:tables).and_return(%w[table1 table2])
|
|
|
|
expect(Rake::Task['db:migrate']).to receive(:invoke)
|
|
|
|
expect(Gitlab::Database).not_to receive(:add_post_migrate_path_to_rails)
|
2020-03-22 11:09:49 -04:00
|
|
|
expect(Rake::Task['db:structure:load']).not_to receive(:invoke)
|
2018-09-12 18:55:26 -04:00
|
|
|
expect(Rake::Task['db:seed_fu']).not_to receive(:invoke)
|
|
|
|
expect { run_rake_task('gitlab:db:configure') }.not_to raise_error
|
|
|
|
expect(rails_paths['db/migrate'].include?(File.join(Rails.root, 'db', 'post_migrate'))).to be(false)
|
2018-09-11 21:41:14 -04:00
|
|
|
end
|
|
|
|
end
|
2016-05-11 17:50:55 -04:00
|
|
|
end
|
|
|
|
|
2020-04-09 08:09:24 -04:00
|
|
|
describe 'clean_structure_sql' do
|
|
|
|
let_it_be(:clean_rake_task) { 'gitlab:db:clean_structure_sql' }
|
|
|
|
let_it_be(:test_task_name) { 'gitlab:db:_test_multiple_structure_cleans' }
|
|
|
|
let_it_be(:structure_file) { 'db/structure.sql' }
|
|
|
|
let_it_be(:input) { 'this is structure data' }
|
|
|
|
let(:output) { StringIO.new }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(File).to receive(:read).with(structure_file).and_return(input)
|
|
|
|
allow(File).to receive(:open).with(structure_file, any_args).and_yield(output)
|
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
Rake::Task[test_task_name].clear if Rake::Task.task_defined?(test_task_name)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can be executed multiple times within another rake task' do
|
|
|
|
Rake::Task.define_task(test_task_name => :environment) do
|
|
|
|
expect_next_instance_of(Gitlab::Database::SchemaCleaner) do |cleaner|
|
|
|
|
expect(cleaner).to receive(:clean).with(output)
|
|
|
|
end
|
|
|
|
Rake::Task[clean_rake_task].invoke
|
|
|
|
|
|
|
|
expect_next_instance_of(Gitlab::Database::SchemaCleaner) do |cleaner|
|
|
|
|
expect(cleaner).to receive(:clean).with(output)
|
|
|
|
end
|
|
|
|
Rake::Task[clean_rake_task].invoke
|
|
|
|
end
|
|
|
|
|
|
|
|
run_rake_task(test_task_name)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-05-11 17:50:55 -04:00
|
|
|
def run_rake_task(task_name)
|
|
|
|
Rake::Task[task_name].reenable
|
|
|
|
Rake.application.invoke_task task_name
|
|
|
|
end
|
|
|
|
end
|