2019-04-29 20:27:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2014-06-11 14:42:41 -04:00
|
|
|
describe UsernameSettingValidator do
|
|
|
|
describe '#valid_value?' do
|
2014-06-12 18:03:03 -04:00
|
|
|
subject(:validator) { described_class.new }
|
|
|
|
|
2014-06-11 14:42:41 -04:00
|
|
|
it "returns true for blank values" do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(validator.valid_value?('')).to eq(true)
|
|
|
|
expect(validator.valid_value?(nil)).to eq(true)
|
2014-06-11 14:42:41 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if value matches an existing user's username" do
|
|
|
|
Fabricate(:user, username: 'vader')
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(validator.valid_value?('vader')).to eq(true)
|
2014-06-11 14:42:41 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if value does not match a user's username" do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(validator.valid_value?('no way')).to eq(false)
|
2014-06-11 14:42:41 -04:00
|
|
|
end
|
2017-10-04 15:08:51 -04:00
|
|
|
|
|
|
|
context "regex support" do
|
2019-05-06 23:12:20 -04:00
|
|
|
fab!(:darthvader) { Fabricate(:user, username: 'darthvader') }
|
|
|
|
fab!(:luke) { Fabricate(:user, username: 'luke') }
|
2017-10-04 15:08:51 -04:00
|
|
|
|
|
|
|
it "returns false if regex doesn't match" do
|
|
|
|
v = described_class.new(regex: 'darth')
|
|
|
|
expect(v.valid_value?('luke')).to eq(false)
|
|
|
|
expect(v.valid_value?('vader')).to eq(false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns true if regex matches" do
|
|
|
|
v = described_class.new(regex: 'darth')
|
|
|
|
expect(v.valid_value?('darthvader')).to eq(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns false if regex matches but username doesn't match a user" do
|
|
|
|
v = described_class.new(regex: 'darth')
|
|
|
|
expect(v.valid_value?('darthmaul')).to eq(false)
|
|
|
|
end
|
|
|
|
end
|
2014-06-11 14:42:41 -04:00
|
|
|
end
|
|
|
|
end
|