debian-mirror-gitlab/spec/rubocop/cop/gitlab/duplicate_spec_location_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

101 lines
2.5 KiB
Ruby
Raw Normal View History

2020-04-22 19:07:51 +05:30
# frozen_string_literal: true
require 'fast_spec_helper'
require_relative '../../../../rubocop/cop/gitlab/duplicate_spec_location'
2021-03-08 18:12:59 +05:30
RSpec.describe RuboCop::Cop::Gitlab::DuplicateSpecLocation do
2020-04-22 19:07:51 +05:30
subject(:cop) { described_class.new }
let(:rails_root) { '../../../../' }
def full_path(path)
File.expand_path(File.join(rails_root, path), __dir__)
end
context 'Non-EE spec file' do
it 'registers no offenses' do
2020-06-23 00:09:42 +05:30
expect_no_offenses(<<~SOURCE, full_path('spec/foo_spec.rb'))
2020-04-22 19:07:51 +05:30
describe 'Foo' do
end
SOURCE
end
end
context 'Non-EE application file' do
it 'registers no offenses' do
2020-06-23 00:09:42 +05:30
expect_no_offenses(<<~SOURCE, full_path('app/models/blog_post.rb'))
2020-04-22 19:07:51 +05:30
class BlogPost
end
SOURCE
end
end
context 'EE application file' do
it 'registers no offenses' do
2020-06-23 00:09:42 +05:30
expect_no_offenses(<<~SOURCE, full_path('ee/app/models/blog_post.rb'))
2020-04-22 19:07:51 +05:30
class BlogPost
end
SOURCE
end
end
context 'EE spec file for EE only code' do
let(:spec_file_path) { full_path('ee/spec/controllers/foo_spec.rb') }
it 'registers no offenses' do
2020-06-23 00:09:42 +05:30
expect_no_offenses(<<~SOURCE, spec_file_path)
2020-04-22 19:07:51 +05:30
describe 'Foo' do
end
SOURCE
end
context 'there is a duplicate file' do
before do
allow(File).to receive(:exist?).and_call_original
allow(File).to receive(:exist?)
.with(full_path('ee/spec/controllers/ee/foo_spec.rb'))
.and_return(true)
end
it 'marks the describe as offending' do
2020-06-23 00:09:42 +05:30
expect_offense(<<~SOURCE, spec_file_path)
2020-04-22 19:07:51 +05:30
describe 'Foo' do
^^^^^^^^^^^^^^ Duplicate spec location in `ee/spec/controllers/ee/foo_spec.rb`.
end
SOURCE
end
end
end
context 'EE spec file for EE extension' do
let(:spec_file_path) { full_path('ee/spec/controllers/ee/foo_spec.rb') }
it 'registers no offenses' do
2020-06-23 00:09:42 +05:30
expect_no_offenses(<<~SOURCE, spec_file_path)
2020-04-22 19:07:51 +05:30
describe 'Foo' do
end
SOURCE
end
context 'there is a duplicate file' do
before do
allow(File).to receive(:exist?).and_call_original
allow(File).to receive(:exist?)
.with(full_path('ee/spec/controllers/foo_spec.rb'))
.and_return(true)
end
it 'marks the describe as offending' do
2020-06-23 00:09:42 +05:30
expect_offense(<<~SOURCE, spec_file_path)
2020-04-22 19:07:51 +05:30
describe 'Foo' do
^^^^^^^^^^^^^^ Duplicate spec location in `ee/spec/controllers/foo_spec.rb`.
end
SOURCE
end
end
end
end