Commit 035453e3 authored by Alexandru Croitor's avatar Alexandru Croitor

Add spec for case when start_at param not provided or nil

parent ea90cf7c
...@@ -22,7 +22,7 @@ module Mutations ...@@ -22,7 +22,7 @@ module Mutations
def resolve(project_path:, start_at: 0) def resolve(project_path:, start_at: 0)
project = authorized_find!(full_path: project_path) project = authorized_find!(full_path: project_path)
service_response = ::JiraImport::UsersImporter.new(context[:current_user], project, start_at).execute service_response = ::JiraImport::UsersImporter.new(context[:current_user], project, start_at.to_i).execute
{ {
jira_users: service_response.payload, jira_users: service_response.payload,
......
...@@ -8,15 +8,17 @@ RSpec.describe 'Importing Jira Users' do ...@@ -8,15 +8,17 @@ RSpec.describe 'Importing Jira Users' do
let_it_be(:user) { create(:user) } let_it_be(:user) { create(:user) }
let_it_be(:project) { create(:project) } let_it_be(:project) { create(:project) }
let(:importer) { instance_double(JiraImport::UsersImporter) }
let(:project_path) { project.full_path } let(:project_path) { project.full_path }
let(:start_at) { 7 } let(:start_at) { 7 }
let(:variables) do
let(:mutation) do {
variables = {
start_at: start_at, start_at: start_at,
project_path: project_path project_path: project_path
} }
end
let(:mutation) do
graphql_mutation(:jira_import_users, variables) graphql_mutation(:jira_import_users, variables)
end end
...@@ -65,9 +67,38 @@ RSpec.describe 'Importing Jira Users' do ...@@ -65,9 +67,38 @@ RSpec.describe 'Importing Jira Users' do
end end
end end
context 'when all params and permissions are ok' do context 'with start_at' do
let(:importer) { instance_double(JiraImport::UsersImporter) } RSpec.shared_examples 'start users import at zero' do
it 'returns imported users' do
users = [{ jira_account_id: '12a', jira_display_name: 'user 1' }]
result = ServiceResponse.success(payload: users)
expect(importer).to receive(:execute).and_return(result)
expect(JiraImport::UsersImporter).to receive(:new).with(current_user, project, 0).and_return(importer)
post_graphql_mutation(mutation, current_user: current_user)
end
end
context 'when nil' do
let(:variables) do
{
start_at: nil,
project_path: project_path
}
end
it_behaves_like 'start users import at zero'
end
context 'when not provided' do
let(:variables) { { project_path: project_path } }
it_behaves_like 'start users import at zero'
end
end
context 'when all params and permissions are ok' do
before do before do
expect(JiraImport::UsersImporter).to receive(:new).with(current_user, project, 7) expect(JiraImport::UsersImporter).to receive(:new).with(current_user, project, 7)
.and_return(importer) .and_return(importer)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment