Commit d92dcb89 authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab-ce master

parents 9654b125 6b02f502
...@@ -106,7 +106,7 @@ module Clusters ...@@ -106,7 +106,7 @@ module Clusters
def terminals(environment) def terminals(environment)
with_reactive_cache do |data| with_reactive_cache do |data|
pods = filter_by_label(data[:pods], app: environment.slug) pods = filter_by_label(data[:pods], app: environment.slug)
terminals = pods.flat_map { |pod| terminals_for_pod(api_url, actual_namespace, pod) } terminals = pods.flat_map { |pod| terminals_for_pod(api_url, actual_namespace, pod) }.compact
terminals.each { |terminal| add_terminal_auth(terminal, terminal_auth) } terminals.each { |terminal| add_terminal_auth(terminal, terminal_auth) }
end end
end end
......
...@@ -214,7 +214,7 @@ class Milestone < ActiveRecord::Base ...@@ -214,7 +214,7 @@ class Milestone < ActiveRecord::Base
end end
def reference_link_text(from = nil) def reference_link_text(from = nil)
self.title self.class.reference_prefix + self.title
end end
def milestoneish_ids def milestoneish_ids
......
---
title: Add % prefix to milestone reference links
merge_request: 23928
author:
type: changed
...@@ -59,7 +59,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -59,7 +59,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do
it 'links with adjacent text' do it 'links with adjacent text' do
doc = reference_filter("Milestone (#{reference}.)") doc = reference_filter("Milestone (#{reference}.)")
expect(doc.to_html).to match(%r(\(<a.+>#{milestone.name}</a>\.\))) expect(doc.to_html).to match(%r(\(<a.+>#{milestone.reference_link_text}</a>\.\)))
end end
it 'ignores invalid milestone IIDs' do it 'ignores invalid milestone IIDs' do
...@@ -80,12 +80,12 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -80,12 +80,12 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See #{reference}") doc = reference_filter("See #{reference}")
expect(doc.css('a').first.attr('href')).to eq urls.milestone_url(milestone) expect(doc.css('a').first.attr('href')).to eq urls.milestone_url(milestone)
expect(doc.text).to eq 'See gfm' expect(doc.text).to eq "See #{milestone.reference_link_text}"
end end
it 'links with adjacent text' do it 'links with adjacent text' do
doc = reference_filter("Milestone (#{reference}.)") doc = reference_filter("Milestone (#{reference}.)")
expect(doc.to_html).to match(%r(\(<a.+>#{milestone.name}</a>\.\))) expect(doc.to_html).to match(%r(\(<a.+>#{milestone.reference_link_text}</a>\.\)))
end end
it 'ignores invalid milestone names' do it 'ignores invalid milestone names' do
...@@ -106,12 +106,12 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -106,12 +106,12 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See #{reference}") doc = reference_filter("See #{reference}")
expect(doc.css('a').first.attr('href')).to eq urls.milestone_url(milestone) expect(doc.css('a').first.attr('href')).to eq urls.milestone_url(milestone)
expect(doc.text).to eq 'See gfm references' expect(doc.text).to eq "See #{milestone.reference_link_text}"
end end
it 'links with adjacent text' do it 'links with adjacent text' do
doc = reference_filter("Milestone (#{reference}.)") doc = reference_filter("Milestone (#{reference}.)")
expect(doc.to_html).to match(%r(\(<a.+>#{milestone.name}</a>\.\))) expect(doc.to_html).to match(%r(\(<a.+>#{milestone.reference_link_text}</a>\.\)))
end end
it 'ignores invalid milestone names' do it 'ignores invalid milestone names' do
...@@ -201,14 +201,14 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -201,14 +201,14 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See (#{reference}.)") doc = reference_filter("See (#{reference}.)")
expect(doc.css('a').first.text) expect(doc.css('a').first.text)
.to eq("#{milestone.name} in #{another_project.full_path}") .to eq("#{milestone.reference_link_text} in #{another_project.full_path}")
end end
it 'has valid text' do it 'has valid text' do
doc = reference_filter("See (#{reference}.)") doc = reference_filter("See (#{reference}.)")
expect(doc.text) expect(doc.text)
.to eq("See (#{milestone.name} in #{another_project.full_path}.)") .to eq("See (#{milestone.reference_link_text} in #{another_project.full_path}.)")
end end
it 'escapes the name attribute' do it 'escapes the name attribute' do
...@@ -217,7 +217,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -217,7 +217,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See #{reference}") doc = reference_filter("See #{reference}")
expect(doc.css('a').first.text) expect(doc.css('a').first.text)
.to eq "#{milestone.name} in #{another_project.full_path}" .to eq "#{milestone.reference_link_text} in #{another_project.full_path}"
end end
end end
...@@ -238,14 +238,14 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -238,14 +238,14 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See (#{reference}.)") doc = reference_filter("See (#{reference}.)")
expect(doc.css('a').first.text) expect(doc.css('a').first.text)
.to eq("#{milestone.name} in #{another_project.path}") .to eq("#{milestone.reference_link_text} in #{another_project.path}")
end end
it 'has valid text' do it 'has valid text' do
doc = reference_filter("See (#{reference}.)") doc = reference_filter("See (#{reference}.)")
expect(doc.text) expect(doc.text)
.to eq("See (#{milestone.name} in #{another_project.path}.)") .to eq("See (#{milestone.reference_link_text} in #{another_project.path}.)")
end end
it 'escapes the name attribute' do it 'escapes the name attribute' do
...@@ -254,7 +254,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -254,7 +254,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See #{reference}") doc = reference_filter("See #{reference}")
expect(doc.css('a').first.text) expect(doc.css('a').first.text)
.to eq "#{milestone.name} in #{another_project.path}" .to eq "#{milestone.reference_link_text} in #{another_project.path}"
end end
end end
...@@ -275,14 +275,14 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -275,14 +275,14 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See (#{reference}.)") doc = reference_filter("See (#{reference}.)")
expect(doc.css('a').first.text) expect(doc.css('a').first.text)
.to eq("#{milestone.name} in #{another_project.path}") .to eq("#{milestone.reference_link_text} in #{another_project.path}")
end end
it 'has valid text' do it 'has valid text' do
doc = reference_filter("See (#{reference}.)") doc = reference_filter("See (#{reference}.)")
expect(doc.text) expect(doc.text)
.to eq("See (#{milestone.name} in #{another_project.path}.)") .to eq("See (#{milestone.reference_link_text} in #{another_project.path}.)")
end end
it 'escapes the name attribute' do it 'escapes the name attribute' do
...@@ -291,7 +291,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -291,7 +291,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do
doc = reference_filter("See #{reference}") doc = reference_filter("See #{reference}")
expect(doc.css('a').first.text) expect(doc.css('a').first.text)
.to eq "#{milestone.name} in #{another_project.path}" .to eq "#{milestone.reference_link_text} in #{another_project.path}"
end end
end end
...@@ -346,7 +346,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do ...@@ -346,7 +346,7 @@ describe Banzai::Filter::MilestoneReferenceFilter do
milestone.update!(group: parent_group) milestone.update!(group: parent_group)
doc = reference_filter("See #{reference}") doc = reference_filter("See #{reference}")
expect(doc.css('a').first.text).to eq(milestone.name) expect(doc.css('a').first.text).to eq(milestone.reference_link_text)
end end
end end
......
...@@ -325,12 +325,13 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching ...@@ -325,12 +325,13 @@ describe Clusters::Platforms::Kubernetes, :use_clean_rails_memory_store_caching
context 'with valid pods' do context 'with valid pods' do
let(:pod) { kube_pod(app: environment.slug) } let(:pod) { kube_pod(app: environment.slug) }
let(:pod_with_no_terminal) { kube_pod(app: environment.slug, status: "Pending") }
let(:terminals) { kube_terminals(service, pod) } let(:terminals) { kube_terminals(service, pod) }
before do before do
stub_reactive_cache( stub_reactive_cache(
service, service,
pods: [pod, pod, kube_pod(app: "should-be-filtered-out")] pods: [pod, pod, pod_with_no_terminal, kube_pod(app: "should-be-filtered-out")]
) )
end end
......
...@@ -318,6 +318,15 @@ describe Milestone do ...@@ -318,6 +318,15 @@ describe Milestone do
end end
end end
describe '#reference_link_text' do
let(:project) { build_stubbed(:project, name: 'sample-project') }
let(:milestone) { build_stubbed(:milestone, iid: 1, project: project, name: 'milestone') }
it 'returns the title with the reference prefix' do
expect(milestone.reference_link_text).to eq '%milestone'
end
end
describe '#participants' do describe '#participants' do
let(:project) { build(:project, name: 'sample-project') } let(:project) { build(:project, name: 'sample-project') }
let(:milestone) { build(:milestone, iid: 1, project: project) } let(:milestone) { build(:milestone, iid: 1, project: project) }
......
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