spec/controllers/fe/admin/elements_controller_spec.rb in fe-0.0.4 vs spec/controllers/fe/admin/elements_controller_spec.rb in fe-1.0.0

- old
+ new

@@ -1,4 +1,204 @@ require 'rails_helper' -describe Fe::Admin::ElementsController do +describe Fe::Admin::ElementsController, type: :controller do + context '#show' do + it 'should work' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element) + create(:page_element, element: element, page: page) + + xhr :get, :edit, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + expect(assigns(:element)).to eq(element) + end + end + context '#new' do + it 'should work' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + + xhr :get, :new, element_type: 'Fe::TextField', element: { style: 'style' }, question_sheet_id: question_sheet.id, page_id: page.id + expect(assigns(:questions)).to eq([element]) + end + end + context '#use_existing' do + it 'should work' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + + xhr :get, :use_existing, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + expect(assigns(:page_element)).to_not be_nil + end + it 'should not put the same question on a questionnaire twice' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + + xhr :get, :use_existing, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + expect(assigns(:page_element)).to be_nil + end + end + context '#create' do + it 'should work' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + + expect { + xhr :post, :create, element_type: 'Fe::TextField', element: { style: 'style' }, question_sheet_id: question_sheet.id, page_id: page.id + }.to change{Fe::Element.count}.by(1) + + expect(assigns(:page_element)).to_not be_nil + new_element = Fe::Element.last + expect(assigns(:page_element).element).to eq(new_element) + expect(assigns(:page_element).page).to eq(page) + end + it 'should handle error saving element' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + + expect { + xhr :post, :create, element_type: 'Fe::TextField', element: { slug: "Illegal Chars: #@$!" }, question_sheet_id: question_sheet.id, page_id: page.id + }.to change{Fe::Element.count}.by(0) + + expect(assigns(:page_element)).to be_nil + expect(response).to render_template('error.js.erb') + end + end + context '#update' do + it 'should work' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + + xhr :put, :update, element: { style: 'style' }, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + + expect(assigns(:element)).to eq(element) + expect(assigns(:element).style).to eq('style') + end + it 'should handle error saving element' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + + xhr :put, :update, element: { slug: "Illegal Chars: #@$!" }, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + expect(assigns(:element)).to eq(element) + expect(response).to render_template('error.js.erb') + end + end + context '#destroy' do + it 'should destroy the element when it is not used in any other pages' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + + xhr :delete, :destroy, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + + expect(Fe::PageElement.find_by(page_id: page.id, element_id: element.id)).to be_nil + expect(Fe::Element.find_by(id: element.id)).to be_nil + end + it 'should not destroy the element when it is not used in any other pages, but it has answers' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + create(:answer, question: element, value: 'answer here', answer_sheet: answer_sheet) + + xhr :delete, :destroy, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + + expect(Fe::PageElement.find_by(page_id: page.id, element_id: element.id)).to be_nil + expect(Fe::Element.find_by(id: element.id)).to_not be_nil + end + it 'should not destroy the element when it has no answers, but is being used in another page' do + answer_sheet = create(:answer_sheet) + page = create(:page) + page2 = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + create(:page_element, element: element, page: page) + create(:page_element, element: element, page: page2) + + xhr :delete, :destroy, question_sheet_id: question_sheet.id, page_id: page.id, id: element.id + + expect(Fe::PageElement.find_by(page_id: page.id, element_id: element.id)).to be_nil + expect(Fe::Element.find_by(id: element.id)).to_not be_nil + end + end + + context '#reorder' do + it 'should work inside a question grid' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + element2 = create(:text_field_element, style: 'style') + element3 = create(:question_grid, style: 'style') + element4 = create(:text_field_element, style: 'style', question_grid_id: element3.id) + element5 = create(:text_field_element, style: 'style', question_grid_id: element3.id) + create(:page_element, element: element, page: page) + create(:page_element, element: element2, page: page) + create(:page_element, element: element3, page: page) + + page_element_positions_before = Fe::PageElement.all.pluck(:position) + + xhr :post, :reorder, question_sheet_id: question_sheet.id, page_id: page.id, "questions_list_#{element3.id}" => [ element5.id, element4.id ] + # it shouldn't touch the page elements + expect(Fe::PageElement.all.pluck(:position)).to eq(page_element_positions_before) + # it should put a new order on the question grid elements + expect(element5.reload.position).to eq(1) + expect(element4.reload.position).to eq(2) + end + it 'should work outside a question grid' do + answer_sheet = create(:answer_sheet) + page = create(:page) + question_sheet = page.question_sheet + create(:answer_sheet_question_sheet, answer_sheet: answer_sheet, question_sheet: question_sheet) + element = create(:text_field_element, style: 'style') + element2 = create(:text_field_element, style: 'style') + element3 = create(:question_grid, style: 'style') + element4 = create(:text_field_element, style: 'style', question_grid_id: element3.id) + element5 = create(:text_field_element, style: 'style', question_grid_id: element3.id) + pe1 = create(:page_element, element: element, page: page) + pe2 = create(:page_element, element: element2, page: page) + pe3 = create(:page_element, element: element3, page: page) + + question_grid_elements_positions_before = element3.reload.elements.pluck(:position) + + xhr :post, :reorder, question_sheet_id: question_sheet.id, page_id: page.id, "questions_list" => [ element3.id, element.id, element2.id ] + # it shouldn't touch the question grid positions + expect(element3.reload.elements.pluck(:position)).to eq(question_grid_elements_positions_before) + # it should put a new order on the page elements + expect(pe3.reload.position).to eq(1) + expect(pe1.reload.position).to eq(2) + expect(pe2.reload.position).to eq(3) + end + end end