Add project controller unit tests [SCI-2732]

This commit is contained in:
Matej Zrimšek 2018-10-10 00:09:32 +02:00
parent e5129160fe
commit 4bf1d904b7
3 changed files with 177 additions and 3 deletions

View file

@ -96,6 +96,6 @@ Rails.application.configure do
# disable sign in with LinkedIn account
config.x.linkedin_signin_enabled = false
# prevents compile assets
config.assets.compile = false
# enable assets compiling
config.assets.compile = true
end

View file

@ -0,0 +1,174 @@
# frozen_string_literal: true
require 'rails_helper'
describe ProjectsController, type: :controller do
login_user
render_views
PROJECTS_CNT = 26
time = Time.new(2015, 8, 1, 14, 35, 0)
let!(:user) { User.first }
let!(:team) { create :team, created_by: user }
let!(:user_team) { create :user_team, team: team, user: user }
let!(:projects_overview) do
ProjectsOverviewService.new(team, user)
end
let!(:project_1) do
create :project, name: 'test project D', visibility: 1, team: team,
archived: false, created_at: time.advance(hours: 2),
created_by: user
end
let!(:project_2) do
create :project, name: 'test project B', visibility: 1, team: team,
archived: true, created_at: time, created_by: user
end
let!(:project_3) do
create :project, name: 'test project C', visibility: 1, team: team,
archived: false, created_at: time.advance(hours: 3),
created_by: user
end
let!(:project_4) do
create :project, name: 'test project A', visibility: 1, team: team,
archived: true, created_at: time.advance(hours: 1),
created_by: user
end
let!(:project_5) do
create :project, name: 'test project E', visibility: 1, team: team,
archived: true, created_at: time.advance(hours: 5),
created_by: user
end
let!(:project_6) do
create :project, name: 'test project F', visibility: 0, team: team,
archived: false, created_at: time.advance(hours: 4),
created_by: user
end
(7..PROJECTS_CNT).each do |i|
let!("project_#{i}") do
create :project, name: "test project #{(64 + i).chr}",
visibility: 1,
team: team, archived: i % 2,
created_at: time.advance(hours: 6, minutes: i),
created_by: user
end
end
(1..PROJECTS_CNT).each do |i|
let!("user_projects_#{i}") do
create :user_project, project: eval("project_#{i}"), user: user
end
end
describe '#index' do
context 'in JSON format' do
it 'returns success response' do
params = { team: team.id, sort: 'atoz' }
get :index, params: params, format: :json
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'application/json'
end
end
end
describe '#index_dt' do
context 'in JSON format' do
it 'returns success response' do
params = { start: 1, length: 2,
order: { '0': { dir: 'ASC', column: '2' } } }
get :index_dt, params: params, format: :json
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'application/json'
end
end
end
describe '#archive' do
context 'in JSON format' do
it 'returns success response' do
params = { team: team.id, sort: 'atoz' }
get :archive, params: params, format: :json
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'application/json'
end
end
end
describe '#create' do
context 'in JSON format' do
it 'returns success response, then unprocessable_entity on second run' do
params = { project: { name: 'test project A1', team_id: team.id,
visibility: 'visible', archived: false } }
get :create, params: params, format: :json
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'application/json'
get :create, params: params, format: :json
expect(response).to have_http_status(:unprocessable_entity)
expect(response.content_type).to eq 'application/json'
end
end
end
describe '#edit' do
context 'in JSON format' do
it 'returns success response' do
params = { id: project_1.id }
get :edit, params: params, format: :json
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'application/json'
end
end
end
describe '#update' do
context 'in HTML format' do
it 'returns redirect response' do
params = { id: project_1.id,
project: { name: 'test project A1', team_id: team.id,
visibility: 'visible' } }
put :update, params: params
expect(response).to have_http_status(:redirect)
expect(response.content_type).to eq 'text/html'
end
end
end
describe '#show' do
context 'in HTML format' do
it 'returns success response' do
params = { id: project_1.id, sort: 'old',
project: { name: 'test project A1', team_id: team.id,
visibility: 'visible' } }
get :show, params: params
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'text/html'
end
end
end
describe '#notifications' do
context 'in JSON format' do
it 'returns success response' do
params = { id: project_1.id,
project: { name: 'test project A1', team_id: team.id,
visibility: 'visible' } }
get :notifications, format: :json, params: params
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'application/json'
end
end
end
describe '#experiment_archive' do
context 'in HTML format' do
it 'returns success response' do
params = { id: project_1.id,
project: { name: 'test project A1', team_id: team.id,
visibility: 'visible' } }
get :experiment_archive, params: params
expect(response).to have_http_status(:success)
expect(response.content_type).to eq 'text/html'
end
end
end
end

View file

@ -1,4 +1,4 @@
require 'rails_helper'
# frozen_string_literal: true
describe RepositoryDatatableService do
let!(:team) { create :team }