#--- # Excerpted from "Agile Web Development with Rails, 2nd Ed." # We make no guarantees that this code is fit for any purpose. # Visit http://www.pragmaticprogrammer.com/titles/rails2 for more book information. #--- require File.dirname(__FILE__) + '/../test_helper' require 'store_controller' # Re-raise errors caught by the controller. class OrderController; def rescue_action(e) raise e end; end class OrderSpeedTest < Test::Unit::TestCase DAVES_DETAILS = { :name => "Dave Thomas", :address => "123 The Street", :email => "dave@pragprog.com", :pay_type => "check" } self.fixture_path = File.join(File.dirname(__FILE__), "../fixtures/performance") fixtures :products def setup @controller = StoreController.new @request = ActionController::TestRequest.new @response = ActionController::TestResponse.new end def test_100_orders Order.delete_all LineItem.delete_all @controller.logger.silence do elapsed_time = Benchmark.realtime do 100.downto(1) do |prd_id| cart = Cart.new cart.add_product(Product.find(prd_id)) post :save_order, { :order => DAVES_DETAILS }, { :cart => cart } assert_redirected_to :action => :index end end assert_equal 100, Order.count assert elapsed_time < 3.00 end end end