Welcome to mirror list, hosted at ThFree Co, Russian Federation.

references_pipeline_spec.rb « pipelines « projects « bulk_imports « lib « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ba4a11dcee8eba0815465e2282a42a35eb6e3f83 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe BulkImports::Projects::Pipelines::ReferencesPipeline, feature_category: :importers do
  let_it_be(:user) { create(:user) }
  let_it_be(:project) { create(:project) }
  let_it_be(:bulk_import) { create(:bulk_import, user: user) }

  let_it_be(:entity) do
    create(
      :bulk_import_entity,
      :project_entity,
      project: project,
      bulk_import: bulk_import,
      source_full_path: 'source/full/path'
    )
  end

  let_it_be(:tracker) { create(:bulk_import_tracker, entity: entity) }
  let_it_be(:context) { BulkImports::Pipeline::Context.new(tracker) }

  let_it_be(:issue) { create(:issue, project: project) }
  let_it_be(:merge_request) { create(:merge_request, source_project: project) }
  let_it_be(:issue_note) { create(:note, noteable: issue, project: project) }
  let_it_be(:merge_request_note) { create(:note, noteable: merge_request, project: project) }
  let_it_be(:system_note) { create(:note, project: project, system: true, noteable: issue) }

  let_it_be(:random_project) { create(:project) }
  let_it_be(:random_issue) { create(:issue, project: random_project) }
  let_it_be(:random_merge_request) { create(:merge_request, source_project: random_project) }
  let_it_be(:random_issue_note) { create(:note, noteable: random_issue, project: random_project) }
  let_it_be(:random_mr_note) { create(:note, noteable: random_merge_request, project: random_project) }
  let_it_be(:random_system_note) { create(:note, system: true, noteable: random_issue, project: random_project) }

  let(:delay) { described_class::DELAY }

  subject(:pipeline) { described_class.new(context) }

  before do
    allow(subject).to receive(:set_source_objects_counter)
  end

  describe '#run' do
    it "enqueues TransformReferencesWorker for the project's issues, mrs and their notes" do
      expect(BulkImports::TransformReferencesWorker).to receive(:perform_in)
        .with(delay, [issue.id], 'Issue', tracker.id)

      expect(BulkImports::TransformReferencesWorker).to receive(:perform_in)
        .with(delay * 2, array_including([issue_note.id, system_note.id]), 'Note', tracker.id)

      expect(BulkImports::TransformReferencesWorker).to receive(:perform_in)
        .with(delay * 3, [merge_request.id], 'MergeRequest', tracker.id)

      expect(BulkImports::TransformReferencesWorker).to receive(:perform_in)
        .with(delay * 4, [merge_request_note.id], 'Note', tracker.id)

      subject.run
    end

    it 'does not enqueue objects that do not belong to the project' do
      expect(BulkImports::TransformReferencesWorker).not_to receive(:perform_in)
        .with(anything, [random_issue.id], 'Issue', tracker.id)

      expect(BulkImports::TransformReferencesWorker).not_to receive(:perform_in)
        .with(anything, array_including([random_issue_note.id, random_system_note.id]), 'Note', tracker.id)

      expect(BulkImports::TransformReferencesWorker).not_to receive(:perform_in)
        .with(anything, [random_merge_request.id], 'MergeRequest', tracker.id)

      expect(BulkImports::TransformReferencesWorker).not_to receive(:perform_in)
        .with(anything, [random_mr_note.id], 'Note', tracker.id)

      subject.run
    end
  end
end