2016-11-03 12:29:30 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe GroupUrlConstrainer do
|
2017-08-17 22:00:37 +05:30
|
|
|
let!(:group) { create(:group, path: 'gitlab') }
|
2016-11-03 12:29:30 +05:30
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
describe '#matches?' do
|
|
|
|
context 'valid request' do
|
|
|
|
let(:request) { build_request(group.path) }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'valid request for nested group' do
|
|
|
|
let!(:nested_group) { create(:group, path: 'nested', parent: group) }
|
|
|
|
let!(:request) { build_request('gitlab/nested') }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'valid request for nested group with reserved top level name' do
|
|
|
|
let!(:nested_group) { create(:group, path: 'api', parent: group) }
|
|
|
|
let!(:request) { build_request('gitlab/api') }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'invalid request' do
|
|
|
|
let(:request) { build_request('foo') }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_falsey }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the request matches a redirect route' do
|
|
|
|
context 'for a root group' do
|
|
|
|
let!(:redirect_route) { group.redirect_routes.create!(path: 'gitlabb') }
|
|
|
|
|
|
|
|
context 'and is a GET request' do
|
|
|
|
let(:request) { build_request(redirect_route.path) }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'and is NOT a GET request' do
|
|
|
|
let(:request) { build_request(redirect_route.path, 'POST') }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_falsey }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'for a nested group' do
|
|
|
|
let!(:nested_group) { create(:group, path: 'nested', parent: group) }
|
|
|
|
let!(:redirect_route) { nested_group.redirect_routes.create!(path: 'gitlabb/nested') }
|
|
|
|
let(:request) { build_request(redirect_route.path) }
|
|
|
|
|
|
|
|
it { expect(subject.matches?(request)).to be_truthy }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def build_request(path, method = 'GET')
|
|
|
|
double(:request,
|
|
|
|
'get?': (method == 'GET'),
|
|
|
|
params: { id: path })
|
2016-11-03 12:29:30 +05:30
|
|
|
end
|
|
|
|
end
|