Commit db39710f8a591f6b7861c19de1dbf9c0cc6f1b92
1 parent
9f455fa1
Exists in
master
and in
23 other branches
Functional and unit tests
Also some little fixes
Showing
5 changed files
with
278 additions
and
1 deletions
Show diff stats
plugins/shopping_cart/controllers/shopping_cart_plugin_profile_controller.rb
| @@ -27,7 +27,7 @@ class ShoppingCartPluginProfileController < ProfileController | @@ -27,7 +27,7 @@ class ShoppingCartPluginProfileController < ProfileController | ||
| 27 | 27 | ||
| 28 | def remove | 28 | def remove |
| 29 | id = params[:id].to_i | 29 | id = params[:id].to_i |
| 30 | - if validate_cart_has_product(id) | 30 | + if validate_cart_presence && validate_cart_has_product(id) |
| 31 | session[:cart][:items].delete(id) | 31 | session[:cart][:items].delete(id) |
| 32 | session[:cart] = nil if session[:cart][:items].empty? | 32 | session[:cart] = nil if session[:cart][:items].empty? |
| 33 | render :text => { | 33 | render :text => { |
plugins/shopping_cart/test/functional/shopping_cart_plugin_myprofile_controller_test.rb
0 → 100644
| @@ -0,0 +1,37 @@ | @@ -0,0 +1,37 @@ | ||
| 1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | ||
| 2 | +require File.dirname(__FILE__) + '/../../controllers/shopping_cart_plugin_myprofile_controller' | ||
| 3 | + | ||
| 4 | +# Re-raise errors caught by the controller. | ||
| 5 | +class ShoppingCartPluginMyprofileController; def rescue_action(e) raise e end; end | ||
| 6 | + | ||
| 7 | +class ShoppingCartPluginMyprofileControllerTest < Test::Unit::TestCase | ||
| 8 | + | ||
| 9 | + def setup | ||
| 10 | + @controller = ShoppingCartPluginMyprofileController.new | ||
| 11 | + @request = ActionController::TestRequest.new | ||
| 12 | + @response = ActionController::TestResponse.new | ||
| 13 | + @enterprise = fast_create(Enterprise) | ||
| 14 | + @admin = create_user('admin').person | ||
| 15 | + @enterprise.add_admin(@admin) | ||
| 16 | + login_as(@admin.identifier) | ||
| 17 | + end | ||
| 18 | + attr_reader :enterprise | ||
| 19 | + | ||
| 20 | + should 'be able to enable shopping cart' do | ||
| 21 | + enterprise.shopping_cart = false | ||
| 22 | + enterprise.save | ||
| 23 | + post :edit, :profile => enterprise.identifier, :shopping_cart => '1' | ||
| 24 | + enterprise.reload | ||
| 25 | + | ||
| 26 | + assert enterprise.shopping_cart | ||
| 27 | + end | ||
| 28 | + | ||
| 29 | + should 'be able to disable shopping cart' do | ||
| 30 | + enterprise.shopping_cart = true | ||
| 31 | + enterprise.save | ||
| 32 | + post :edit, :profile => enterprise.identifier, :shopping_cart => '0' | ||
| 33 | + enterprise.reload | ||
| 34 | + | ||
| 35 | + assert !enterprise.shopping_cart | ||
| 36 | + end | ||
| 37 | +end |
plugins/shopping_cart/test/functional/shopping_cart_plugin_profile_controller_test.rb
0 → 100644
| @@ -0,0 +1,180 @@ | @@ -0,0 +1,180 @@ | ||
| 1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | ||
| 2 | +require File.dirname(__FILE__) + '/../../controllers/shopping_cart_plugin_profile_controller' | ||
| 3 | + | ||
| 4 | +# Re-raise errors caught by the controller. | ||
| 5 | +class ShoppingCartPluginProfileController; def rescue_action(e) raise e end; end | ||
| 6 | + | ||
| 7 | +class ShoppingCartPluginProfileControllerTest < Test::Unit::TestCase | ||
| 8 | + | ||
| 9 | + def setup | ||
| 10 | + @controller = ShoppingCartPluginProfileController.new | ||
| 11 | + @request = ActionController::TestRequest.new | ||
| 12 | + @response = ActionController::TestResponse.new | ||
| 13 | + @enterprise = fast_create(Enterprise) | ||
| 14 | + @product = fast_create(Product, :enterprise_id => @enterprise.id) | ||
| 15 | + end | ||
| 16 | + attr_reader :enterprise | ||
| 17 | + attr_reader :product | ||
| 18 | + | ||
| 19 | + should 'add a new product to cart' do | ||
| 20 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 21 | + | ||
| 22 | + assert product_in_cart?(product) | ||
| 23 | + assert_equal 1, product_quantity(product) | ||
| 24 | + end | ||
| 25 | + | ||
| 26 | + should 'grow quantity through add' do | ||
| 27 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 28 | + assert_equal 1, product_quantity(product) | ||
| 29 | + | ||
| 30 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 31 | + assert_equal 2, product_quantity(product) | ||
| 32 | + end | ||
| 33 | + | ||
| 34 | + should 'not add product to cart if it does not exists' do | ||
| 35 | + assert_nothing_raised { get :add, :profile => enterprise.identifier, :id => 9999 } | ||
| 36 | + | ||
| 37 | + assert !product_in_cart?(product) | ||
| 38 | + assert !response_ok? | ||
| 39 | + assert 3, reponse_error_code | ||
| 40 | + end | ||
| 41 | + | ||
| 42 | + should 'remove cart if the product being removed is the last one' do | ||
| 43 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 44 | + assert cart? | ||
| 45 | + | ||
| 46 | + get :remove, :profile => enterprise.identifier, :id => product.id | ||
| 47 | + assert !cart? | ||
| 48 | + end | ||
| 49 | + | ||
| 50 | + should 'not try to remove a product if there is no cart' do | ||
| 51 | + instantiate_session | ||
| 52 | + assert !cart? | ||
| 53 | + | ||
| 54 | + assert_nothing_raised { get :remove, :profile => enterprise.identifier, :id => 9999 } | ||
| 55 | + assert !response_ok? | ||
| 56 | + assert_equal 2, reponse_error_code | ||
| 57 | + end | ||
| 58 | + | ||
| 59 | + should 'just remove product if there are other products on cart' do | ||
| 60 | + another_product = fast_create(Product, :enterprise_id => enterprise.id) | ||
| 61 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 62 | + get :add, :profile => enterprise.identifier, :id => another_product.id | ||
| 63 | + | ||
| 64 | + get :remove, :profile => enterprise.identifier, :id => product.id | ||
| 65 | + assert cart? | ||
| 66 | + assert !product_in_cart?(product) | ||
| 67 | + end | ||
| 68 | + | ||
| 69 | + should 'not try to remove a product that is not in the cart' do | ||
| 70 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 71 | + assert cart? | ||
| 72 | + assert_nothing_raised { get :remove, :profile => enterprise.identifier, :id => 9999 } | ||
| 73 | + | ||
| 74 | + assert !response_ok? | ||
| 75 | + assert_equal 4, reponse_error_code | ||
| 76 | + end | ||
| 77 | + | ||
| 78 | + should 'not try to list the cart if there is no cart' do | ||
| 79 | + instantiate_session | ||
| 80 | + assert !cart? | ||
| 81 | + | ||
| 82 | + assert_nothing_raised { get :list, :profile => enterprise.identifier } | ||
| 83 | + assert !response_ok? | ||
| 84 | + assert_equal 2, reponse_error_code | ||
| 85 | + end | ||
| 86 | + | ||
| 87 | + should 'list products without errors' do | ||
| 88 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 89 | + | ||
| 90 | + assert_nothing_raised { get :list, :profile => enterprise.identifier } | ||
| 91 | + assert response_ok? | ||
| 92 | + end | ||
| 93 | + | ||
| 94 | + should 'update the quantity of a product' do | ||
| 95 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 96 | + assert 1, product_quantity(product) | ||
| 97 | + | ||
| 98 | + get :update_quantity, :profile => enterprise.identifier, :id => product.id, :quantity => 3 | ||
| 99 | + assert 3, product_quantity(product) | ||
| 100 | + end | ||
| 101 | + | ||
| 102 | + should 'not try to update quantity the quantity of a product if there is no cart' do | ||
| 103 | + instantiate_session | ||
| 104 | + assert !cart? | ||
| 105 | + | ||
| 106 | + assert_nothing_raised { get :update_quantity, :profile => enterprise.identifier, :id => 9999, :quantity => 3 } | ||
| 107 | + assert !response_ok? | ||
| 108 | + assert_equal 2, reponse_error_code | ||
| 109 | + end | ||
| 110 | + | ||
| 111 | + should 'not try to update the quantity of a product that is not in the cart' do | ||
| 112 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 113 | + assert cart? | ||
| 114 | + assert_nothing_raised { get :update_quantity, :profile => enterprise.identifier, :id => 9999, :quantity => 3 } | ||
| 115 | + | ||
| 116 | + assert !response_ok? | ||
| 117 | + assert_equal 4, reponse_error_code | ||
| 118 | + end | ||
| 119 | + | ||
| 120 | + should 'not update the quantity of a product with a invalid value' do | ||
| 121 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 122 | + | ||
| 123 | + assert_nothing_raised { get :update_quantity, :profile => enterprise.identifier, :id => product.id, :quantity => -1} | ||
| 124 | + assert !response_ok? | ||
| 125 | + assert_equal 5, reponse_error_code | ||
| 126 | + | ||
| 127 | + assert_nothing_raised { get :update_quantity, :profile => enterprise.identifier, :id => product.id, :quantity => 'asdf'} | ||
| 128 | + assert !response_ok? | ||
| 129 | + assert_equal 5, reponse_error_code | ||
| 130 | + end | ||
| 131 | + | ||
| 132 | + should 'clean the cart' do | ||
| 133 | + another_product = fast_create(Product, :enterprise_id => enterprise.id) | ||
| 134 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 135 | + get :add, :profile => enterprise.identifier, :id => another_product.id | ||
| 136 | + | ||
| 137 | + assert_nothing_raised { get :clean, :profile => enterprise.identifier } | ||
| 138 | + assert !cart? | ||
| 139 | + end | ||
| 140 | + | ||
| 141 | + should 'not crash if there is no cart' do | ||
| 142 | + instantiate_session | ||
| 143 | + assert !cart? | ||
| 144 | + assert_nothing_raised { get :clean, :profile => enterprise.identifier } | ||
| 145 | + end | ||
| 146 | + | ||
| 147 | + private | ||
| 148 | + | ||
| 149 | + def json_response | ||
| 150 | + ActiveSupport::JSON.decode @response.body | ||
| 151 | + end | ||
| 152 | + | ||
| 153 | + def cart? | ||
| 154 | + !session[:cart].nil? | ||
| 155 | + end | ||
| 156 | + | ||
| 157 | + def product_in_cart?(product) | ||
| 158 | + session[:cart][:items].has_key?(product.id) | ||
| 159 | + end | ||
| 160 | + | ||
| 161 | + def product_quantity(product) | ||
| 162 | + session[:cart][:items][product.id] | ||
| 163 | + end | ||
| 164 | + | ||
| 165 | + def response_ok? | ||
| 166 | + json_response['ok'] | ||
| 167 | + end | ||
| 168 | + | ||
| 169 | + def reponse_error_code | ||
| 170 | + json_response['error']['code'] | ||
| 171 | + end | ||
| 172 | + | ||
| 173 | + # temporary hack...if I don't do this the session stays as an Array instead | ||
| 174 | + # of a TestSession | ||
| 175 | + def instantiate_session | ||
| 176 | + get :add, :profile => enterprise.identifier, :id => product.id | ||
| 177 | + get :remove, :profile => enterprise.identifier, :id => product.id | ||
| 178 | + end | ||
| 179 | + | ||
| 180 | +end |
plugins/shopping_cart/test/unit/shopping_cart_plugin/cart_helper_test.rb
0 → 100644
| @@ -0,0 +1,38 @@ | @@ -0,0 +1,38 @@ | ||
| 1 | +require File.dirname(__FILE__) + '/../../../../../test/test_helper' | ||
| 2 | + | ||
| 3 | +class ShoppingCartPlugin::CartHelperTest < Test::Unit::TestCase | ||
| 4 | + | ||
| 5 | + include ShoppingCartPlugin::CartHelper | ||
| 6 | + | ||
| 7 | + def setup | ||
| 8 | + @product = mock() | ||
| 9 | + @product.stubs(:name).returns('Sample') | ||
| 10 | + @product.stubs(:price).returns(nil) | ||
| 11 | + @product.stubs(:discount).returns(nil) | ||
| 12 | + end | ||
| 13 | + | ||
| 14 | + attr_reader :product | ||
| 15 | + | ||
| 16 | + should 'return 0 on sell price if the product have no price' do | ||
| 17 | + assert_equal 0, sell_price(product) | ||
| 18 | + end | ||
| 19 | + | ||
| 20 | + should 'return the price of the product on sell price if there is no discount' do | ||
| 21 | + price = 5.73 | ||
| 22 | + product.stubs(:price).returns(price) | ||
| 23 | + | ||
| 24 | + assert_equal price, sell_price(product) | ||
| 25 | + end | ||
| 26 | + | ||
| 27 | + should 'return the price with discount on sell price if there is a discount' do | ||
| 28 | + price = 5.73 | ||
| 29 | + discount = 1 | ||
| 30 | + product.stubs(:price).returns(price) | ||
| 31 | + product.stubs(:discount).returns(discount) | ||
| 32 | + product.stubs(:price_with_discount).returns(price-discount) | ||
| 33 | + | ||
| 34 | + assert_equal price-discount, sell_price(product) | ||
| 35 | + end | ||
| 36 | + | ||
| 37 | +end | ||
| 38 | + |
plugins/shopping_cart/test/unit/shopping_cart_plugin_test.rb
0 → 100644
| @@ -0,0 +1,22 @@ | @@ -0,0 +1,22 @@ | ||
| 1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | ||
| 2 | + | ||
| 3 | +class ShoppingCartPluginTest < Test::Unit::TestCase | ||
| 4 | + | ||
| 5 | + def setup | ||
| 6 | + @shopping_cart = ShoppingCartPlugin.new | ||
| 7 | + @context = mock() | ||
| 8 | + @profile = mock() | ||
| 9 | + @profile.stubs(:identifier).returns('random-user') | ||
| 10 | + @context.stubs(:profile).returns(@profile) | ||
| 11 | + @shopping_cart.context = @context | ||
| 12 | + @shopping_cart.stubs(:profile).returns(@profile) | ||
| 13 | + end | ||
| 14 | + | ||
| 15 | + attr_reader :shopping_cart | ||
| 16 | + attr_reader :context | ||
| 17 | + | ||
| 18 | + should 'return true to stylesheet' do | ||
| 19 | + assert shopping_cart.stylesheet? | ||
| 20 | + end | ||
| 21 | + | ||
| 22 | +end |