summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2019-06-07 14:38:26 +0300
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2019-06-14 20:36:19 +0300
commit9259ab7decd385d24c35dd71ec2c2de1ca8208cc (patch)
tree6497e0db7a71ca71882b8c51b0dfa4d375fc8758
parent34b8231d49c880fc07f63c0b48f916a4f864e9c5 (diff)
downloadgitlab-ce-dz-remove-deprecated-group-routes.tar.gz
Remove deprecated group routesdz-remove-deprecated-group-routes
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
-rw-r--r--changelogs/unreleased/dz-remove-deprecated-group-routes.yml5
-rw-r--r--config/routes/group.rb8
-rw-r--r--spec/routing/group_routing_spec.rb113
3 files changed, 14 insertions, 112 deletions
diff --git a/changelogs/unreleased/dz-remove-deprecated-group-routes.yml b/changelogs/unreleased/dz-remove-deprecated-group-routes.yml
new file mode 100644
index 00000000000..bfa62c620d5
--- /dev/null
+++ b/changelogs/unreleased/dz-remove-deprecated-group-routes.yml
@@ -0,0 +1,5 @@
+---
+title: Remove deprecated group routes
+merge_request: 29351
+author:
+type: removed
diff --git a/config/routes/group.rb b/config/routes/group.rb
index b300fcb757f..2cf9eb82447 100644
--- a/config/routes/group.rb
+++ b/config/routes/group.rb
@@ -88,12 +88,4 @@ constraints(::Constraints::GroupUrlConstrainer.new) do
put '/', action: :update
delete '/', action: :destroy
end
-
- # Legacy paths should be defined last, so they would be ignored if routes with
- # one of the previously reserved words exist.
- scope(path: 'groups/*group_id') do
- Gitlab::Routing.redirect_legacy_paths(self, :labels, :milestones, :group_members,
- :edit, :issues, :merge_requests, :projects,
- :activity)
- end
end
diff --git a/spec/routing/group_routing_spec.rb b/spec/routing/group_routing_spec.rb
index 00ca394a50b..c6b101ae908 100644
--- a/spec/routing/group_routing_spec.rb
+++ b/spec/routing/group_routing_spec.rb
@@ -41,111 +41,16 @@ describe "Groups", "routing" do
expect(get("/groups/#{group_path}/-/milestones")).to route_to('groups/milestones#index', group_id: group_path)
end
- describe 'legacy redirection' do
- describe 'labels' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/labels", "/groups/complex.group-namegit/-/labels" do
- let(:resource) { create(:group, parent: group, path: 'labels') }
- end
-
- context 'when requesting JSON' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/labels.json", "/groups/complex.group-namegit/-/labels.json" do
- let(:resource) { create(:group, parent: group, path: 'labels') }
- end
- end
- end
-
- describe 'group_members' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/group_members", "/groups/complex.group-namegit/-/group_members" do
- let(:resource) { create(:group, parent: group, path: 'group_members') }
- end
- end
-
- describe 'avatar' do
- it 'routes to the avatars controller' do
- expect(delete("/groups/#{group_path}/-/avatar"))
- .to route_to(group_id: group_path,
- controller: 'groups/avatars',
- action: 'destroy')
- end
- end
-
- describe 'milestones' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/milestones", "/groups/complex.group-namegit/-/milestones" do
- let(:resource) { create(:group, parent: group, path: 'milestones') }
- end
-
- context 'nested routes' do
- include RSpec::Rails::RequestExampleGroup
-
- let(:milestone) { create(:milestone, group: group) }
-
- it 'redirects the nested routes' do
- request = get("/groups/#{group_path}/milestones/#{milestone.id}/merge_requests")
- expect(request).to redirect_to("/groups/#{group_path}/-/milestones/#{milestone.id}/merge_requests")
- end
- end
-
- context 'with a query string' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/milestones?hello=world", "/groups/complex.group-namegit/-/milestones?hello=world" do
- let(:resource) { create(:group, parent: group, path: 'milestones') }
- end
-
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/milestones?milestones=/milestones", "/groups/complex.group-namegit/-/milestones?milestones=/milestones" do
- let(:resource) { create(:group, parent: group, path: 'milestones') }
- end
- end
- end
-
- describe 'edit' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/edit", "/groups/complex.group-namegit/-/edit" do
- let(:resource) do
- pending('still rejected because of the wildcard reserved word')
- create(:group, parent: group, path: 'edit')
- end
- end
- end
-
- describe 'issues' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/issues", "/groups/complex.group-namegit/-/issues" do
- let(:resource) { create(:group, parent: group, path: 'issues') }
- end
- end
-
- describe 'merge_requests' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/merge_requests", "/groups/complex.group-namegit/-/merge_requests" do
- let(:resource) { create(:group, parent: group, path: 'merge_requests') }
- end
- end
-
- describe 'projects' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/projects", "/groups/complex.group-namegit/-/projects" do
- let(:resource) { create(:group, parent: group, path: 'projects') }
- end
- end
-
- describe 'activity' do
- it_behaves_like 'redirecting a legacy path', "/groups/complex.group-namegit/activity", "/groups/complex.group-namegit/-/activity" do
- let(:resource) { create(:group, parent: group, path: 'activity') }
- end
-
- it_behaves_like 'redirecting a legacy path', "/groups/activity/activity", "/groups/activity/-/activity" do
- let!(:parent) { create(:group, path: 'activity') }
- let(:resource) { create(:group, parent: parent, path: 'activity') }
- end
- end
-
- describe 'subgroup "boards"' do
- it 'shows group show page' do
- allow(Group).to receive(:find_by_full_path).with('gitlabhq/boards', any_args).and_return(true)
-
- expect(get('/groups/gitlabhq/boards')).to route_to('groups#show', id: 'gitlabhq/boards')
- end
+ it 'routes to the avatars controller' do
+ expect(delete("/groups/#{group_path}/-/avatar"))
+ .to route_to(group_id: group_path,
+ controller: 'groups/avatars',
+ action: 'destroy')
+ end
- it 'shows boards index page' do
- allow(Group).to receive(:find_by_full_path).with('gitlabhq', any_args).and_return(true)
+ it 'routes to the boards controller' do
+ allow(Group).to receive(:find_by_full_path).with('gitlabhq', any_args).and_return(true)
- expect(get('/groups/gitlabhq/-/boards')).to route_to('groups/boards#index', group_id: 'gitlabhq')
- end
- end
+ expect(get('/groups/gitlabhq/-/boards')).to route_to('groups/boards#index', group_id: 'gitlabhq')
end
end