565ead6102
Ran: - git format-patch v9.2.2..v9.2.5 --stdout > patchfile.patch - git checkout -b 9-2-5-security-patch origin/v9.2.2 - git apply patchfile.patch - git commit - [Got the sha ref for the commit] - git checkout -b upstream-9-2-security master - git cherry-pick <SHA of the patchfile commit> - [Resolved conflicts] - git cherry-pick --continue
46 lines
1.4 KiB
Ruby
46 lines
1.4 KiB
Ruby
require 'spec_helper'
|
|
require Rails.root.join('db', 'post_migrate', '20170406111121_clean_upload_symlinks.rb')
|
|
|
|
describe CleanUploadSymlinks do
|
|
let(:migration) { described_class.new }
|
|
let(:test_dir) { File.join(Rails.root, "tmp", "tests", "move_uploads_test") }
|
|
let(:uploads_dir) { File.join(test_dir, "public", "uploads") }
|
|
let(:new_uploads_dir) { File.join(uploads_dir, "system") }
|
|
let(:original_path) { File.join(new_uploads_dir, 'user') }
|
|
let(:symlink_path) { File.join(uploads_dir, 'user') }
|
|
|
|
before do
|
|
FileUtils.remove_dir(test_dir) if File.directory?(test_dir)
|
|
FileUtils.mkdir_p(uploads_dir)
|
|
allow(migration).to receive(:base_directory).and_return(test_dir)
|
|
allow(migration).to receive(:say)
|
|
end
|
|
|
|
describe "#up" do
|
|
before do
|
|
FileUtils.mkdir_p(original_path)
|
|
FileUtils.ln_s(original_path, symlink_path)
|
|
end
|
|
|
|
it 'removes the symlink' do
|
|
migration.up
|
|
|
|
expect(File.symlink?(symlink_path)).to be(false)
|
|
end
|
|
end
|
|
|
|
describe '#down' do
|
|
before do
|
|
FileUtils.mkdir_p(File.join(original_path))
|
|
FileUtils.touch(File.join(original_path, 'dummy.file'))
|
|
end
|
|
|
|
it 'creates a symlink' do
|
|
expected_path = File.join(symlink_path, "dummy.file")
|
|
migration.down
|
|
|
|
expect(File.exist?(expected_path)).to be(true)
|
|
expect(File.symlink?(symlink_path)).to be(true)
|
|
end
|
|
end
|
|
end
|