Commit 8c59b4d7 authored by Sean McGivern's avatar Sean McGivern

Merge branch 'sh-fix-issue-63910' into 'master'

Fix attachments using the wrong URLs in e-mails

Closes #63910

See merge request gitlab-org/gitlab-ce!30197
parents d3cc7b19 0e341a6e
---
title: Fix attachments using the wrong URLs in e-mails
merge_request: 30197
author:
type: fixed
...@@ -56,10 +56,10 @@ module Banzai ...@@ -56,10 +56,10 @@ module Banzai
def process_link_to_upload_attr(html_attr) def process_link_to_upload_attr(html_attr)
path_parts = [Addressable::URI.unescape(html_attr.value)] path_parts = [Addressable::URI.unescape(html_attr.value)]
if group if project
path_parts.unshift(relative_url_root, 'groups', group.full_path, '-')
elsif project
path_parts.unshift(relative_url_root, project.full_path) path_parts.unshift(relative_url_root, project.full_path)
elsif group
path_parts.unshift(relative_url_root, 'groups', group.full_path, '-')
else else
path_parts.unshift(relative_url_root) path_parts.unshift(relative_url_root)
end end
......
...@@ -50,6 +50,43 @@ describe MarkupHelper do ...@@ -50,6 +50,43 @@ describe MarkupHelper do
expect(markdown(actual, project: second_project)).to match(expected) expect(markdown(actual, project: second_project)).to match(expected)
end end
end end
describe 'uploads' do
let(:text) { "![ImageTest](/uploads/test.png)" }
let(:group) { create(:group) }
subject { helper.markdown(text) }
describe 'inside a project' do
it 'renders uploads relative to project' do
expect(subject).to include("#{project.full_path}/uploads/test.png")
end
end
describe 'inside a group' do
before do
helper.instance_variable_set(:@group, group)
helper.instance_variable_set(:@project, nil)
end
it 'renders uploads relative to the group' do
expect(subject).to include("#{group.full_path}/-/uploads/test.png")
end
end
describe "with a group in the context" do
let(:project_in_group) { create(:project, group: group) }
before do
helper.instance_variable_set(:@group, group)
helper.instance_variable_set(:@project, project_in_group)
end
it 'renders uploads relative to project' do
expect(subject).to include("#{project_in_group.path_with_namespace}/uploads/test.png")
end
end
end
end end
describe '#markdown_field' do describe '#markdown_field' do
......
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