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 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152
|
# frozen_string_literal: true
require 'fast_spec_helper'
require 'gitlab/dangerfiles/spec_helper'
require_relative '../../../tooling/danger/database_dictionary'
RSpec.describe Tooling::Danger::DatabaseDictionary, feature_category: :shared do
include_context "with dangerfile"
let(:fake_danger) { DangerSpecHelper.fake_danger.include(described_class) }
subject(:database_dictionary) { fake_danger.new(helper: fake_helper) }
describe '#database_dictionary_files' do
let(:database_dictionary_files) do
[
'db/docs/ci_pipelines.yml',
'db/docs/projects.yml'
]
end
let(:other_files) do
[
'app/models/model.rb',
'app/assets/javascripts/file.js'
]
end
shared_examples 'an array of Found objects' do |change_type|
it 'returns an array of Found objects' do
expect(database_dictionary.database_dictionary_files(change_type: change_type))
.to contain_exactly(
an_instance_of(described_class::Found),
an_instance_of(described_class::Found)
)
expect(database_dictionary.database_dictionary_files(change_type: change_type).map(&:path))
.to eq(database_dictionary_files)
end
end
shared_examples 'an empty array' do |change_type|
it 'returns an array of Found objects' do
expect(database_dictionary.database_dictionary_files(change_type: change_type)).to be_empty
end
end
describe 'retrieves added database dictionary files' do
context 'with added added database dictionary files' do
let(:added_files) { database_dictionary_files }
include_examples 'an array of Found objects', :added
end
context 'without added added database dictionary files' do
let(:added_files) { other_files }
include_examples 'an empty array', :added
end
end
describe 'retrieves modified database dictionary files' do
context 'with modified modified database dictionary files' do
let(:modified_files) { database_dictionary_files }
include_examples 'an array of Found objects', :modified
end
context 'without modified modified database dictionary files' do
let(:modified_files) { other_files }
include_examples 'an empty array', :modified
end
end
describe 'retrieves deleted database dictionary files' do
context 'with deleted deleted database dictionary files' do
let(:deleted_files) { database_dictionary_files }
include_examples 'an array of Found objects', :deleted
end
context 'without deleted deleted database dictionary files' do
let(:deleted_files) { other_files }
include_examples 'an empty array', :deleted
end
end
end
describe described_class::Found do
let(:database_dictionary_path) { 'db/docs/ci_pipelines.yml' }
let(:gitlab_schema) { 'gitlab_ci' }
let(:yaml) do
{
'table_name' => 'ci_pipelines',
'classes' => ['Ci::Pipeline'],
'feature_categories' => ['continuous_integration'],
'description' => 'TODO',
'introduced_by_url' => 'https://gitlab.com/gitlab-org/gitlab/-/commit/c6ae290cea4b88ecaa9cfe0bc9d88e8fd32070c1',
'milestone' => '9.0',
'gitlab_schema' => gitlab_schema
}
end
let(:raw_yaml) { YAML.dump(yaml) }
subject(:found) { described_class.new(database_dictionary_path) }
before do
allow(File).to receive(:read).and_call_original
allow(File).to receive(:read).with(database_dictionary_path).and_return(raw_yaml)
end
described_class::ATTRIBUTES.each do |attribute|
describe "##{attribute}" do
it 'returns value from the YAML' do
expect(found.public_send(attribute)).to eq(yaml[attribute])
end
end
end
describe '#raw' do
it 'returns the raw YAML' do
expect(found.raw).to eq(raw_yaml)
end
end
describe '#ci_schema?' do
it { expect(found.ci_schema?).to be_truthy }
context 'with main schema' do
let(:gitlab_schema) { 'gitlab_main' }
it { expect(found.ci_schema?).to be_falsey }
end
end
describe '#main_schema?' do
it { expect(found.main_schema?).to be_falsey }
context 'with main schema' do
let(:gitlab_schema) { 'gitlab_main' }
it { expect(found.main_schema?).to be_truthy }
end
end
end
end
|