File: project_import_data_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (73 lines) | stat: -rw-r--r-- 1,959 bytes parent folder | download
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
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe ProjectImportData do
  describe '#merge_data' do
    it 'writes the Hash to the attribute if it is nil' do
      row = described_class.new

      row.merge_data('number' => 10)

      expect(row.data).to eq({ 'number' => 10 })
    end

    it 'merges the Hash into an existing Hash if one was present' do
      row = described_class.new(data: { 'number' => 10 })

      row.merge_data('foo' => 'bar')

      expect(row.data).to eq({ 'number' => 10, 'foo' => 'bar' })
    end
  end

  describe '#merge_credentials' do
    it 'writes the Hash to the attribute if it is nil' do
      row = described_class.new

      row.merge_credentials('number' => 10)

      expect(row.credentials).to eq({ 'number' => 10 })
    end

    it 'merges the Hash into an existing Hash if one was present' do
      row = described_class.new

      row.credentials = { 'number' => 10 }
      row.merge_credentials('foo' => 'bar')

      expect(row.credentials).to eq({ 'number' => 10, 'foo' => 'bar' })
    end
  end

  describe '#clear_credentials' do
    it 'clears out the Hash' do
      row = described_class.new

      row.merge_credentials('number' => 10)
      row.clear_credentials

      expect(row.credentials).to eq({})
    end
  end

  describe '#user_mapping_enabled?' do
    it 'returns user_contribution_mapping_enabled when present in data' do
      import_data = described_class.new(data: { 'user_contribution_mapping_enabled' => true })

      expect(import_data.user_mapping_enabled?).to be(true)
    end

    it 'returns false when user_contribution_mapping_enabled is not present in data' do
      import_data = described_class.new(data: { 'number' => 10 })

      expect(import_data.user_mapping_enabled?).to be(false)
    end

    it 'returns false when data is nil' do
      import_data = described_class.new

      expect(import_data.user_mapping_enabled?).to be(false)
    end
  end
end