Commit 8e512ece authored by Mark Chao's avatar Mark Chao

Merge branch '31065-gmh-add-size-over-metrics' into 'master'

Adding initial tracking for file size highlight limits

See merge request gitlab-org/gitlab!61273
parents e9eee696 61875426
---
name: track_file_size_over_highlight_limit
introduced_by_url: https://gitlab.com/gitlab-org/gitlab/-/merge_requests/61273
rollout_issue_url: https://gitlab.com/gitlab-org/gitlab/-/issues/330374
milestone: '13.12'
type: development
group: group::code review
default_enabled: false
...@@ -11,7 +11,11 @@ module Gitlab ...@@ -11,7 +11,11 @@ module Gitlab
end end
def self.too_large?(size) def self.too_large?(size)
size.to_i > Gitlab.config.extra['maximum_text_highlight_size_kilobytes'] return false unless size.to_i > Gitlab.config.extra['maximum_text_highlight_size_kilobytes']
over_highlight_size_limit.increment(source: "text highlighter") if Feature.enabled?(:track_file_size_over_highlight_limit)
true
end end
attr_reader :blob_name attr_reader :blob_name
...@@ -96,5 +100,12 @@ module Gitlab ...@@ -96,5 +100,12 @@ module Gitlab
'Counts the times highlights have timed out' 'Counts the times highlights have timed out'
) )
end end
def self.over_highlight_size_limit
@over_highlight_size_limit ||= Gitlab::Metrics.counter(
:over_highlight_size_limit,
'Count the times files have been over the highlight size limit'
)
end
end end
end end
...@@ -46,13 +46,21 @@ RSpec.describe Gitlab::Highlight do ...@@ -46,13 +46,21 @@ RSpec.describe Gitlab::Highlight do
expect(result).to eq(%[<span id="LC1" class="line" lang="plaintext">plain text contents</span>]) expect(result).to eq(%[<span id="LC1" class="line" lang="plaintext">plain text contents</span>])
end end
it 'returns plain version for long content' do context 'when content is too long to be highlighted' do
let(:result) { described_class.highlight(file_name, content) } # content is 44 bytes
before do
stub_config(extra: { 'maximum_text_highlight_size_kilobytes' => 0.0001 } ) # 1.024 bytes stub_config(extra: { 'maximum_text_highlight_size_kilobytes' => 0.0001 } ) # 1.024 bytes
end
result = described_class.highlight(file_name, content) # content is 44 bytes it 'increments the metric for oversized files' do
expect { result }.to change { over_highlight_size_limit('text highlighter') }.by(1)
end
it 'returns plain version for long content' do
expect(result).to eq(%[<span id="LC1" class="line" lang="">(make-pathname :defaults name</span>\n<span id="LC2" class="line" lang="">:type "assem")</span>]) expect(result).to eq(%[<span id="LC1" class="line" lang="">(make-pathname :defaults name</span>\n<span id="LC2" class="line" lang="">:type "assem")</span>])
end end
end
it 'highlights multi-line comments' do it 'highlights multi-line comments' do
result = described_class.highlight(file_name, multiline_content) result = described_class.highlight(file_name, multiline_content)
...@@ -168,4 +176,11 @@ RSpec.describe Gitlab::Highlight do ...@@ -168,4 +176,11 @@ RSpec.describe Gitlab::Highlight do
.counter(:highlight_timeout, 'Counts the times highlights have timed out') .counter(:highlight_timeout, 'Counts the times highlights have timed out')
.get(source: source) .get(source: source)
end end
def over_highlight_size_limit(source)
Gitlab::Metrics
.counter(:over_highlight_size_limit,
'Count the times text has been over the highlight size limit')
.get(source: source)
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