Add the :migration metadata, and don't use factories in FixWronglyRenamedRoutes spec
Signed-off-by: Rémy Coutable <remy@rymai.me>
This commit is contained in:
parent
5392568e1e
commit
941485ef75
1 changed files with 37 additions and 24 deletions
|
@ -1,29 +1,35 @@
|
|||
require 'spec_helper'
|
||||
require Rails.root.join('db', 'post_migrate', '20170518231126_fix_wrongly_renamed_routes.rb')
|
||||
|
||||
describe FixWronglyRenamedRoutes, truncate: true do
|
||||
describe FixWronglyRenamedRoutes, :truncate, :migration do
|
||||
let(:subject) { described_class.new }
|
||||
let(:namespaces_table) { table(:namespaces) }
|
||||
let(:projects_table) { table(:projects) }
|
||||
let(:routes_table) { table(:routes) }
|
||||
let(:broken_namespace) do
|
||||
namespace = create(:group, name: 'apiis')
|
||||
namespace.route.update_attribute(:path, 'api0is')
|
||||
namespace
|
||||
namespaces_table.create!(name: 'apiis', path: 'apiis').tap do |namespace|
|
||||
routes_table.create!(source_type: 'Namespace', source_id: namespace.id, name: 'api0is', path: 'api0is')
|
||||
end
|
||||
end
|
||||
let(:broken_namespace_route) { routes_table.where(source_type: 'Namespace', source_id: broken_namespace.id).first }
|
||||
|
||||
describe '#wrongly_renamed' do
|
||||
it "includes routes that have names that don't match their namespace" do
|
||||
broken_namespace
|
||||
_other_namespace = create(:group, name: 'api0')
|
||||
other_namespace = namespaces_table.create!(name: 'api0', path: 'api0')
|
||||
routes_table.create!(source_type: 'Namespace', source_id: other_namespace.id, name: 'api0', path: 'api0')
|
||||
|
||||
expect(subject.wrongly_renamed.map(&:id))
|
||||
.to contain_exactly(broken_namespace.route.id)
|
||||
.to contain_exactly(broken_namespace_route.id)
|
||||
end
|
||||
end
|
||||
|
||||
describe "#paths_and_corrections" do
|
||||
it 'finds the wrong path and gets the correction from the namespace' do
|
||||
broken_namespace
|
||||
namespace = create(:group, name: 'uploads-test')
|
||||
namespace.route.update_attribute(:path, 'uploads0-test')
|
||||
namespaces_table.create!(name: 'uploads-test', path: 'uploads-test').tap do |namespace|
|
||||
routes_table.create!(source_type: 'Namespace', source_id: namespace.id, name: 'uploads-test', path: 'uploads0-test')
|
||||
end
|
||||
|
||||
expected_result = [
|
||||
{ 'namespace_path' => 'apiis', 'path' => 'api0is' },
|
||||
|
@ -36,38 +42,45 @@ describe FixWronglyRenamedRoutes, truncate: true do
|
|||
|
||||
describe '#routes_in_namespace_query' do
|
||||
it 'includes only the required routes' do
|
||||
namespace = create(:group, path: 'hello')
|
||||
project = create(:project, namespace: namespace)
|
||||
_other_namespace = create(:group, path: 'hello0')
|
||||
namespace = namespaces_table.create!(name: 'hello', path: 'hello')
|
||||
namespace_route = routes_table.create!(source_type: 'Namespace', source_id: namespace.id, name: 'hello', path: 'hello')
|
||||
project = projects_table.new(name: 'my-project', path: 'my-project', namespace_id: namespace.id).tap do |project|
|
||||
project.save!(validate: false)
|
||||
end
|
||||
routes_table.create!(source_type: 'Project', source_id: project.id, name: 'my-project', path: 'hello/my-project')
|
||||
_other_namespace = namespaces_table.create!(name: 'hello0', path: 'hello0')
|
||||
|
||||
result = Route.where(subject.routes_in_namespace_query('hello'))
|
||||
result = routes_table.where(subject.routes_in_namespace_query('hello'))
|
||||
project_route = routes_table.where(source_type: 'Project', source_id: project.id).first
|
||||
|
||||
expect(result).to contain_exactly(namespace.route, project.route)
|
||||
expect(result).to contain_exactly(namespace_route, project_route)
|
||||
end
|
||||
end
|
||||
|
||||
describe '#up' do
|
||||
let(:broken_project) do
|
||||
project = create(:project, namespace: broken_namespace, path: 'broken-project')
|
||||
project.route.update_attribute(:path, 'api0is/broken-project')
|
||||
project
|
||||
end
|
||||
|
||||
it 'renames incorrectly named routes' do
|
||||
broken_project
|
||||
broken_project =
|
||||
projects_table.new(name: 'broken-project', path: 'broken-project', namespace_id: broken_namespace.id).tap do |project|
|
||||
project.save!(validate: false)
|
||||
routes_table.create!(source_type: 'Project', source_id: project.id, name: 'broken-project', path: 'api0is/broken-project')
|
||||
end
|
||||
|
||||
subject.up
|
||||
|
||||
expect(broken_project.route.reload.path).to eq('apiis/broken-project')
|
||||
expect(broken_namespace.route.reload.path).to eq('apiis')
|
||||
broken_project_route = routes_table.where(source_type: 'Project', source_id: broken_project.id).first
|
||||
|
||||
expect(broken_project_route.path).to eq('apiis/broken-project')
|
||||
expect(broken_namespace_route.reload.path).to eq('apiis')
|
||||
end
|
||||
|
||||
it "doesn't touch namespaces that look like something that should be renamed" do
|
||||
namespace = create(:group, path: 'api0')
|
||||
namespaces_table.create!(name: 'apiis', path: 'apiis')
|
||||
namespace = namespaces_table.create!(name: 'hello', path: 'api0')
|
||||
namespace_route = routes_table.create!(source_type: 'Namespace', source_id: namespace.id, name: 'hello', path: 'api0')
|
||||
|
||||
subject.up
|
||||
|
||||
expect(namespace.route.reload.path).to eq('api0')
|
||||
expect(namespace_route.reload.path).to eq('api0')
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue