192 lines
7.4 KiB
Ruby
192 lines
7.4 KiB
Ruby
require_relative '../spec_helper'
|
|
|
|
feature ArticlesController do
|
|
let(:user) { create(:user, groups: [create(:workgroup, role_article_meta: true)]) }
|
|
let(:supplier) { create(:supplier) }
|
|
let!(:article_category) { create(:article_category) }
|
|
|
|
before { login user }
|
|
|
|
describe ':index', js: true do
|
|
before {
|
|
login user
|
|
visit supplier_articles_path(supplier_id: supplier.id)
|
|
}
|
|
|
|
it 'can visit supplier articles path' do
|
|
expect(page).to have_content(supplier.name)
|
|
expect(page).to have_content(I18n.t('articles.index.edit_all'))
|
|
end
|
|
|
|
it 'can create a new article' do
|
|
click_on I18n.t('articles.index.new')
|
|
expect(page).to have_selector('form#new_article')
|
|
article = build(:article, supplier: supplier, article_category: article_category)
|
|
within('#new_article') do
|
|
fill_in 'article_name', :with => article.name
|
|
fill_in 'article_unit', :with => article.unit
|
|
select article.article_category.name, :from => 'article_article_category_id'
|
|
fill_in 'article_price', :with => article.price
|
|
fill_in 'article_unit_quantity', :with => article.unit_quantity
|
|
fill_in 'article_tax', :with => article.tax
|
|
fill_in 'article_deposit', :with => article.deposit
|
|
# "Element cannot be scrolled into view" error, js as workaround
|
|
# find('input[type="submit"]').click
|
|
page.execute_script('$("form#new_article").submit();')
|
|
end
|
|
expect(page).to have_content(article.name)
|
|
end
|
|
end
|
|
|
|
describe ':upload' do
|
|
let(:filename) { 'foodsoft_file_02.csv' }
|
|
let(:file) { Rails.root.join("spec/fixtures/#{filename}") }
|
|
|
|
before do
|
|
visit upload_supplier_articles_path(supplier_id: supplier.id)
|
|
attach_file 'articles_file', file
|
|
end
|
|
|
|
Dir.glob('spec/fixtures/foodsoft_file_01.*') do |test_file|
|
|
describe "can import articles from #{test_file}" do
|
|
let(:file) { Rails.root.join(test_file) }
|
|
|
|
it do
|
|
find("#articles_type option[value='foodsoft']").select_option
|
|
find('input[type="submit"]').click
|
|
expect(find("tr:nth-child(1) #new_articles__note").value).to eq "bio ◎"
|
|
expect(find("tr:nth-child(2) #new_articles__name").value).to eq "Pijnboompitten"
|
|
|
|
4.times do |i|
|
|
all("tr:nth-child(#{i + 1}) select > option")[1].select_option
|
|
end
|
|
find('input[type="submit"]').click
|
|
expect(page).to have_content("Pijnboompitten")
|
|
|
|
expect(supplier.articles.count).to eq 4
|
|
end
|
|
end
|
|
end
|
|
|
|
Dir.glob('spec/fixtures/bnn_file_01.*') do |test_file|
|
|
describe "can import articles from #{test_file}" do
|
|
let(:file) { Rails.root.join(test_file) }
|
|
|
|
it do
|
|
find("#articles_type option[value='bnn']").select_option
|
|
find('input[type="submit"]').click
|
|
expect(find("tr:nth-child(1) #new_articles__note").value).to eq "bio"
|
|
expect(find("tr:nth-child(1) #new_articles__name").value).to eq "Walnoten (ongeroosterd)"
|
|
# set article category
|
|
4.times do |i|
|
|
all("tr:nth-child(#{i + 1}) select > option")[1].select_option
|
|
end
|
|
find('input[type="submit"]').click
|
|
|
|
expect(page).to have_content("Pijnboompitten")
|
|
|
|
expect(supplier.articles.count).to eq 4
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "updates" do
|
|
file_paths = ['spec/fixtures/foodsoft_file_02.csv', 'spec/fixtures/bnn_file_02.bnn', 'spec/fixtures/odin_file_02.xml']
|
|
let(:filename) { 'foodsoft_file_02.csv' }
|
|
let(:file) { Rails.root.join("spec/fixtures/#{filename}") }
|
|
let(:val) { 'foodsoft' }
|
|
let(:type) { %w[foodsoft bnn odin] }
|
|
|
|
before do
|
|
visit upload_supplier_articles_path(supplier_id: supplier.id)
|
|
attach_file 'articles_file', file
|
|
find("#articles_type option[value='#{val}']").select_option
|
|
end
|
|
|
|
file_paths.each_with_index do |test_file, index|
|
|
describe "updates article for #{test_file}" do
|
|
let(:article) { create(:article, supplier: supplier, name: 'Foobar', order_number: 1, unit: '250 g') }
|
|
let(:file) { Rails.root.join(test_file) }
|
|
let(:val) { type[index] }
|
|
|
|
it do
|
|
article.reload
|
|
find('input[type="submit"]').click
|
|
expect(find("#articles_#{article.id}_name").value).to eq 'Tomatoes'
|
|
find('input[type="submit"]').click
|
|
article.reload
|
|
expect(article.name).to eq 'Tomatoes'
|
|
if type[index] == "odin"
|
|
expect([article.unit, article.unit_quantity, article.price]).to eq ['500gr', 20, 1.20]
|
|
else
|
|
expect([article.unit, article.unit_quantity, article.price]).to eq ['500 g', 20, 1.20]
|
|
end
|
|
end
|
|
|
|
it "handles missing data" do
|
|
find('input[type="submit"]').click # to overview
|
|
find('input[type="submit"]').click # missing category, re-show form
|
|
expect(find('tr.alert')).to be_present
|
|
expect(supplier.articles.count).to eq 0
|
|
|
|
all("tr select > option")[1].select_option
|
|
find('input[type="submit"]').click # now it should succeed
|
|
expect(supplier.articles.count).to eq 1
|
|
end
|
|
end
|
|
|
|
describe "takes over category from file" do
|
|
it do
|
|
find(:css, '#articles_update_category[value="1"]').set(true) # check take over category from file
|
|
expect(ArticleCategory.count).to eq 1 # new Category vegetables should be created from file
|
|
find('input[type="submit"]').click # upload file
|
|
find('input[type="submit"]').click # submit changes
|
|
expect(ArticleCategory.count).to eq 2 # it is
|
|
expect(supplier.articles.count).to eq 1
|
|
expect(supplier.articles.first.article_category.name).to eq "Vegetables"
|
|
end
|
|
end
|
|
|
|
describe "overwrites article_category from file" do
|
|
let!(:article_category) { create(:article_category, name: "Fruit") }
|
|
let(:article) { create(:article, supplier: supplier, name: 'Tomatoes', order_number: 1, unit: '250 g', article_category: article_category) }
|
|
|
|
it do
|
|
find(:css, '#articles_update_category[value="1"]').set(true) # check take over category from file
|
|
find('input[type="submit"]').click #upload file
|
|
find('input[type="submit"]').click #submit changes
|
|
expect(supplier.articles.count).to eq 1
|
|
expect(supplier.articles.first.article_category.name).to eq "Vegetables"
|
|
end
|
|
end
|
|
|
|
describe "can remove an existing article" do
|
|
let!(:article) { create(:article, supplier: supplier, name: 'Foobar', order_number: 99999) }
|
|
|
|
it do
|
|
check('articles_outlist_absent')
|
|
find('input[type="submit"]').click
|
|
expect(find("#outlisted_articles_#{article.id}", visible: :all)).to be_present
|
|
|
|
all("tr select > option")[1].select_option
|
|
find('input[type="submit"]').click
|
|
expect(article.reload.deleted?).to be true
|
|
end
|
|
end
|
|
|
|
describe "can convert units when updating" do
|
|
let!(:article) { create(:article, supplier: supplier, order_number: 1, unit: '250 g') }
|
|
|
|
it do
|
|
check('articles_convert_units')
|
|
find('input[type="submit"]').click
|
|
expect(find("#articles_#{article.id}_name").value).to eq 'Tomatoes'
|
|
find('input[type="submit"]').click
|
|
article.reload
|
|
expect([article.unit, article.unit_quantity, article.price]).to eq ['250 g', 40, 0.6]
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|