summaryrefslogtreecommitdiff
path: root/test/linter/test_erubi.vader
diff options
context:
space:
mode:
Diffstat (limited to 'test/linter/test_erubi.vader')
-rw-r--r--test/linter/test_erubi.vader32
1 files changed, 32 insertions, 0 deletions
diff --git a/test/linter/test_erubi.vader b/test/linter/test_erubi.vader
new file mode 100644
index 00000000..cd4a0b68
--- /dev/null
+++ b/test/linter/test_erubi.vader
@@ -0,0 +1,32 @@
+Before:
+ call ale#assert#SetUpLinterTest('eruby', 'erubi')
+
+After:
+ call ale#assert#TearDownLinterTest()
+
+Execute(Executable should not contain any filter code by default):
+ call ale#test#SetFilename('../test-files/ruby/not_a_rails_app/file.rb')
+
+ AssertLinter 'ruby', [
+ \ 'ruby -r erubi/capture_end -e ' . ale#Escape('""'),
+ \ 'ruby -r erubi/capture_end -e ' . ale#Escape('puts Erubi::CaptureEndEngine.new($stdin.read).src') . '< %t | ruby -c',
+ \]
+
+Execute(Executable should filter invalid eRuby when inside a Rails project):
+ call ale#test#SetFilename('../test-files/ruby/valid_rails_app/app/views/my_great_view.html.erb')
+
+ AssertLinter 'ruby', [
+ \ 'ruby -r erubi/capture_end -e ' . ale#Escape('""'),
+ \ 'ruby -r erubi/capture_end -e ' . ale#Escape('puts Erubi::CaptureEndEngine.new($stdin.read.gsub(%{<%=},%{<%}), nil, %{-}).src') . '< %t | ruby -c',
+ \]
+
+Execute(Command should be blank if the first command in the chain returns output):
+ GivenCommandOutput [
+ \ "/usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in `require': cannot load such file -- erubi/capture_end (LoadError)",
+ \ " from /usr/lib/ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in `require'",
+ \]
+
+ AssertLinter 'ruby', [
+ \ 'ruby -r erubi/capture_end -e ' . ale#Escape('""'),
+ \ '',
+ \]