Files
openfoodnetwork/spec/models/spree/calculator_spec.rb
Luis Ramos 4c9e4ee926 Fix problem in calculator spec
I am not sure why this started failing on this branch only and not in master but this fix is correct because line_items are created with order defined already, an order.reload is enough to load them into the order
2020-10-15 17:19:39 +01:00

43 lines
1.2 KiB
Ruby

require 'spec_helper'
module Spree
describe Calculator do
let(:calculator) { Spree::Calculator.new }
let!(:enterprise) { create(:enterprise) }
let!(:order) { create(:order) }
let!(:shipment) { create(:shipment) }
let!(:line_item) { create(:line_item, order: order) }
let!(:line_item2) { create(:line_item, order: order) }
before do
order.reload.shipments = [shipment]
end
describe "#line_items_for" do
it "returns the line item if given a line item" do
result = calculator.__send__(:line_items_for, line_item)
expect(result).to eq [line_item]
end
it "returns line items if given an object with line items" do
result = calculator.__send__(:line_items_for, order)
expect(result).to eq [line_item, line_item2]
end
it "returns line items if given an object with an order" do
result = calculator.__send__(:line_items_for, shipment)
expect(result).to eq [line_item, line_item2]
end
it "returns the original object if given anything else" do
result = calculator.__send__(:line_items_for, enterprise)
expect(result).to eq [enterprise]
end
end
end
end