fix unique char counting in password validator
This commit is contained in:
parent
137e941814
commit
94e1105af7
|
@ -18,7 +18,7 @@ class PasswordValidator < ActiveModel::EachValidator
|
||||||
record.errors.add(attribute, :same_as_current)
|
record.errors.add(attribute, :same_as_current)
|
||||||
elsif SiteSetting.block_common_passwords && CommonPasswords.common_password?(value)
|
elsif SiteSetting.block_common_passwords && CommonPasswords.common_password?(value)
|
||||||
record.errors.add(attribute, :common)
|
record.errors.add(attribute, :common)
|
||||||
elsif value.chars.uniq.size < SiteSetting.password_unique_characters
|
elsif value.chars.inject(Hash.new(0)) { |h,char| h[char] += 1; h }.reject { |k,v| v > 1 }.size < SiteSetting.password_unique_characters
|
||||||
record.errors.add(attribute, :unique_characters)
|
record.errors.add(attribute, :unique_characters)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -93,19 +93,19 @@ describe PasswordValidator do
|
||||||
end
|
end
|
||||||
|
|
||||||
it "adds an error when there are too few unique characters" do
|
it "adds an error when there are too few unique characters" do
|
||||||
@password = "cheeeeeeeese"
|
@password = "aaaaaa5432"
|
||||||
validate
|
validate
|
||||||
expect(record.errors[:password]).to include(password_error_message(:unique_characters))
|
expect(record.errors[:password]).to include(password_error_message(:unique_characters))
|
||||||
end
|
end
|
||||||
|
|
||||||
it "doesn't add an error when there are enough unique characters" do
|
it "doesn't add an error when there are enough unique characters" do
|
||||||
@password = "spooooooorts"
|
@password = "aaaaa54321"
|
||||||
validate
|
validate
|
||||||
expect(record.errors[:password]).not_to be_present
|
expect(record.errors[:password]).not_to be_present
|
||||||
end
|
end
|
||||||
|
|
||||||
it "counts capital letters as unique" do
|
it "counts capital letters as different" do
|
||||||
@password = "cHeEeeeeesE"
|
@password = "aaaAaa5432"
|
||||||
validate
|
validate
|
||||||
expect(record.errors[:password]).not_to be_present
|
expect(record.errors[:password]).not_to be_present
|
||||||
end
|
end
|
||||||
|
|
|
@ -264,11 +264,11 @@ describe UsersController do
|
||||||
token = user.email_tokens.create(email: user.email).token
|
token = user.email_tokens.create(email: user.email).token
|
||||||
|
|
||||||
get :password_reset, token: token
|
get :password_reset, token: token
|
||||||
put :password_reset, token: token, password: 'hg9ow8yhg98o'
|
put :password_reset, token: token, password: 'hg9ow8yHG32O'
|
||||||
put :password_reset, token: token, password: 'test123123Asdfsdf'
|
put :password_reset, token: token, password: 'test123987AsdfXYZ'
|
||||||
|
|
||||||
user.reload
|
user.reload
|
||||||
expect(user.confirm_password?('hg9ow8yhg98o')).to eq(true)
|
expect(user.confirm_password?('hg9ow8yHG32O')).to eq(true)
|
||||||
|
|
||||||
# logged in now
|
# logged in now
|
||||||
expect(user.user_auth_tokens.count).to eq(1)
|
expect(user.user_auth_tokens.count).to eq(1)
|
||||||
|
|
Loading…
Reference in New Issue