summaryrefslogtreecommitdiff
path: root/spec/helpers/blob_helper_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/helpers/blob_helper_spec.rb')
-rw-r--r--spec/helpers/blob_helper_spec.rb114
1 files changed, 57 insertions, 57 deletions
diff --git a/spec/helpers/blob_helper_spec.rb b/spec/helpers/blob_helper_spec.rb
index 2bc3933809f..8be0a360b6d 100644
--- a/spec/helpers/blob_helper_spec.rb
+++ b/spec/helpers/blob_helper_spec.rb
@@ -1,31 +1,31 @@
-require 'spec_helper'
+require "spec_helper"
describe BlobHelper do
include TreeHelper
- describe '#highlight' do
- it 'wraps highlighted content' do
- expect(helper.highlight('test.rb', '52')).to eq(%q[<pre class="code highlight"><code><span id="LC1" class="line" lang="ruby"><span class="mi">52</span></span></code></pre>])
+ describe "#highlight" do
+ it "wraps highlighted content" do
+ expect(helper.highlight("test.rb", "52")).to eq('<pre class="code highlight"><code><span id="LC1" class="line" lang="ruby"><span class="mi">52</span></span></code></pre>')
end
- it 'handles plain version' do
- expect(helper.highlight('test.rb', '52', plain: true)).to eq(%q[<pre class="code highlight"><code><span id="LC1" class="line" lang="">52</span></code></pre>])
+ it "handles plain version" do
+ expect(helper.highlight("test.rb", "52", plain: true)).to eq('<pre class="code highlight"><code><span id="LC1" class="line" lang="">52</span></code></pre>')
end
end
describe "#sanitize_svg_data" do
- let(:input_svg_path) { File.join(Rails.root, 'spec', 'fixtures', 'unsanitized.svg') }
+ let(:input_svg_path) { File.join(Rails.root, "spec", "fixtures", "unsanitized.svg") }
let(:data) { File.read(input_svg_path) }
- let(:expected_svg_path) { File.join(Rails.root, 'spec', 'fixtures', 'sanitized.svg') }
+ let(:expected_svg_path) { File.join(Rails.root, "spec", "fixtures", "sanitized.svg") }
let(:expected) { File.read(expected_svg_path) }
- it 'retains essential elements' do
+ it "retains essential elements" do
expect(sanitize_svg_data(data)).to eq(expected)
end
end
describe "#edit_blob_link" do
- let(:namespace) { create(:namespace, name: 'gitlab' )}
+ let(:namespace) { create(:namespace, name: "gitlab")}
let(:project) { create(:project, :repository, namespace: namespace) }
before do
@@ -33,44 +33,44 @@ describe BlobHelper do
allow(self).to receive(:can_collaborate_with_project?).and_return(true)
end
- it 'verifies blob is text' do
+ it "verifies blob is text" do
expect(helper).not_to receive(:blob_text_viewable?)
- button = edit_blob_button(project, 'refs/heads/master', 'README.md')
+ button = edit_blob_button(project, "refs/heads/master", "README.md")
- expect(button).to start_with('<button')
+ expect(button).to start_with("<button")
end
- it 'uses the passed blob instead retrieve from repository' do
- blob = project.repository.blob_at('refs/heads/master', 'README.md')
+ it "uses the passed blob instead retrieve from repository" do
+ blob = project.repository.blob_at("refs/heads/master", "README.md")
expect(project.repository).not_to receive(:blob_at)
- edit_blob_button(project, 'refs/heads/master', 'README.md', blob: blob)
+ edit_blob_button(project, "refs/heads/master", "README.md", blob: blob)
end
- it 'returns a link with the proper route' do
+ it "returns a link with the proper route" do
stub_feature_flags(web_ide_default: false)
- link = edit_blob_button(project, 'master', 'README.md')
+ link = edit_blob_button(project, "master", "README.md")
- expect(Capybara.string(link).find_link('Edit')[:href]).to eq("/#{project.full_path}/edit/master/README.md")
+ expect(Capybara.string(link).find_link("Edit")[:href]).to eq("/#{project.full_path}/edit/master/README.md")
end
- it 'returns a link with a Web IDE route' do
- link = edit_blob_button(project, 'master', 'README.md')
+ it "returns a link with a Web IDE route" do
+ link = edit_blob_button(project, "master", "README.md")
- expect(Capybara.string(link).find_link('Edit')[:href]).to eq("/-/ide/project/#{project.full_path}/edit/master/-/README.md")
+ expect(Capybara.string(link).find_link("Edit")[:href]).to eq("/-/ide/project/#{project.full_path}/edit/master/-/README.md")
end
- it 'returns a link with the passed link_opts on the expected route' do
+ it "returns a link with the passed link_opts on the expected route" do
stub_feature_flags(web_ide_default: false)
- link = edit_blob_button(project, 'master', 'README.md', link_opts: { mr_id: 10 })
+ link = edit_blob_button(project, "master", "README.md", link_opts: {mr_id: 10})
- expect(Capybara.string(link).find_link('Edit')[:href]).to eq("/#{project.full_path}/edit/master/README.md?mr_id=10")
+ expect(Capybara.string(link).find_link("Edit")[:href]).to eq("/#{project.full_path}/edit/master/README.md?mr_id=10")
end
end
- context 'viewer related' do
+ context "viewer related" do
include FakeBlobHelpers
let(:project) { build(:project, lfs_enabled: true) }
@@ -92,48 +92,48 @@ describe BlobHelper do
let(:viewer) { viewer_class.new(blob) }
let(:blob) { fake_blob }
- describe '#blob_render_error_reason' do
- context 'for error :too_large' do
- context 'when the blob size is larger than the absolute size limit' do
+ describe "#blob_render_error_reason" do
+ context "for error :too_large" do
+ context "when the blob size is larger than the absolute size limit" do
let(:blob) { fake_blob(size: 10.megabytes) }
- it 'returns an error message' do
- expect(helper.blob_render_error_reason(viewer)).to eq('it is larger than 5 MB')
+ it "returns an error message" do
+ expect(helper.blob_render_error_reason(viewer)).to eq("it is larger than 5 MB")
end
end
- context 'when the blob size is larger than the size limit' do
+ context "when the blob size is larger than the size limit" do
let(:blob) { fake_blob(size: 2.megabytes) }
- it 'returns an error message' do
- expect(helper.blob_render_error_reason(viewer)).to eq('it is larger than 1 MB')
+ it "returns an error message" do
+ expect(helper.blob_render_error_reason(viewer)).to eq("it is larger than 1 MB")
end
end
end
- context 'for error :server_side_but_stored_externally' do
+ context "for error :server_side_but_stored_externally" do
let(:blob) { fake_blob(lfs: true) }
- it 'returns an error message' do
- expect(helper.blob_render_error_reason(viewer)).to eq('it is stored in LFS')
+ it "returns an error message" do
+ expect(helper.blob_render_error_reason(viewer)).to eq("it is stored in LFS")
end
end
end
- describe '#blob_render_error_options' do
+ describe "#blob_render_error_options" do
before do
assign(:project, project)
assign(:blob, blob)
- assign(:id, File.join('master', blob.path))
+ assign(:id, File.join("master", blob.path))
- controller.params[:controller] = 'projects/blob'
- controller.params[:action] = 'show'
+ controller.params[:controller] = "projects/blob"
+ controller.params[:action] = "show"
controller.params[:namespace_id] = project.namespace.to_param
controller.params[:project_id] = project.to_param
- controller.params[:id] = File.join('master', blob.path)
+ controller.params[:id] = File.join("master", blob.path)
end
- context 'for error :collapsed' do
+ context "for error :collapsed" do
let(:blob) { fake_blob(size: 2.megabytes) }
it 'includes a "load it anyway" link' do
@@ -141,24 +141,24 @@ describe BlobHelper do
end
end
- context 'for error :too_large' do
+ context "for error :too_large" do
let(:blob) { fake_blob(size: 10.megabytes) }
it 'does not include a "load it anyway" link' do
expect(helper.blob_render_error_options(viewer)).not_to include(/load it anyway/)
end
- context 'when the viewer is rich' do
- context 'the blob is rendered as text' do
- let(:blob) { fake_blob(path: 'file.md', size: 2.megabytes) }
+ context "when the viewer is rich" do
+ context "the blob is rendered as text" do
+ let(:blob) { fake_blob(path: "file.md", size: 2.megabytes) }
it 'includes a "view the source" link' do
expect(helper.blob_render_error_options(viewer)).to include(/view the source/)
end
end
- context 'the blob is not rendered as text' do
- let(:blob) { fake_blob(path: 'file.pdf', binary: true, size: 2.megabytes) }
+ context "the blob is not rendered as text" do
+ let(:blob) { fake_blob(path: "file.pdf", binary: true, size: 2.megabytes) }
it 'does not include a "view the source" link' do
expect(helper.blob_render_error_options(viewer)).not_to include(/view the source/)
@@ -166,12 +166,12 @@ describe BlobHelper do
end
end
- context 'when the viewer is not rich' do
+ context "when the viewer is not rich" do
before do
viewer_class.type = :simple
end
- let(:blob) { fake_blob(path: 'file.md', size: 2.megabytes) }
+ let(:blob) { fake_blob(path: "file.md", size: 2.megabytes) }
it 'does not include a "view the source" link' do
expect(helper.blob_render_error_options(viewer)).not_to include(/view the source/)
@@ -183,8 +183,8 @@ describe BlobHelper do
end
end
- context 'for error :server_side_but_stored_externally' do
- let(:blob) { fake_blob(path: 'file.md', lfs: true) }
+ context "for error :server_side_but_stored_externally" do
+ let(:blob) { fake_blob(path: "file.md", lfs: true) }
it 'does not include a "load it anyway" link' do
expect(helper.blob_render_error_options(viewer)).not_to include(/load it anyway/)
@@ -201,7 +201,7 @@ describe BlobHelper do
end
end
- describe '#ide_edit_path' do
+ describe "#ide_edit_path" do
let(:project) { create(:project) }
around do |example|
@@ -213,19 +213,19 @@ describe BlobHelper do
end
end
- it 'returns full IDE path' do
+ it "returns full IDE path" do
Rails.application.routes.default_url_options[:script_name] = nil
expect(helper.ide_edit_path(project, "master", "")).to eq("/-/ide/project/#{project.namespace.path}/#{project.path}/edit/master")
end
- it 'returns full IDE path with second -' do
+ it "returns full IDE path with second -" do
Rails.application.routes.default_url_options[:script_name] = nil
expect(helper.ide_edit_path(project, "testing/slashes", "readme.md")).to eq("/-/ide/project/#{project.namespace.path}/#{project.path}/edit/testing/slashes/-/readme.md")
end
- it 'returns IDE path without relative_url_root' do
+ it "returns IDE path without relative_url_root" do
Rails.application.routes.default_url_options[:script_name] = "/gitlab"
expect(helper.ide_edit_path(project, "master", "")).to eq("/gitlab/-/ide/project/#{project.namespace.path}/#{project.path}/edit/master")