2019-12-04 20:38:33 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'fast_spec_helper'
|
|
|
|
require 'rubocop'
|
|
|
|
require_relative '../../../../rubocop/cop/scalability/file_uploads'
|
|
|
|
|
2020-06-23 00:09:42 +05:30
|
|
|
describe RuboCop::Cop::Scalability::FileUploads, type: :rubocop do
|
2019-12-04 20:38:33 +05:30
|
|
|
include CopHelper
|
|
|
|
include ExpectOffense
|
|
|
|
|
|
|
|
subject(:cop) { described_class.new }
|
2019-12-21 20:55:43 +05:30
|
|
|
|
2019-12-04 20:38:33 +05:30
|
|
|
let(:message) { 'Do not upload files without workhorse acceleration. Please refer to https://docs.gitlab.com/ee/development/uploads.html' }
|
|
|
|
|
|
|
|
context 'with required params' do
|
|
|
|
it 'detects File in types array' do
|
2020-06-23 00:09:42 +05:30
|
|
|
expect_offense(<<~PATTERN)
|
2019-12-04 20:38:33 +05:30
|
|
|
params do
|
|
|
|
requires :certificate, allow_blank: false, types: [String, File]
|
|
|
|
^^^^ #{message}
|
|
|
|
end
|
|
|
|
PATTERN
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'detects File as type argument' do
|
2020-06-23 00:09:42 +05:30
|
|
|
expect_offense(<<~PATTERN)
|
2019-12-04 20:38:33 +05:30
|
|
|
params do
|
|
|
|
requires :attachment, type: File
|
|
|
|
^^^^ #{message}
|
|
|
|
end
|
|
|
|
PATTERN
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with optional params' do
|
|
|
|
it 'detects File in types array' do
|
2020-06-23 00:09:42 +05:30
|
|
|
expect_offense(<<~PATTERN)
|
2019-12-04 20:38:33 +05:30
|
|
|
params do
|
|
|
|
optional :certificate, allow_blank: false, types: [String, File]
|
|
|
|
^^^^ #{message}
|
|
|
|
end
|
|
|
|
PATTERN
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'detects File as type argument' do
|
2020-06-23 00:09:42 +05:30
|
|
|
expect_offense(<<~PATTERN)
|
2019-12-04 20:38:33 +05:30
|
|
|
params do
|
|
|
|
optional :attachment, type: File
|
|
|
|
^^^^ #{message}
|
|
|
|
end
|
|
|
|
PATTERN
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|