2019-10-12 21:52:04 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
RSpec.shared_examples 'url validator examples' do |schemes|
|
2019-10-12 21:52:04 +05:30
|
|
|
describe '#validate' do
|
|
|
|
let(:validator) { described_class.new(attributes: [:link_url], **options) }
|
|
|
|
let(:badge) { build(:badge, link_url: 'http://www.example.com') }
|
2018-11-08 19:23:39 +05:30
|
|
|
|
2019-10-12 21:52:04 +05:30
|
|
|
subject { validator.validate(badge) }
|
2018-11-08 19:23:39 +05:30
|
|
|
|
|
|
|
context 'with no options' do
|
|
|
|
let(:options) { {} }
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
it "allows #{schemes.join(',')} schemes by default" do
|
|
|
|
expect(validator.options[:schemes]).to eq schemes
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it 'checks that the url structure is valid' do
|
|
|
|
badge.link_url = "#{badge.link_url}:invalid_port"
|
|
|
|
|
|
|
|
subject
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
expect(badge.errors).to be_present
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
context 'with schemes' do
|
|
|
|
let(:options) { { schemes: %w(http) } }
|
2018-11-08 19:23:39 +05:30
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
it 'allows urls with the defined schemes' do
|
2018-11-08 19:23:39 +05:30
|
|
|
subject
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
expect(badge.errors).to be_empty
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
it 'add error if the url scheme does not match the selected ones' do
|
2018-11-08 19:23:39 +05:30
|
|
|
badge.link_url = 'https://www.example.com'
|
|
|
|
|
|
|
|
subject
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
expect(badge.errors).to be_present
|
2018-11-08 19:23:39 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2019-10-12 21:52:04 +05:30
|
|
|
|
|
|
|
RSpec.shared_examples 'public url validator examples' do |setting|
|
|
|
|
let(:validator) { described_class.new(attributes: [:link_url]) }
|
|
|
|
let(:badge) { build(:badge, link_url: 'http://www.example.com') }
|
|
|
|
|
|
|
|
subject { validator.validate(badge) }
|
|
|
|
|
|
|
|
context 'by default' do
|
|
|
|
it 'blocks urls pointing to localhost' do
|
|
|
|
badge.link_url = 'https://127.0.0.1'
|
|
|
|
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(badge.errors).to be_present
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'blocks urls pointing to the local network' do
|
|
|
|
badge.link_url = 'https://192.168.1.1'
|
|
|
|
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(badge.errors).to be_present
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when local requests are allowed' do
|
|
|
|
let!(:settings) { create(:application_setting) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_application_setting(setting)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not block urls pointing to localhost' do
|
|
|
|
badge.link_url = 'https://127.0.0.1'
|
|
|
|
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(badge.errors).not_to be_present
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not block urls pointing to the local network' do
|
|
|
|
badge.link_url = 'https://192.168.1.1'
|
|
|
|
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(badge.errors).not_to be_present
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|