add specs
This commit is contained in:
parent
e902aa0d5a
commit
45db0575b1
46 changed files with 714 additions and 238 deletions
131
spec/integration/ordergroup_invoice_spec.rb
Normal file
131
spec/integration/ordergroup_invoice_spec.rb
Normal file
|
|
@ -0,0 +1,131 @@
|
|||
require_relative '../spec_helper'
|
||||
|
||||
feature OrdergroupInvoice, type: :feature, js: true do
|
||||
let(:admin) { create :user, groups: [create(:workgroup, role_finance: true), create(:ordergroup, name: "AdminOrders")] }
|
||||
let(:user) { create :user, groups: [create(:ordergroup)] }
|
||||
|
||||
let(:article) { create :article, unit_quantity: 4 }
|
||||
let(:article1) { create :article, unit_quantity: 2 }
|
||||
let(:order) { create :order, supplier: article.supplier, article_ids: [article.id], ends: Time.now }
|
||||
let(:order1) { create :order, supplier: article1.supplier, article_ids: [article1.id], ends: Time.now }
|
||||
|
||||
let(:go) { create :group_order, order: order, ordergroup: user.ordergroup}
|
||||
let(:go1) { create :group_order, order: order1, ordergroup: admin.ordergroup}
|
||||
|
||||
let(:oa) { order.order_articles.find_by_article_id(article.id) }
|
||||
let(:oa1) { order1.order_articles.find_by_article_id(article1.id) }
|
||||
let(:ftt) { create :financial_transaction_type }
|
||||
|
||||
let(:goa) { create :group_order_article, group_order: go, order_article: oa }
|
||||
let(:goa1) { create :group_order_article, group_order: go1, order_article: oa1 }
|
||||
|
||||
include ActiveJob::TestHelper
|
||||
|
||||
before do
|
||||
login admin
|
||||
goa.update_quantities 2, 0
|
||||
goa1.update_quantities 2, 0
|
||||
oa.update_results!
|
||||
oa1.update_results!
|
||||
FoodsoftConfig[:contact][:tax_number] = 12_345_678
|
||||
order.update!(state: 'closed')
|
||||
order1.update!(state: 'closed')
|
||||
end
|
||||
|
||||
after { clear_enqueued_jobs }
|
||||
|
||||
# first ensure theres multiple orders and the check box to combine them to a multiorder
|
||||
|
||||
it 'shows the elements to combine orders' do
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_css("#order_#{order.id}_combine")
|
||||
expect(page).to have_css("#order_#{order1.id}_combine")
|
||||
expect(page).to have_css(".merge-orders-btn")
|
||||
end
|
||||
|
||||
it 'cannot combine orders when orders are not closed' do
|
||||
order.update!(state: 'finished')
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_css("#order_#{order.id}_combine")
|
||||
expect(page).to have_css("#order_#{order1.id}_combine")
|
||||
expect(page).to have_css(".merge-orders-btn")
|
||||
# check the checkboxes and click the button
|
||||
check("order_#{order.id}_combine")
|
||||
check("order_#{order1.id}_combine")
|
||||
click_link_or_button 'Zusammenführen'
|
||||
expect(page).to have_content('Die Bestellung ist bereits Teil einer Multi-Bestellung oder ist noch nicht abgeschlossen.')
|
||||
end
|
||||
|
||||
it 'cannot combine orders when group_orders already have an invoice' do
|
||||
group_order_invoice = create(:group_order_invoice, group_order: go)
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_css("#order_#{order.id}_combine")
|
||||
expect(page).to have_css("#order_#{order1.id}_combine")
|
||||
expect(page).to have_css(".merge-orders-btn")
|
||||
# check the checkboxes and click the button
|
||||
check("order_#{order.id}_combine")
|
||||
check("order_#{order1.id}_combine")
|
||||
click_link_or_button 'Zusammenführen'
|
||||
expect(page).to have_content('Zusammenführen nicht möglich. Es gibt bereits Rechnungen für einige der Bestellgruppen.')
|
||||
end
|
||||
|
||||
it 'can generate multiple ordergroup invoice' do
|
||||
multi_order = create(:multi_order, orders: [order, order1])
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_selector(:link_or_button, "Multi Bestellung auflösen")
|
||||
click_link_or_button 'Toggle details'
|
||||
expect(page).to have_selector(:link_or_button, I18n.t('activerecord.attributes.group_order_invoice.links.generate_with_date'))
|
||||
click_link_or_button I18n.t('activerecord.attributes.group_order_invoice.links.generate_with_date')
|
||||
sleep 1
|
||||
expect(OrdergroupInvoice.all.count).to eq(2)
|
||||
end
|
||||
|
||||
it 'can generate single ordergroup invoice' do
|
||||
multi_order = create(:multi_order, orders: [order, order1])
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_selector(:link_or_button, "Multi Bestellung auflösen")
|
||||
click_link_or_button 'Toggle details'
|
||||
expect(page).to have_selector(:link_or_button, I18n.t('activerecord.attributes.group_order_invoice.links.generate'))
|
||||
first(:link_or_button, I18n.t('activerecord.attributes.group_order_invoice.links.generate')).click
|
||||
sleep 1
|
||||
expect(OrdergroupInvoice.all.count).to eq(1)
|
||||
end
|
||||
it 'cannot toggel details when config wrong' do
|
||||
FoodsoftConfig[:contact][:tax_number] = nil
|
||||
multi_order = create(:multi_order, orders: [order, order1])
|
||||
visit finance_order_index_path
|
||||
expect(page).not_to have_selector(:link_or_button, 'Toggle details')
|
||||
end
|
||||
|
||||
it 'cannot destroy multi_order if invoice attached' do
|
||||
multi_order = create(:multi_order, orders: [order, order1])
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_selector(:link_or_button, "Multi Bestellung auflösen")
|
||||
click_link_or_button 'Toggle details'
|
||||
expect(page).to have_selector(:link_or_button, I18n.t('activerecord.attributes.group_order_invoice.links.generate'))
|
||||
sleep 1
|
||||
first(:link_or_button, I18n.t('activerecord.attributes.group_order_invoice.links.generate')).click
|
||||
sleep 1
|
||||
expect(OrdergroupInvoice.all.count).to eq(1)
|
||||
click_link_or_button 'Multi Bestellung auflösen'
|
||||
expect(page).to have_content("Lösche erst die Rechnungen")
|
||||
end
|
||||
|
||||
it 'can toggle elements for ordergroup invoice' do
|
||||
multi_order = create(:multi_order, orders: [order, order1])
|
||||
visit finance_order_index_path
|
||||
expect(page).to have_selector(:link_or_button, "Multi Bestellung auflösen")
|
||||
click_link_or_button 'Toggle details'
|
||||
expect(page).to have_selector(:link_or_button, I18n.t('activerecord.attributes.group_order_invoice.links.generate_with_date'))
|
||||
click_link_or_button I18n.t('activerecord.attributes.group_order_invoice.links.generate_with_date')
|
||||
sleep 1
|
||||
expect(OrdergroupInvoice.all.count).to eq(2)
|
||||
check("sepa_downloaded_all_multi_#{multi_order.id}")
|
||||
sleep 1
|
||||
expect(page).to have_checked_field("sepa_downloaded_multi_#{OrdergroupInvoice.last.id}")
|
||||
expect(page).to have_checked_field("sepa_downloaded_multi_#{OrdergroupInvoice.first.id}")
|
||||
check("paid_all_multi_#{multi_order.id}")
|
||||
expect(page).to have_checked_field("paid_multi_#{OrdergroupInvoice.first.id}")
|
||||
expect(page).to have_checked_field("paid_multi_#{OrdergroupInvoice.last.id}")
|
||||
end
|
||||
end
|
||||
Loading…
Add table
Add a link
Reference in a new issue