2019-04-29 20:27:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-10-11 05:41:23 -04:00
|
|
|
require 'rails_helper'
|
2013-02-05 14:16:51 -05:00
|
|
|
require 'email'
|
|
|
|
|
|
|
|
describe Email do
|
|
|
|
|
2013-04-14 20:20:33 -04:00
|
|
|
describe "is_valid?" do
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2015-05-27 00:12:10 -04:00
|
|
|
it 'treats a nil as invalid' do
|
|
|
|
expect(Email.is_valid?(nil)).to eq(false)
|
|
|
|
end
|
|
|
|
|
2013-04-14 20:20:33 -04:00
|
|
|
it 'treats a good email as valid' do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(Email.is_valid?('sam@sam.com')).to eq(true)
|
2013-04-14 20:20:33 -04:00
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2013-04-14 20:20:33 -04:00
|
|
|
it 'treats a bad email as invalid' do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(Email.is_valid?('sam@sam')).to eq(false)
|
2013-04-14 20:20:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'allows museum tld' do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(Email.is_valid?('sam@nic.museum')).to eq(true)
|
2013-04-14 20:20:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not think a word is an email' do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(Email.is_valid?('sam')).to eq(false)
|
2013-04-14 20:20:33 -04:00
|
|
|
end
|
2013-02-25 11:42:20 -05:00
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
2013-02-25 11:42:20 -05:00
|
|
|
|
2013-04-14 20:20:33 -04:00
|
|
|
describe "downcase" do
|
|
|
|
|
2014-07-14 10:16:24 -04:00
|
|
|
it 'downcases local and host part' do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(Email.downcase('SAM@GMAIL.COM')).to eq('sam@gmail.com')
|
|
|
|
expect(Email.downcase('sam@GMAIL.COM')).to eq('sam@gmail.com')
|
2013-04-14 20:20:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'leaves invalid emails untouched' do
|
2015-01-09 11:34:37 -05:00
|
|
|
expect(Email.downcase('SAM@GMAILCOM')).to eq('SAM@GMAILCOM')
|
|
|
|
expect(Email.downcase('samGMAIL.COM')).to eq('samGMAIL.COM')
|
|
|
|
expect(Email.downcase('sam@GM@AIL.COM')).to eq('sam@GM@AIL.COM')
|
2013-04-14 20:20:33 -04:00
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
2013-04-14 20:20:33 -04:00
|
|
|
|
2021-03-18 13:09:23 -04:00
|
|
|
describe "obfuscate" do
|
|
|
|
|
|
|
|
it 'correctly obfuscates emails' do
|
|
|
|
expect(Email.obfuscate('a@b.com')).to eq('*@*.com')
|
|
|
|
expect(Email.obfuscate('test@test.co.uk')).to eq('t***@t***.**.uk')
|
|
|
|
expect(Email.obfuscate('simple@example.com')).to eq('s****e@e*****e.com')
|
|
|
|
expect(Email.obfuscate('very.common@example.com')).to eq('v*********n@e*****e.com')
|
|
|
|
expect(Email.obfuscate('disposable.style.email.with+symbol@example.com')).to eq('d********************************l@e*****e.com')
|
|
|
|
expect(Email.obfuscate('other.email-with-hyphen@example.com')).to eq('o*********************n@e*****e.com')
|
|
|
|
expect(Email.obfuscate('fully-qualified-domain@example.com')).to eq('f********************n@e*****e.com')
|
|
|
|
expect(Email.obfuscate('user.name+tag+sorting@example.com')).to eq('u*******************g@e*****e.com')
|
|
|
|
expect(Email.obfuscate('x@example.com')).to eq('*@e*****e.com')
|
|
|
|
expect(Email.obfuscate('example-indeed@strange-example.com')).to eq('e************d@s*************e.com')
|
|
|
|
expect(Email.obfuscate('example@s.example')).to eq('e*****e@*.example')
|
|
|
|
expect(Email.obfuscate('mailhost!username@example.org')).to eq('m***************e@e*****e.org')
|
|
|
|
expect(Email.obfuscate('user%example.com@example.org')).to eq('u**************m@e*****e.org')
|
|
|
|
expect(Email.obfuscate('user-@example.org')).to eq('u***-@e*****e.org')
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2021-04-27 01:48:51 -04:00
|
|
|
describe "message_id_rfc_format" do
|
|
|
|
|
|
|
|
it "returns message ID in RFC format" do
|
|
|
|
expect(Email.message_id_rfc_format("test@test")).to eq("<test@test>")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns input if already in RFC format" do
|
|
|
|
expect(Email.message_id_rfc_format("<test@test>")).to eq("<test@test>")
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "message_id_clean" do
|
|
|
|
|
|
|
|
it "returns message ID if in RFC format" do
|
|
|
|
expect(Email.message_id_clean("<test@test>")).to eq("test@test")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns input if a clean message ID is not in RFC format" do
|
|
|
|
message_id = "<" + "@" * 50
|
|
|
|
expect(Email.message_id_clean(message_id)).to eq(message_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|