Commit 014ac44299b51921e20c8ea7d7d41cd1a33a08d2
1 parent
b6aaca22
Exists in
master
and in
29 other branches
ActionItem703: removing www from email address
Showing
5 changed files
with
37 additions
and
3 deletions
Show diff stats
app/models/environment.rb
@@ -274,12 +274,12 @@ class Environment < ActiveRecord::Base | @@ -274,12 +274,12 @@ class Environment < ActiveRecord::Base | ||
274 | # | 274 | # |
275 | # If #force_www is true, adds 'www.' at the beginning of the hostname. If the | 275 | # If #force_www is true, adds 'www.' at the beginning of the hostname. If the |
276 | # environment has not associated domains, returns 'localhost'. | 276 | # environment has not associated domains, returns 'localhost'. |
277 | - def default_hostname | 277 | + def default_hostname(email_hostname = false) |
278 | if self.domains(true).empty? | 278 | if self.domains(true).empty? |
279 | 'localhost' | 279 | 'localhost' |
280 | else | 280 | else |
281 | domain = self.domains.find(:first, :order => 'id').name | 281 | domain = self.domains.find(:first, :order => 'id').name |
282 | - force_www ? ('www.' + domain) : domain | 282 | + email_hostname ? domain : (force_www ? ('www.' + domain) : domain) |
283 | end | 283 | end |
284 | end | 284 | end |
285 | 285 |
app/models/person.rb
@@ -98,7 +98,7 @@ class Person < Profile | @@ -98,7 +98,7 @@ class Person < Profile | ||
98 | 98 | ||
99 | def email_addresses | 99 | def email_addresses |
100 | # TODO for now, only one e-mail address | 100 | # TODO for now, only one e-mail address |
101 | - ['%s@%s' % [self.identifier, self.environment.default_hostname ] ] | 101 | + ['%s@%s' % [self.identifier, self.environment.default_hostname(true) ] ] |
102 | end | 102 | end |
103 | 103 | ||
104 | def display_info_to?(user) | 104 | def display_info_to?(user) |
test/functional/mailconf_controller_test.rb
@@ -74,6 +74,24 @@ class MailconfControllerTest < Test::Unit::TestCase | @@ -74,6 +74,24 @@ class MailconfControllerTest < Test::Unit::TestCase | ||
74 | assert_tag :tag => 'input', :attributes => { :name => 'user[enable_email]', :type => 'hidden', :value => '0' } | 74 | assert_tag :tag => 'input', :attributes => { :name => 'user[enable_email]', :type => 'hidden', :value => '0' } |
75 | end | 75 | end |
76 | 76 | ||
77 | + should 'not display www in email address when force_www=true' do | ||
78 | + login_as('ze') | ||
79 | + env = Environment.default | ||
80 | + env.force_www = true | ||
81 | + env.save! | ||
82 | + get :index, :profile => 'ze' | ||
83 | + assert_tag :tag => 'label', :attributes => { :for => 'user_enable_email' }, :content => /ze@colivre.net/ | ||
84 | + end | ||
85 | + | ||
86 | + should 'not display www in email address when force_www=false' do | ||
87 | + login_as('ze') | ||
88 | + env = Environment.default | ||
89 | + env.force_www = false | ||
90 | + env.save! | ||
91 | + get :index, :profile => 'ze' | ||
92 | + assert_tag :tag => 'label', :attributes => { :for => 'user_enable_email' }, :content => /ze@colivre.net/ | ||
93 | + end | ||
94 | + | ||
77 | should 'save mail enable/disable as true' do | 95 | should 'save mail enable/disable as true' do |
78 | login_as('ze') | 96 | login_as('ze') |
79 | post :save, :profile => 'ze', :user => { :enable_email => '1' } | 97 | post :save, :profile => 'ze', :user => { :enable_email => '1' } |
test/unit/environment_test.rb
@@ -178,6 +178,12 @@ class EnvironmentTest < Test::Unit::TestCase | @@ -178,6 +178,12 @@ class EnvironmentTest < Test::Unit::TestCase | ||
178 | assert_equal 'www.example.com', env.default_hostname | 178 | assert_equal 'www.example.com', env.default_hostname |
179 | end | 179 | end |
180 | 180 | ||
181 | + should 'not add www when requesting domain for email address' do | ||
182 | + env = Environment.create!(:name => 'test environment', :force_www => true) | ||
183 | + env.domains << Domain.create(:name => 'example.com') | ||
184 | + assert_equal 'example.com', env.default_hostname(true) | ||
185 | + end | ||
186 | + | ||
181 | should 'provide default top URL' do | 187 | should 'provide default top URL' do |
182 | env = Environment.new | 188 | env = Environment.new |
183 | env.expects(:default_hostname).returns('www.lalala.net') | 189 | env.expects(:default_hostname).returns('www.lalala.net') |
test/unit/person_test.rb
@@ -280,6 +280,16 @@ class PersonTest < Test::Unit::TestCase | @@ -280,6 +280,16 @@ class PersonTest < Test::Unit::TestCase | ||
280 | assert_equal ['testuser@somedomain.com'], person.email_addresses | 280 | assert_equal ['testuser@somedomain.com'], person.email_addresses |
281 | end | 281 | end |
282 | 282 | ||
283 | + should 'not show www in e-mail addresses when force_www=true' do | ||
284 | + env = Environment.create!(:name => 'sample env', :domains => [Domain.new(:name => 'somedomain.com')]) | ||
285 | + env.force_www = true | ||
286 | + env.save | ||
287 | + person = Person.new(:identifier => 'testuser') | ||
288 | + person.expects(:environment).returns(env) | ||
289 | + | ||
290 | + assert_equal ['testuser@somedomain.com'], person.email_addresses | ||
291 | + end | ||
292 | + | ||
283 | should 'show profile info to friend' do | 293 | should 'show profile info to friend' do |
284 | person = create_user('test_user').person | 294 | person = create_user('test_user').person |
285 | person.public_profile = false | 295 | person.public_profile = false |