debian-mirror-gitlab/spec/lib/gitlab/import_export/recursive_merge_folders_spec.rb

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

57 lines
2 KiB
Ruby
Raw Normal View History

2023-01-13 00:05:48 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::ImportExport::RecursiveMergeFolders do
describe '.merge' do
2023-09-09 18:01:29 +05:30
it 'merges folder and ignores symlinks and files that share hard links' do
2023-01-13 00:05:48 +05:30
Dir.mktmpdir do |tmpdir|
source = "#{tmpdir}/source"
FileUtils.mkdir_p("#{source}/folder/folder")
FileUtils.touch("#{source}/file1.txt")
2023-09-09 18:01:29 +05:30
FileUtils.touch("#{source}/file_that_shares_hard_links.txt")
2023-01-13 00:05:48 +05:30
FileUtils.touch("#{source}/folder/file2.txt")
FileUtils.touch("#{source}/folder/folder/file3.txt")
FileUtils.ln_s("#{source}/file1.txt", "#{source}/symlink-file1.txt")
FileUtils.ln_s("#{source}/folder", "#{source}/symlink-folder")
2023-09-09 18:01:29 +05:30
FileUtils.link("#{source}/file_that_shares_hard_links.txt", "#{source}/hard_link.txt")
2023-01-13 00:05:48 +05:30
target = "#{tmpdir}/target"
FileUtils.mkdir_p("#{target}/folder/folder")
FileUtils.mkdir_p("#{target}/folderA")
FileUtils.touch("#{target}/fileA.txt")
described_class.merge(source, target)
expect(Dir.children("#{tmpdir}/target")).to match_array(%w[folder file1.txt folderA fileA.txt])
expect(Dir.children("#{tmpdir}/target/folder")).to match_array(%w[folder file2.txt])
expect(Dir.children("#{tmpdir}/target/folder/folder")).to match_array(%w[file3.txt])
end
end
it 'raises an error for invalid source path' do
Dir.mktmpdir do |tmpdir|
expect do
described_class.merge("#{tmpdir}/../", tmpdir)
end.to raise_error(Gitlab::Utils::PathTraversalAttackError)
end
end
it 'raises an error for source path outside temp dir' do
Dir.mktmpdir do |tmpdir|
expect do
described_class.merge('/', tmpdir )
end.to raise_error(StandardError, 'path / is not allowed')
end
end
it 'raises an error for invalid target path' do
Dir.mktmpdir do |tmpdir|
expect do
described_class.merge(tmpdir, "#{tmpdir}/../")
end.to raise_error(Gitlab::Utils::PathTraversalAttackError)
end
end
end
end