# frozen_string_literal: true require "abstract_unit" class ActionableExceptionsTest < ActionDispatch::IntegrationTest Actions = [] class ActionError < StandardError include ActiveSupport::ActionableError action "Successful action" do Actions << "Action!" end action "Failed action" do raise "Inaction!" end end Noop = -> env { [200, {}, [""]] } setup do @app = ActionDispatch::ActionableExceptions.new(Noop) Actions.clear end test "dispatches an actionable error" do post ActionDispatch::ActionableExceptions.endpoint, params: { error: ActionError.name, action: "Successful action", location: "/", } assert_equal ["Action!"], Actions assert_equal 302, response.status assert_equal "/", response.headers["Location"] end test "cannot dispatch errors if not allowed" do post ActionDispatch::ActionableExceptions.endpoint, params: { error: ActionError.name, action: "Successful action", location: "/", }, headers: { "action_dispatch.show_exceptions" => false } assert_empty Actions end test "dispatched action can fail" do assert_raise RuntimeError do post ActionDispatch::ActionableExceptions.endpoint, params: { error: ActionError.name, action: "Failed action", location: "/", } end end test "cannot dispatch non-actionable errors" do assert_raise ActiveSupport::ActionableError::NonActionable do post ActionDispatch::ActionableExceptions.endpoint, params: { error: RuntimeError.name, action: "Inexistent action", location: "/", } end end test "cannot dispatch Inexistent errors" do assert_raise ActiveSupport::ActionableError::NonActionable do post ActionDispatch::ActionableExceptions.endpoint, params: { error: "", action: "Inexistent action", location: "/", } end end end