FIX: validate presence of 'top menu' setting

This commit is contained in:
Arpit Jalan 2018-01-17 01:37:18 +05:30
parent d74f609921
commit 1208254961
3 changed files with 48 additions and 0 deletions

View File

@ -117,6 +117,7 @@ basic:
default: "latest|new|unread|top|categories"
regex: "latest"
regex_error: "site_settings.errors.must_include_latest"
validator: RegexPresenceValidator
choices:
- latest
- new

View File

@ -0,0 +1,16 @@
class RegexPresenceValidator
include RegexSettingValidation
def initialize(opts = {})
@opts = opts
initialize_regex_opts(opts)
end
def valid_value?(val)
val.present? && regex_match?(val)
end
def error_message
I18n.t(@regex_error)
end
end

View File

@ -0,0 +1,31 @@
require "rails_helper"
RSpec.describe RegexPresenceValidator do
subject { described_class.new(regex: 'latest', regex_error: 'site_settings.errors.must_include_latest') }
describe "#valid_value?" do
describe "when value is present" do
it "without regex match" do
expect(subject.valid_value?("categories|new")).to eq(false)
expect(subject.error_message).to eq(I18n.t(
"site_settings.errors.must_include_latest"
))
end
it "with regex match" do
expect(subject.valid_value?("latest|categories")).to eq(true)
end
end
describe "when value is empty" do
it "should not be valid" do
expect(subject.valid_value?("")).to eq(false)
expect(subject.error_message).to eq(I18n.t(
"site_settings.errors.must_include_latest"
))
end
end
end
end