current_user != @user_block.revoker
flash[:error] = t(@user_block.revoker ? ".only_creator_or_revoker_can_edit" : ".only_creator_can_edit")
redirect_to :action => "edit"
- elsif @user_block.update(
- :ends_at => Time.now.utc + @block_period.hours,
- :reason => params[:user_block][:reason],
- :needs_view => params[:user_block][:needs_view]
- )
- flash[:notice] = t(".success")
- redirect_to(@user_block)
else
- render :action => "edit"
+ user_block_was_active = @user_block.active?
+ @user_block.reason = params[:user_block][:reason]
+ @user_block.needs_view = params[:user_block][:needs_view]
+ @user_block.ends_at = Time.now.utc + @block_period.hours
+ if !user_block_was_active && @user_block.active?
+ flash.now[:error] = t(".inactive_block_cannot_be_reactivated")
+ render :action => "edit"
+ elsif @user_block.save
+ flash[:notice] = t(".success")
+ redirect_to @user_block
+ else
+ render :action => "edit"
+ end
end
else
redirect_to edit_user_block_path(:id => params[:id])
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
##
end
end
- def check_block_updates(block)
+ 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)