【发布时间】:2012-05-26 01:22:00
【问题描述】:
我有以下包含许多订单项的购物车模型。它只包含一个添加新行项目并增加其数量的方法。
class Cart < ActiveRecord::Base
has_many :line_items, dependent: :destroy
validate :cart_total_price_cannot_be_greater_than_500
def add_product(product_id)
current_item = line_items.find_by_product_id(product_id)
# Updates quantity or add a new line item
if current_item
current_item.quantity += 1
else
current_item = line_items.build(product_id: product_id)
current_item.quantity = 1
product = Product.find(product_id)
current_item.product_price = product.price
end
current_item
end
def cart_total_price
line_items.to_a.sum { |item| item.product_price * item.quantity }
end
def cart_total_price_cannot_be_greater_than_500
if cart_total_price > 500
errors.add(:base, "has a too high price")
end
end
end
订单项模型如下:
class LineItem < ActiveRecord::Base
belongs_to :product
belongs_to :cart
def total_price
product.price * quantity
end
end
以下测试工作正常:
require 'test_helper'
class CartTest < ActiveSupport::TestCase
fixtures :products
test "add duplicated products to cart" do
cart = Cart.create
# :ruby is a product
cart.add_product(products(:ruby).id).save
cart.add_product(products(:ruby).id).save
assert_equal 1, cart.line_items.size
assert_equal 2, cart.line_items.first.quantity
end
end
一切顺利,直到我添加了第三行 validate :cart_total_price_cannot_be_greater_than_500。这现在破坏了我的测试,我从rake test 收到以下错误:
Finished tests in 0.294143s, 23.7979 tests/s, 84.9927 assertions/s.
1) Failure:
test_add_duplicated_products_to_cart(CartTest) [/home/luca/Documents/Sites/depot/test/unit/cart_test.rb:14]:
<2> expected but was
<1>.
我做错了什么?如果我注释掉 validate 方法,测试将正确通过。
附:我的第二个问题是:为什么如果我在 cart_total_price 方法上调用 sum 之前不添加“to_a”方法它不起作用?
谢谢!
编辑:关于第二个问题,to_a 方法不是查询数据库而不执行求和吗?我想在数据库而不是服务器端执行计算。我正在从 .NET 和 LINQ 学习 Rails,我可以使用:
int sum = dbContext.LineItems.Where(l => l.CartId == cartId).Sum(l => l.Quantity * l.ProductPrice)
【问题讨论】:
标签: ruby-on-rails ruby validation activerecord