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