debian-mirror-gitlab/spec/haml_lint/linter/no_plain_nodes_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

95 lines
2.3 KiB
Ruby
Raw Normal View History

2019-09-04 21:01:54 +05:30
# frozen_string_literal: true
require 'spec_helper'
require 'haml_lint'
require 'haml_lint/spec'
require Rails.root.join('haml_lint/linter/no_plain_nodes')
2020-07-28 23:09:34 +05:30
RSpec.describe HamlLint::Linter::NoPlainNodes do
2019-09-04 21:01:54 +05:30
include_context 'linter'
context 'reports when a tag has an inline plain node' do
let(:haml) { '%tag Hello Tanuki' }
let(:message) { "`Hello Tanuki` is a plain node. Please use an i18n method like `= _('Hello Tanuki')`" }
it { is_expected.to report_lint message: message }
end
context 'reports when a tag has multiline plain nodes' do
let(:haml) { <<-HAML }
%tag
Hello
Tanuki
HAML
it { is_expected.to report_lint count: 1 }
end
context 'reports when a tag has an inline plain node with interpolation' do
let(:haml) { '%tag Hello #{"Tanuki"}!' } # rubocop:disable Lint/InterpolationCheck
it { is_expected.to report_lint }
end
context 'does not report when a tag has an inline script' do
let(:haml) { '%tag= "Hello Tanuki"' }
it { is_expected.not_to report_lint }
end
context 'does not report when a tag is empty' do
let(:haml) { '%tag' }
it { is_expected.not_to report_lint }
end
context 'reports multiple when a tag has multiline plain nodes split by non-text nodes' do
let(:haml) { <<-HAML }
%tag
Hello
.split-node There
Tanuki
HAML
it { is_expected.to report_lint count: 3 }
end
2020-05-24 23:13:21 +05:30
context 'does not report when a html entity' do
let(:haml) { '%tag &nbsp;' }
it { is_expected.not_to report_lint }
end
context 'does report when something that looks like a html entity' do
let(:haml) { '%tag &some text;' }
it { is_expected.to report_lint }
end
context 'does not report multiline when one or more html entities' do
%w(&nbsp;&gt; &#x000A9; &#187;).each do |elem|
let(:haml) { <<-HAML }
%tag
#{elem}
HAML
it elem do
is_expected.not_to report_lint
end
end
end
context 'does report multiline when one or more html entities amidst plain text' do
%w(&nbsp;Test Test&gt; &#x000A9;Hello &nbsp;Hello&#187;).each do |elem|
let(:haml) { <<-HAML }
%tag
#{elem}
HAML
it elem do
is_expected.to report_lint
end
end
end
2019-09-04 21:01:54 +05:30
end