discourse/spec/lib/validators/username_setting_validator_...

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

43 lines
1.3 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
RSpec.describe UsernameSettingValidator do
2014-06-11 14:42:41 -04:00
describe '#valid_value?' do
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
context "with regex support" do
fab!(:darthvader) { Fabricate(:user, username: 'darthvader') }
fab!(:luke) { Fabricate(:user, username: 'luke') }
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