add feature test on type de champ:

add typde de champ
delete type de champ
This commit is contained in:
Tanguy PATTE 2015-11-17 11:23:13 +01:00
parent afd0b72ae8
commit 65c8c039ac
2 changed files with 38 additions and 69 deletions

View file

@ -25,7 +25,7 @@
- unless ff.object.id.nil? - unless ff.object.id.nil?
.form-group .form-group
%br   %br  
= link_to("Delete", admin_procedure_type_de_champ_path(@procedure, ff.object.id), method: :delete, remote: true) = link_to("", admin_procedure_type_de_champ_path(@procedure, ff.object.id), method: :delete, remote: true, id: "delete_type_de_champ_#{ff.object.id}", class: %w(form-control btn btn-danger fa fa-trash-o) )
/ %button.form-control.btn.btn-danger.fa.fa-trash-o{type: 'button'}
/ , id: "delete_type_de_champ_#{type_de_champ.id || index}_procedure"}

View file

@ -26,6 +26,7 @@ feature 'add a new type de champs', js: true do
page.find_by_id('procedure_types_de_champ_attributes_0_type_champ').set type_champ page.find_by_id('procedure_types_de_champ_attributes_0_type_champ').set type_champ
page.find_by_id('procedure_types_de_champ_attributes_0_description').set description page.find_by_id('procedure_types_de_champ_attributes_0_description').set description
click_button 'Ajouter un champ' click_button 'Ajouter un champ'
wait_for_ajax
procedure.reload procedure.reload
end end
subject { procedure.types_de_champ.first } subject { procedure.types_de_champ.first }
@ -35,71 +36,39 @@ feature 'add a new type de champs', js: true do
expect(subject.type_champ).to eq(type_champ) expect(subject.type_champ).to eq(type_champ)
expect(subject.description).to eq(description) expect(subject.description).to eq(description)
end end
context 'user fill another one' do
let(:libelle) { 'coucou' }
let(:type_champ) { 'textarea' }
let(:description) { 'to be or not to be' }
before do
page.find_by_id('procedure_types_de_champ_attributes_1_libelle').set libelle
select(type_champ, from: 'procedure_types_de_champ_attributes_1_type_champ')
page.find_by_id('procedure_types_de_champ_attributes_1_description').set description
click_button 'Ajouter un champ'
wait_for_ajax
procedure.reload
end
subject { procedure.types_de_champ.last }
scenario 'creates another types_de_champ' do
expect(page).to have_css('#procedure_types_de_champ_attributes_2_libelle')
expect(subject.libelle).to eq(libelle)
expect(subject.type_champ).to eq(type_champ)
expect(subject.description).to eq(description)
expect(procedure.types_de_champ.count).to eq(2)
end
context 'user delete the first one' do
let(:type_de_champ) { procedure.types_de_champ.first }
before do
page.find_by_id("delete_type_de_champ_#{type_de_champ.id}").click
wait_for_ajax
procedure.reload
end
scenario 'deletes type de champ' do
expect(procedure.types_de_champ.count).to eq(1)
end
end
end
end end
end end
# context 'when create a new procedure' do
# before do
# visit new_admin_procedure_path
# end
# scenario 'page have form to created new type de champs' do
# expect(page).to have_css('#type_de_champ_0')
# expect(page).to have_css('input[name="procedure[new_type_de_champ[0]][libelle]"]')
# expect(page).to have_css('select[name="procedure[new_type_de_champ[0]][type_champ]"]')
# expect(page).to have_css('textarea[name="procedure[new_type_de_champ[0]][description]"]')
# expect(page).to have_css('input[name="procedure[new_type_de_champ[0]][order_place]"]', visible: false)
# expect(page).to have_css('input[name="procedure[new_type_de_champ[0]][_destroy]"]', visible: false)
# expect(page).to have_css('#order_type_de_champ_0_button', visible: false);
# expect(page).to have_css('#order_type_de_champ_0_up_procedure', visible: false);
# expect(page).to have_css('#order_type_de_champ_0_down_procedure', visible: false);
# expect(page).to have_css('#new_type_de_champ #add_type_de_champ_button')
# end
# context 'when user add a new champs type' do
# before do
# page.find_by_id('procedure_new_type_de_champ_0__libelle').set 'Libelle de test'
# page.find_by_id('procedure_new_type_de_champ_0__description').set 'Description de test'
# page.click_on 'add_type_de_champ_procedure'
# end
# scenario 'a new champs type line is appeared with increment index id' do
# expect(page).to have_css('#type_de_champ_1')
# expect(page).to have_css('input[name="procedure[new_type_de_champ[1]][libelle]"]')
# expect(page).to have_css('select[name="procedure[new_type_de_champ[1]][type_champ]"]')
# expect(page).to have_css('textarea[name="procedure[new_type_de_champ[1]][description]"]')
# expect(page).to have_css('input[name="procedure[new_type_de_champ[1]][order_place]"]', visible: false)
# expect(page).to have_css('input[name="procedure[new_type_de_champ[1]][_destroy]"]', visible: false)
# expect(page).to have_css('#order_type_de_champ_1_button', visible: false);
# expect(page).to have_css('#order_type_de_champ_1_up_procedure', visible: false);
# expect(page).to have_css('#order_type_de_champ_1_down_procedure', visible: false);
# end
# scenario 'the first line is filled' do
# expect(page.find_by_id('procedure_new_type_de_champ_0__libelle').value).to eq('Libelle de test')
# expect(page.find_by_id('procedure_new_type_de_champ_0__description').value).to eq('Description de test')
# expect(page.find_by_id('procedure_new_type_de_champ_0__order_place', visible: false).value).to eq('1')
# end
# scenario 'the first line have new button delete' do
# expect(page).to have_css('#delete_type_de_champ_0_button')
# expect(page).to have_css('#delete_type_de_champ_0_procedure')
# end
# scenario 'the new line is empty' do
# expect(page.find_by_id('procedure_new_type_de_champ_1__libelle').value).to eq('')
# expect(page.find_by_id('procedure_new_type_de_champ_1__description').value).to eq('')
# expect(page.find_by_id('procedure_new_type_de_champ_1__order_place', visible: false).value).to eq('2')
# expect(page.find_by_id('procedure_new_type_de_champ_1___destroy', visible: false).value).to eq('false')
# end
# scenario 'the button Ajouter is at side new line' do
# expect(page).to have_css('#new_type_de_champ #type_de_champ_1 #add_type_de_champ_button')
# expect(page).not_to have_css('#type_de_champ_0 #add_type_de_champ_button')
# end
# end
# end
# end