check_block_buttons block, :edit => 1
end
- private
-
- def check_block_buttons(block, edit: 0, revoke: 0)
- [user_blocks_path, user_block_path(block)].each do |path|
- get path
- assert_response :success
- assert_select "a[href='#{edit_user_block_path block}']", :count => edit
- assert_select "a[href='#{revoke_user_block_path block}']", :count => revoke
- end
- end
-
- public
-
##
# test the new action
def test_new
:user_block_period => "12",
:user_block => { :needs_view => false, :reason => "Vandalism" })
end
- id = UserBlock.order(:id).ids.last
- assert_redirected_to user_block_path(:id => id)
+ b = UserBlock.last
+ assert_redirected_to user_block_path(:id => b.id)
assert_equal "Created a block on user #{target_user.display_name}.", flash[:notice]
- b = UserBlock.find(id)
assert_in_delta Time.now.utc, b.created_at, 1
assert_in_delta Time.now.utc, b.updated_at, 1
assert_in_delta Time.now.utc + 12.hours, b.ends_at, 1
:user_block_period => "336",
:user_block => { :needs_view => false, :reason => "Vandalism" })
- block = UserBlock.order(:id).last
+ block = UserBlock.last
assert_equal 1209600, block.ends_at - block.created_at
end
assert_equal "Original Reason", block.reason
session_for(creator_user)
- check_block_updates(block)
+ check_inactive_block_updates(block)
end
##
assert_equal "Original Reason", block.reason
session_for(creator_user)
- check_block_updates(block)
+ check_inactive_block_updates(block)
session_for(revoker_user)
- check_block_updates(block)
+ check_inactive_block_updates(block)
end
##
private
- def check_block_updates(block)
+ def check_block_buttons(block, edit: 0, revoke: 0)
+ [user_blocks_path, user_block_path(block)].each do |path|
+ get path
+ assert_response :success
+ assert_select "a[href='#{edit_user_block_path block}']", :count => edit
+ assert_select "a[href='#{revoke_user_block_path block}']", :count => revoke
+ end
+ end
+
+ def check_inactive_block_updates(block)
put user_block_path(block,
:user_block_period => "0",
:user_block => { :needs_view => false, :reason => "Updated Reason" })
put user_block_path(block,
:user_block_period => "0",
- :user_block => { :needs_view => true, :reason => "Updated Reason 2" })
+ :user_block => { :needs_view => true, :reason => "Updated Reason Needs View" })
+ assert_response :success
+ assert_equal "This block is inactive and cannot be reactivated.", flash[:error]
+ block.reload
+ assert_not_predicate block, :active?
+ assert_equal "Updated Reason", block.reason
+
+ put user_block_path(block,
+ :user_block_period => "1",
+ :user_block => { :needs_view => false, :reason => "Updated Reason Duration Extended" })
+ assert_response :success
+ assert_equal "This block is inactive and cannot be reactivated.", flash[:error]
+ block.reload
+ assert_not_predicate block, :active?
+ assert_equal "Updated Reason", block.reason
+
+ put user_block_path(block,
+ :user_block_period => "0",
+ :user_block => { :needs_view => false, :reason => "Updated Reason Again" })
assert_redirected_to user_block_path(block)
assert_equal "Block updated.", flash[:notice]
block.reload
- assert_predicate block, :active?
- assert_equal "Updated Reason 2", block.reason
+ assert_not_predicate block, :active?
+ assert_equal "Updated Reason Again", block.reason
end
def check_user_blocks_table(user_blocks)