Use with_settings for temporary changes to settings
This commit is contained in:
parent
e83f0bd131
commit
b9c5df4dad
4 changed files with 17 additions and 43 deletions
|
@ -677,7 +677,7 @@ class DiaryEntriesControllerTest < ActionDispatch::IntegrationTest
|
||||||
get diary_rss_path
|
get diary_rss_path
|
||||||
assert_select "rss>channel>item", :count => 2
|
assert_select "rss>channel>item", :count => 2
|
||||||
|
|
||||||
with_diary_feed_delay(6) do
|
with_settings(:diary_feed_delay => 6) do
|
||||||
get diary_rss_path
|
get diary_rss_path
|
||||||
assert_select "rss>channel>item", :count => 1
|
assert_select "rss>channel>item", :count => 1
|
||||||
end
|
end
|
||||||
|
@ -1003,13 +1003,4 @@ class DiaryEntriesControllerTest < ActionDispatch::IntegrationTest
|
||||||
assert_select "a[href=?]", "/user/#{ERB::Util.u(entry.user.display_name)}/diary/#{entry.id}"
|
assert_select "a[href=?]", "/user/#{ERB::Util.u(entry.user.display_name)}/diary/#{entry.id}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def with_diary_feed_delay(value)
|
|
||||||
diary_feed_delay = Settings.diary_feed_delay
|
|
||||||
Settings.diary_feed_delay = value
|
|
||||||
|
|
||||||
yield
|
|
||||||
|
|
||||||
Settings.diary_feed_delay = diary_feed_delay
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -214,7 +214,7 @@ class MessagesControllerTest < ActionDispatch::IntegrationTest
|
||||||
# Check that sending a message fails when the message limit is hit
|
# Check that sending a message fails when the message limit is hit
|
||||||
assert_no_difference "ActionMailer::Base.deliveries.size" do
|
assert_no_difference "ActionMailer::Base.deliveries.size" do
|
||||||
assert_no_difference "Message.count" do
|
assert_no_difference "Message.count" do
|
||||||
with_message_limit(0) do
|
with_settings(:max_messages_per_hour => 0) do
|
||||||
perform_enqueued_jobs do
|
perform_enqueued_jobs do
|
||||||
post messages_path(:display_name => recipient_user.display_name,
|
post messages_path(:display_name => recipient_user.display_name,
|
||||||
:message => { :title => "Test Message", :body => "Test message body" })
|
:message => { :title => "Test Message", :body => "Test message body" })
|
||||||
|
@ -472,15 +472,4 @@ class MessagesControllerTest < ActionDispatch::IntegrationTest
|
||||||
assert_response :not_found
|
assert_response :not_found
|
||||||
assert_template "no_such_message"
|
assert_template "no_such_message"
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def with_message_limit(value)
|
|
||||||
max_messages_per_hour = Settings.max_messages_per_hour
|
|
||||||
Settings.max_messages_per_hour = value
|
|
||||||
|
|
||||||
yield
|
|
||||||
|
|
||||||
Settings.max_messages_per_hour = max_messages_per_hour
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -235,22 +235,19 @@ class RelationTest < ActiveSupport::TestCase
|
||||||
# the maximum number of members in a relation.
|
# the maximum number of members in a relation.
|
||||||
def test_max_members_per_relation_limit
|
def test_max_members_per_relation_limit
|
||||||
# Speed up unit test by using a small relation member limit
|
# Speed up unit test by using a small relation member limit
|
||||||
default_limit = Settings.max_number_of_relation_members
|
with_settings(:max_number_of_relation_members => 20) do
|
||||||
Settings.max_number_of_relation_members = 20
|
user = create(:user)
|
||||||
|
changeset = create(:changeset, :user => user)
|
||||||
|
relation = create(:relation, :changeset => changeset)
|
||||||
|
node = create(:node, :longitude => 116, :latitude => 39)
|
||||||
|
# Create relation which exceeds the relation member limit by one
|
||||||
|
0.upto(Settings.max_number_of_relation_members) do |i|
|
||||||
|
create(:relation_member, :relation => relation, :member_type => "Node", :member_id => node.id, :sequence_id => i)
|
||||||
|
end
|
||||||
|
|
||||||
user = create(:user)
|
assert_raise OSM::APITooManyRelationMembersError do
|
||||||
changeset = create(:changeset, :user => user)
|
relation.create_with_history user
|
||||||
relation = create(:relation, :changeset => changeset)
|
end
|
||||||
node = create(:node, :longitude => 116, :latitude => 39)
|
|
||||||
# Create relation which exceeds the relation member limit by one
|
|
||||||
0.upto(Settings.max_number_of_relation_members) do |i|
|
|
||||||
create(:relation_member, :relation => relation, :member_type => "Node", :member_id => node.id, :sequence_id => i)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
assert_raise OSM::APITooManyRelationMembersError do
|
|
||||||
relation.create_with_history user
|
|
||||||
end
|
|
||||||
|
|
||||||
Settings.max_number_of_relation_members = default_limit
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -384,14 +384,11 @@ module ActiveSupport
|
||||||
Settings.merge!(saved_settings)
|
Settings.merge!(saved_settings)
|
||||||
end
|
end
|
||||||
|
|
||||||
def with_user_account_deletion_delay(value)
|
def with_user_account_deletion_delay(value, &block)
|
||||||
freeze_time
|
freeze_time
|
||||||
default_value = Settings.user_account_deletion_delay
|
|
||||||
Settings.user_account_deletion_delay = value
|
|
||||||
|
|
||||||
yield
|
with_settings(:user_account_deletion_delay => value, &block)
|
||||||
|
ensure
|
||||||
Settings.user_account_deletion_delay = default_value
|
|
||||||
unfreeze_time
|
unfreeze_time
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue