scinote-web/spec/services/project_json_export_service_spec.rb

86 lines
3.2 KiB
Ruby

require 'rails_helper'
describe ProjectsJsonExportService do
before :all do
@user = create(:user)
@team = create(:team, created_by: @user)
@accessible_project_1 = create(:project, name: Faker::Name.unique.name, created_by: @user, team: @team)
@accessible_project_2 = create(:project, name: Faker::Name.unique.name, created_by: @user, team: @team)
@unaccessible_project = create(:project, name: Faker::Name.unique.name, created_by: @user, team: @team)
@accessible_experiment_1 = create(:experiment, created_by: @user,
last_modified_by: @user, project: @accessible_project_1)
@accessible_experiment_2 = create(:experiment, created_by: @user,
last_modified_by: @user, project: @accessible_project_2)
@unaccessible_experiment = create(:experiment, created_by: @user,
last_modified_by: @user, project: @unaccessible_project)
@accessible_task_1 = create(:my_module, :with_due_date, created_by: @user,
last_modified_by: @user, experiment: @accessible_experiment_1)
@accessible_task_2 = create(:my_module, :with_due_date, created_by: @user,
last_modified_by: @user, experiment: @accessible_experiment_2)
@unaccessible_task = create(:my_module, :with_due_date, created_by: @user,
last_modified_by: @user, experiment: @unaccessible_experiment)
@unaccessible_project.user_assignments.destroy_all
end
describe 'Generate project json' do
let(:action) do
ProjectsJsonExportService.new(task_ids, Faker::Internet.url, @user).generate_data
end
let(:one_project) do
[@accessible_task_1.id]
end
let(:multiple_projects) do
[@accessible_task_1.id, @accessible_task_2.id, @unaccessible_task.id]
end
let(:no_accessible_projects) do
[@unaccessible_task.id]
end
context 'One project' do
let(:task_ids) do
one_project
end
it 'Get response one project' do
response = action
expect(response.length).to eq 1
expect(response[0].keys).to contain_exactly('id', 'name', 'experiments')
expect(response[0]['experiments'].length).to eq 1
expect(response[0]['experiments'][0].keys).to contain_exactly('id', 'name', 'description', 'tasks')
expect(response[0]['experiments'][0]['tasks'].length).to eq 1
end
end
context 'Multiple projects' do
let(:task_ids) do
multiple_projects
end
it 'Get response multiple projects' do
response = action
expect(response.length).to eq 2
expect(response[0].keys).to contain_exactly('id', 'name', 'experiments')
expect(response[0]['experiments'].length).to eq 1
expect(response[0]['experiments'][0].keys).to contain_exactly('id', 'name', 'description', 'tasks')
expect(response[0]['experiments'][0]['tasks'].length).to eq 1
end
end
context 'Not accessible project' do
let(:task_ids) do
no_accessible_projects
end
it 'Get response for not accessible project' do
response = action
expect(response.length).to eq 0
end
end
end
end