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