mirror of
https://github.com/discourse/discourse.git
synced 2025-02-22 12:17:12 +00:00
* Remove outdated option
04078317ba
* Use the non-globally exposed RSpec syntax
https://github.com/rspec/rspec-core/pull/2803
* Use the non-globally exposed RSpec syntax, cont
https://github.com/rspec/rspec-core/pull/2803
* Comply to strict predicate matchers
See:
- https://github.com/rspec/rspec-expectations/pull/1195
- https://github.com/rspec/rspec-expectations/pull/1196
- https://github.com/rspec/rspec-expectations/pull/1277
25 lines
665 B
Ruby
25 lines
665 B
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe RegexSettingValidator do
|
|
describe '#valid_value?' do
|
|
subject(:validator) { described_class.new }
|
|
|
|
it "returns true for blank values" do
|
|
expect(validator.valid_value?('')).to eq(true)
|
|
expect(validator.valid_value?(nil)).to eq(true)
|
|
end
|
|
|
|
it "return false for invalid regex" do
|
|
expect(validator.valid_value?('(()')).to eq(false)
|
|
end
|
|
|
|
it "returns false for regex with dangerous matches" do
|
|
expect(validator.valid_value?('(.)*')).to eq(false)
|
|
end
|
|
|
|
it "returns true for safe regex" do
|
|
expect(validator.valid_value?('\d{3}-\d{4}')).to eq(true)
|
|
end
|
|
end
|
|
end
|