493d437e79
* Remove outdated option https://github.com/rspec/rspec-core/commit/04078317ba6577699d06cf4dccf014254dcde7a6 * 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
|