Commit 831ceea9 authored by Felipe Artur's avatar Felipe Artur

Prevent rewritting plain links as embedded

Prevents rewritting plain image/video links as embedded when moving
issues.
parent b8293135
---
title: Prevent turning plain links into embedded when moving issues
merge_request: 31489
author:
type: fixed
...@@ -27,7 +27,15 @@ module Gitlab ...@@ -27,7 +27,15 @@ module Gitlab
klass = target_parent.is_a?(Namespace) ? NamespaceFileUploader : FileUploader klass = target_parent.is_a?(Namespace) ? NamespaceFileUploader : FileUploader
moved = klass.copy_to(file, target_parent) moved = klass.copy_to(file, target_parent)
moved.markdown_link
moved_markdown = moved.markdown_link
# Prevents rewrite of plain links as embedded
if was_embedded?(markdown)
moved_markdown
else
moved_markdown.sub(/\A!/, "")
end
end end
end end
...@@ -43,6 +51,10 @@ module Gitlab ...@@ -43,6 +51,10 @@ module Gitlab
referenced_files.compact.select(&:exists?) referenced_files.compact.select(&:exists?)
end end
def was_embedded?(markdown)
markdown.starts_with?("!")
end
private private
def find_file(project, secret, file) def find_file(project, secret, file)
......
...@@ -55,6 +55,17 @@ describe Gitlab::Gfm::UploadsRewriter do ...@@ -55,6 +55,17 @@ describe Gitlab::Gfm::UploadsRewriter do
end end
end end
it 'does not rewrite plain links as embedded' do
embedded_link = image_uploader.markdown_link
plain_image_link = embedded_link.sub(/\A!/, "")
text = "#{plain_image_link} and #{embedded_link}"
moved_text = described_class.new(text, old_project, user).rewrite(new_project)
expect(moved_text.scan(/!\[.*?\]/).count).to eq(1)
expect(moved_text.scan(/\A\[.*?\]/).count).to eq(1)
end
context "file are stored locally" do context "file are stored locally" do
include_examples "files are accessible" include_examples "files are accessible"
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment