# frozen_string_literal: true require 'spec_helper' describe Gitlab::JiraImport::IssuesImporter do let_it_be(:user) { create(:user) } let_it_be(:project) { create(:project) } let_it_be(:jira_import) { create(:jira_import_state, project: project) } let_it_be(:jira_service) { create(:jira_service, project: project) } subject { described_class.new(project) } before do stub_feature_flags(jira_issue_import: true) end describe '#imported_items_cache_key' do it_behaves_like 'raise exception if not implemented' it { expect(subject.imported_items_cache_key).to eq("jira-importer/already-imported/#{project.id}/issues") } end describe '#execute', :clean_gitlab_redis_cache do context 'when no returned issues' do it 'does not schedule any import jobs' do expect(subject).to receive(:fetch_issues).with(0).and_return([]) expect(subject).not_to receive(:already_imported?) expect(subject).not_to receive(:mark_as_imported) expect(Gitlab::JiraImport::ImportIssueWorker).not_to receive(:perform_async) job_waiter = subject.execute expect(job_waiter.jobs_remaining).to eq(0) expect(Gitlab::JiraImport.get_issues_next_start_at(project.id)).to eq(-1) end end context 'with results returned' do JiraIssue = Struct.new(:id) let_it_be(:jira_issue1) { JiraIssue.new(1) } let_it_be(:jira_issue2) { JiraIssue.new(2) } context 'when single page of results is returned' do before do stub_const("#{described_class.name}::BATCH_SIZE", 3) end it 'schedules 2 import jobs' do expect(subject).to receive(:fetch_issues).and_return([jira_issue1, jira_issue2]) expect(Gitlab::JiraImport::ImportIssueWorker).to receive(:perform_async).twice expect(Gitlab::Cache::Import::Caching).to receive(:set_add).twice.and_call_original expect(Gitlab::Cache::Import::Caching).to receive(:set_includes?).twice.and_call_original allow_next_instance_of(Gitlab::JiraImport::IssueSerializer) do |instance| allow(instance).to receive(:execute).and_return({ key: 'data' }) end job_waiter = subject.execute expect(job_waiter.jobs_remaining).to eq(2) expect(Gitlab::JiraImport.get_issues_next_start_at(project.id)).to eq(2) end end context 'when there is more than one page of results' do before do stub_const("#{described_class.name}::BATCH_SIZE", 2) end it 'schedules 3 import jobs' do expect(subject).to receive(:fetch_issues).with(0).and_return([jira_issue1, jira_issue2]) expect(Gitlab::JiraImport::ImportIssueWorker).to receive(:perform_async).twice.times expect(Gitlab::Cache::Import::Caching).to receive(:set_add).twice.times.and_call_original expect(Gitlab::Cache::Import::Caching).to receive(:set_includes?).twice.times.and_call_original allow_next_instance_of(Gitlab::JiraImport::IssueSerializer) do |instance| allow(instance).to receive(:execute).and_return({ key: 'data' }) end job_waiter = subject.execute expect(job_waiter.jobs_remaining).to eq(2) expect(Gitlab::JiraImport.get_issues_next_start_at(project.id)).to eq(2) end end context 'when duplicate results are returned' do before do stub_const("#{described_class.name}::BATCH_SIZE", 2) end it 'schedules 2 import jobs' do expect(subject).to receive(:fetch_issues).with(0).and_return([jira_issue1, jira_issue1]) expect(Gitlab::JiraImport::ImportIssueWorker).to receive(:perform_async).once expect(Gitlab::Cache::Import::Caching).to receive(:set_add).once.and_call_original expect(Gitlab::Cache::Import::Caching).to receive(:set_includes?).twice.times.and_call_original allow_next_instance_of(Gitlab::JiraImport::IssueSerializer) do |instance| allow(instance).to receive(:execute).and_return({ key: 'data' }) end job_waiter = subject.execute expect(job_waiter.jobs_remaining).to eq(1) expect(Gitlab::JiraImport.get_issues_next_start_at(project.id)).to eq(2) end end end end end