Commit dc90e040 authored by GitLab Bot's avatar GitLab Bot

Add latest changes from gitlab-org/gitlab@13-0-stable-ee

parent 6a4f265c
...@@ -89,9 +89,10 @@ export default class Issue { ...@@ -89,9 +89,10 @@ export default class Issue {
initIssueBtnEventListeners() { initIssueBtnEventListeners() {
const issueFailMessage = __('Unable to update this issue at this time.'); const issueFailMessage = __('Unable to update this issue at this time.');
return $(document).on( // NOTE: data attribute seems unnecessary but is actually necessary
return $('.js-issuable-buttons[data-action="close-reopen"]').on(
'click', 'click',
'.js-issuable-actions a.btn-close, .js-issuable-actions a.btn-reopen, a.btn-close-anyway', 'a.btn-close, a.btn-reopen, a.btn-close-anyway',
e => { e => {
e.preventDefault(); e.preventDefault();
e.stopImmediatePropagation(); e.stopImmediatePropagation();
...@@ -108,10 +109,7 @@ export default class Issue { ...@@ -108,10 +109,7 @@ export default class Issue {
} else { } else {
this.disableCloseReopenButton($button); this.disableCloseReopenButton($button);
const url = $button.data('close-reopen-url'); const url = $button.attr('href');
if (!url) {
return;
}
return axios return axios
.put(url) .put(url)
......
...@@ -102,7 +102,7 @@ module CacheMarkdownField ...@@ -102,7 +102,7 @@ module CacheMarkdownField
def updated_cached_html_for(markdown_field) def updated_cached_html_for(markdown_field)
return unless cached_markdown_fields.markdown_fields.include?(markdown_field) return unless cached_markdown_fields.markdown_fields.include?(markdown_field)
refresh_markdown_cache if attribute_invalidated?(cached_markdown_fields.html_field(markdown_field)) refresh_markdown_cache! if attribute_invalidated?(cached_markdown_fields.html_field(markdown_field))
cached_html_for(markdown_field) cached_html_for(markdown_field)
end end
......
...@@ -32,7 +32,7 @@ ...@@ -32,7 +32,7 @@
%a.btn.btn-default.float-right.d-block.d-sm-none.gutter-toggle.issuable-gutter-toggle.js-sidebar-toggle{ href: "#" } %a.btn.btn-default.float-right.d-block.d-sm-none.gutter-toggle.issuable-gutter-toggle.js-sidebar-toggle{ href: "#" }
= icon('angle-double-left') = icon('angle-double-left')
.detail-page-header-actions.js-issuable-actions .detail-page-header-actions.js-issuable-actions.js-issuable-buttons{ data: { "action": "close-reopen" } }
.clearfix.issue-btn-group.dropdown .clearfix.issue-btn-group.dropdown
%button.btn.btn-default.float-left.d-md-none.d-lg-none.d-xl-none{ type: "button", data: { toggle: "dropdown" } } %button.btn.btn-default.float-left.d-md-none.d-lg-none.d-xl-none{ type: "button", data: { toggle: "dropdown" } }
Options Options
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
.float-left.btn-group.prepend-left-10.issuable-close-dropdown.droplab-dropdown.js-issuable-close-dropdown .float-left.btn-group.prepend-left-10.issuable-close-dropdown.droplab-dropdown.js-issuable-close-dropdown
= link_to "#{display_button_action} #{display_issuable_type}", close_reopen_issuable_path(issuable), = link_to "#{display_button_action} #{display_issuable_type}", close_reopen_issuable_path(issuable),
method: button_method, class: "#{button_class} btn-#{button_action} #{(add_blocked_class ? 'btn-issue-blocked' : '')}", title: "#{display_button_action} #{display_issuable_type}", data: { qa_selector: 'close_issue_button', 'close-reopen-url': close_reopen_issuable_path(issuable) } method: button_method, class: "#{button_class} btn-#{button_action} #{(add_blocked_class ? 'btn-issue-blocked' : '')}", title: "#{display_button_action} #{display_issuable_type}", data: { qa_selector: 'close_issue_button' }
= button_tag type: 'button', class: "#{toggle_class} btn-#{button_action}-color", = button_tag type: 'button', class: "#{toggle_class} btn-#{button_action}-color",
data: { 'dropdown-trigger' => '#issuable-close-menu' }, 'aria-label' => _('Toggle dropdown') do data: { 'dropdown-trigger' => '#issuable-close-menu' }, 'aria-label' => _('Toggle dropdown') do
......
---
title: Fix issue and MR API performance regression when Markdown cache is stale
merge_request: 33235
author:
type: fixed
---
title: Fix close issue when user created the issue
merge_request: 33294
author:
type: fixed
...@@ -15,14 +15,14 @@ ...@@ -15,14 +15,14 @@
<g class="edgeLabels"></g> <g class="edgeLabels"></g>
<g class="nodes"> <g class="nodes">
<g <g
class="node js-issuable-actions btn-close clickable" class="node js-issuable-buttons btn-close clickable"
style="opacity: 1;" style="opacity: 1;"
id="A" id="A"
transform="translate(92.67500305175781,25.25)" transform="translate(92.67500305175781,25.25)"
title="click to PUT" title="click to PUT"
> >
<a <a
class="js-issuable-actions btn-close clickable" class="js-issuable-buttons btn-close clickable"
href="https://invalid" href="https://invalid"
rel="noopener" rel="noopener"
> >
......
...@@ -209,8 +209,8 @@ describe CacheMarkdownField, :clean_gitlab_redis_cache do ...@@ -209,8 +209,8 @@ describe CacheMarkdownField, :clean_gitlab_redis_cache do
thing.cached_markdown_version += 1 thing.cached_markdown_version += 1
end end
it 'calls #refresh_markdown_cache' do it 'calls #refresh_markdown_cache!' do
expect(thing).to receive(:refresh_markdown_cache) expect(thing).to receive(:refresh_markdown_cache!)
expect(thing.updated_cached_html_for(:description)).to eq(html) expect(thing.updated_cached_html_for(:description)).to eq(html)
end end
...@@ -227,8 +227,8 @@ describe CacheMarkdownField, :clean_gitlab_redis_cache do ...@@ -227,8 +227,8 @@ describe CacheMarkdownField, :clean_gitlab_redis_cache do
thing.try(:save) thing.try(:save)
end end
it 'does not call #refresh_markdown_cache' do it 'does not call #refresh_markdown_cache!' do
expect(thing).not_to receive(:refresh_markdown_cache) expect(thing).not_to receive(:refresh_markdown_cache!)
expect(thing.updated_cached_html_for(:description)).to eq(html) expect(thing.updated_cached_html_for(:description)).to eq(html)
end end
......
...@@ -80,25 +80,21 @@ RSpec.shared_examples 'a mentionable' do ...@@ -80,25 +80,21 @@ RSpec.shared_examples 'a mentionable' do
context 'when there are cached markdown fields' do context 'when there are cached markdown fields' do
before do before do
if subject.is_a?(CacheMarkdownField) skip unless subject.is_a?(CacheMarkdownField)
subject.refresh_markdown_cache
end
end end
it 'sends in cached markdown fields when appropriate' do it 'sends in cached markdown fields when appropriate' do
if subject.is_a?(CacheMarkdownField) && subject.extractors[author].blank? subject.extractors[author] = nil
expect_next_instance_of(Gitlab::ReferenceExtractor) do |ext| expect_next_instance_of(Gitlab::ReferenceExtractor) do |ext|
attrs = subject.class.mentionable_attrs.collect(&:first) & subject.cached_markdown_fields.markdown_fields attrs = subject.class.mentionable_attrs.collect(&:first) & subject.cached_markdown_fields.markdown_fields
attrs.each do |field| attrs.each do |field|
expect(ext).to receive(:analyze).with(subject.send(field), hash_including(rendered: anything)) expect(ext).to receive(:analyze).with(subject.send(field), hash_including(rendered: anything))
end
end end
end
expect(subject).not_to receive(:refresh_markdown_cache) expect(subject).to receive(:cached_markdown_fields).at_least(:once).and_call_original
expect(subject).to receive(:cached_markdown_fields).at_least(:once).and_call_original
subject.all_references(author) subject.all_references(author)
end
end end
end end
...@@ -126,26 +122,40 @@ RSpec.shared_examples 'an editable mentionable' do ...@@ -126,26 +122,40 @@ RSpec.shared_examples 'an editable mentionable' do
context 'when there are cached markdown fields' do context 'when there are cached markdown fields' do
before do before do
if subject.is_a?(CacheMarkdownField) skip unless subject.is_a?(CacheMarkdownField)
subject.refresh_markdown_cache
end
end
it 'refreshes markdown cache if necessary' do
subject.save! subject.save!
end
it 'refreshes markdown cache if necessary' do
set_mentionable_text.call('This is a text') set_mentionable_text.call('This is a text')
if subject.is_a?(CacheMarkdownField) && subject.extractors[author].blank? subject.extractors[author] = nil
expect_next_instance_of(Gitlab::ReferenceExtractor) do |ext| expect_next_instance_of(Gitlab::ReferenceExtractor) do |ext|
subject.cached_markdown_fields.markdown_fields.each do |field| subject.cached_markdown_fields.markdown_fields.each do |field|
expect(ext).to receive(:analyze).with(subject.send(field), hash_including(rendered: anything)) expect(ext).to receive(:analyze).with(subject.send(field), hash_including(rendered: anything))
end
end end
end
expect(subject).to receive(:refresh_markdown_cache) expect(subject).to receive(:refresh_markdown_cache).and_call_original
expect(subject).to receive(:cached_markdown_fields).at_least(:once).and_call_original expect(subject).to receive(:cached_markdown_fields).at_least(:once).and_call_original
subject.all_references(author)
end
context 'when the markdown cache is stale' do
before do
expect(subject).to receive(:latest_cached_markdown_version).at_least(:once) do
(Gitlab::MarkdownCache::CACHE_COMMONMARK_VERSION + 1) << 16
end
end
it 'persists the refreshed cache so that it does not have to be refreshed every time' do
expect(subject).to receive(:refresh_markdown_cache).once.and_call_original
subject.all_references(author)
subject.reload
subject.all_references(author) subject.all_references(author)
end end
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