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

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2023-02-20 16:49:51 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2023-02-20 16:49:51 +0300
commit71786ddc8e28fbd3cb3fcc4b3ff15e5962a1c82e (patch)
tree6a2d93ef3fb2d353bb7739e4b57e6541f51cdd71 /spec/services/import_csv
parenta7253423e3403b8c08f8a161e5937e1488f5f407 (diff)
Add latest changes from gitlab-org/gitlab@15-9-stable-eev15.9.0-rc42
Diffstat (limited to 'spec/services/import_csv')
-rw-r--r--spec/services/import_csv/base_service_spec.rb64
1 files changed, 64 insertions, 0 deletions
diff --git a/spec/services/import_csv/base_service_spec.rb b/spec/services/import_csv/base_service_spec.rb
new file mode 100644
index 00000000000..0c0ed40ff4d
--- /dev/null
+++ b/spec/services/import_csv/base_service_spec.rb
@@ -0,0 +1,64 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+RSpec.describe ImportCsv::BaseService, feature_category: :importers do
+ let_it_be(:user) { create(:user) }
+ let_it_be(:project) { create(:project) }
+ let_it_be(:csv_io) { double }
+
+ subject { described_class.new(user, project, csv_io) }
+
+ shared_examples 'abstract method' do |method, args|
+ it "raises NotImplemented error when #{method} is called" do
+ if args
+ expect { subject.send(method, args) }.to raise_error(NotImplementedError)
+ else
+ expect { subject.send(method) }.to raise_error(NotImplementedError)
+ end
+ end
+ end
+
+ it_behaves_like 'abstract method', :email_results_to_user
+ it_behaves_like 'abstract method', :attributes_for, "any"
+ it_behaves_like 'abstract method', :validate_headers_presence!, "any"
+ it_behaves_like 'abstract method', :create_object_class
+
+ describe '#detect_col_sep' do
+ context 'when header contains invalid separators' do
+ it 'raises error' do
+ header = 'Name&email'
+
+ expect { subject.send(:detect_col_sep, header) }.to raise_error(CSV::MalformedCSVError)
+ end
+ end
+
+ context 'when header is valid' do
+ shared_examples 'header with valid separators' do
+ let(:header) { "Name#{separator}email" }
+
+ it 'returns separator value' do
+ expect(subject.send(:detect_col_sep, header)).to eq(separator)
+ end
+ end
+
+ context 'with ; as separator' do
+ let(:separator) { ';' }
+
+ it_behaves_like 'header with valid separators'
+ end
+
+ context 'with \t as separator' do
+ let(:separator) { "\t" }
+
+ it_behaves_like 'header with valid separators'
+ end
+
+ context 'with , as separator' do
+ let(:separator) { ',' }
+
+ it_behaves_like 'header with valid separators'
+ end
+ end
+ end
+end