# frozen_string_literal: true # rubocop:disable Metrics/BlockLength require 'rails_helper' RSpec.describe 'Api::V2::ResultTextsController', type: :request do let(:user) { create(:user) } let(:team) { create(:team, created_by: user) } let(:project) { create(:project, team: team, created_by: user) } let(:experiment) { create(:experiment, :with_tasks, project: project, created_by: user) } let(:task) { experiment.my_modules.first } let(:result) { create(:result, user: user, my_module: task) } let(:result_archived) { create(:result, :archived, user: user, my_module: task) } let(:valid_headers) { { Authorization: "Bearer #{generate_token(user.id)}", 'Content-Type': 'application/json' } } let(:api_path) do api_v2_team_project_experiment_task_result_result_texts_path( team_id: team.id, project_id: project.id, experiment_id: experiment.id, task_id: task.id, result_id: result.id ) end describe 'GET result_texts, #index' do let!(:result_orderable_element) { create(:result_orderable_element, :result_text, result: result) } context 'when has valid params' do it 'renders 200' do get api_path, headers: valid_headers expect(response).to have_http_status(200) hash_body = nil expect { hash_body = json }.not_to raise_exception expect(hash_body[:data]).to match_array( JSON.parse( ActiveModelSerializers::SerializableResource .new(result.result_texts, each_serializer: Api::V2::ResultTextSerializer) .to_json )['data'] ) end end context 'when result is not found' do it 'renders 404' do get api_v2_team_project_experiment_task_result_result_texts_path( team_id: team.id, project_id: project.id, experiment_id: experiment.id, task_id: task.id, result_id: -1 ), headers: valid_headers expect(response).to have_http_status(404) end end end describe 'GET result_text, #show' do let(:result_text) { create(:result_text, result: result) } context 'when has valid params' do it 'renders 200' do hash_body = nil get api_v2_team_project_experiment_task_result_result_text_path( team_id: team.id, project_id: project.id, experiment_id: experiment.id, task_id: task.id, result_id: result.id, id: result_text.id ), headers: valid_headers expect(response).to have_http_status(200) expect { hash_body = json }.not_to raise_exception expect(hash_body[:data]).to match( JSON.parse( ActiveModelSerializers::SerializableResource .new(result_text, serializer: Api::V2::ResultTextSerializer) .to_json )['data'] ) end end end describe 'POST result_text, #create' do let(:action) do post(api_path, params: request_body.to_json, headers: valid_headers) end context 'when has valid params' do let(:request_body) do { data: { type: 'result_texts', attributes: { name: 'Result text', text: '
Hello!
' } } } end it 'creates new result_text' do expect { action }.to change { ResultText.count }.by(1) end it 'returns status 201' do action expect(response).to have_http_status(201) end it 'returns well-formatted response' do hash_body = nil action expect { hash_body = json }.not_to raise_exception expect(hash_body[:data]).to match( JSON.parse( ActiveModelSerializers::SerializableResource .new(ResultText.last, serializer: Api::V2::ResultTextSerializer) .to_json )['data'] ) end end context 'when has missing param' do let(:request_body) do { data: { type: 'result_texts', attributes: {} } } end it 'renders 400' do action expect(response).to have_http_status(400) end end context 'when include tinymce' do let(:request_body) do { data: { type: 'result_texts', attributes: { name: 'Result text', text: "Result text 1 " } }, included: [ { type: 'tiny_mce_assets', attributes: { file_data: ''\ 'AACCAIAAAD91JpzAAAACXBIWXMAAC4jAAAuIwF4pT92AAAAE0lE'\ 'QVQIHWP8//8/AwMDExADAQAkBgMBOOSShwAAAABJRU5ErkJggg==', file_token: '1', file_name: 'test.png' } } ] } end it 'Response with correct text result and TinyMCE images' do hash_body = nil action expect(response).to have_http_status 201 expect { hash_body = json }.not_to raise_exception expect(hash_body[:data]).to match( JSON.parse( ActiveModelSerializers::SerializableResource .new(ResultText.last, serializer: Api::V2::ResultTextSerializer) .to_json )['data'] ) expect(ResultText.last.text).to include "data-mce-token=\"#{Base62.encode(TinyMceAsset.last.id)}\"" end end end describe 'PATCH result_text, #update' do let(:result_text) { create(:result_text, result: result) } let(:result_text_archived) { create(:result_text, result: result_archived) } let(:action) do patch(api_v2_team_project_experiment_task_result_result_text_path( team_id: team.id, project_id: project.id, experiment_id: experiment.id, task_id: task.id, result_id: result.id, id: result_text.id ), params: request_body.to_json, headers: valid_headers) end let(:action_archived) do patch(api_v2_team_project_experiment_task_result_result_text_path( team_id: team.id, project_id: project.id, experiment_id: experiment.id, task_id: task.id, result_id: result_archived.id, id: result_text_archived.id ), params: request_body.to_json, headers: valid_headers) end context 'when has valid params' do let(:request_body) do { data: { type: 'result_texts', attributes: { name: 'Result text', text: '