summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorw0rp <w0rp@users.noreply.github.com>2017-11-16 10:19:32 +0000
committerGitHub <noreply@github.com>2017-11-16 10:19:32 +0000
commitf90a2d54744d7bfe985b0cd48a00012afecdc754 (patch)
tree1f893e61a746d359b858a3eade8fc350b9ad84ab /test
parentee07be5f59611510ed21880f5d895393e954d418 (diff)
parentad7ea3630758af51f6be826fcd453dfc42a6cd75 (diff)
downloadale-f90a2d54744d7bfe985b0cd48a00012afecdc754.zip
Merge pull request #1114 from elebow/eruby-strip-rails-flavoring
Strip Rails flavoring from eRuby when in a Rails project. Fixes #580.
Diffstat (limited to 'test')
-rw-r--r--test/command_callback/test_erb_command_callback.vader21
-rw-r--r--test/command_callback/test_erubis_command_callback.vader21
-rw-r--r--test/ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb0
3 files changed, 42 insertions, 0 deletions
diff --git a/test/command_callback/test_erb_command_callback.vader b/test/command_callback/test_erb_command_callback.vader
new file mode 100644
index 00000000..2cfff7ed
--- /dev/null
+++ b/test/command_callback/test_erb_command_callback.vader
@@ -0,0 +1,21 @@
+Before:
+ runtime ale_linters/eruby/erb.vim
+ call ale#test#SetDirectory('/testplugin/test/command_callback')
+
+After:
+ call ale#linter#Reset()
+ call ale#test#RestoreDirectory()
+
+Execute(Executable should not contain any filter code by default):
+ call ale#test#SetFilename('../ruby_fixtures/not_a_rails_app/file.rb')
+
+ AssertEqual
+ \ 'erb -P -x %t | ruby -c',
+ \ ale_linters#eruby#erb#GetCommand(bufnr(''))
+
+Execute(Executable should filter invalid eRuby when inside a Rails project):
+ call ale#test#SetFilename('../ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb')
+
+ AssertEqual
+ \ 'ruby -r erb -e ' . ale#Escape('puts ERB.new($stdin.read.gsub(%{<%=},%{<%}), nil, %{-}).src') . ' | ruby -c',
+ \ ale_linters#eruby#erb#GetCommand(bufnr(''))
diff --git a/test/command_callback/test_erubis_command_callback.vader b/test/command_callback/test_erubis_command_callback.vader
new file mode 100644
index 00000000..68624ec6
--- /dev/null
+++ b/test/command_callback/test_erubis_command_callback.vader
@@ -0,0 +1,21 @@
+Before:
+ runtime ale_linters/eruby/erubis.vim
+ call ale#test#SetDirectory('/testplugin/test/command_callback')
+
+After:
+ call ale#linter#Reset()
+ call ale#test#RestoreDirectory()
+
+Execute(Executable should not contain any filter code by default):
+ call ale#test#SetFilename('../ruby_fixtures/not_a_rails_app/file.rb')
+
+ AssertEqual
+ \ 'erubis -x %t | ruby -c',
+ \ ale_linters#eruby#erubis#GetCommand(bufnr(''))
+
+Execute(Executable should filter invalid eRuby when inside a Rails project):
+ call ale#test#SetFilename('../ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb')
+
+ AssertEqual
+ \ 'ruby -r erubis -e ' . ale#Escape('puts Erubis::Eruby.new($stdin.read.gsub(%{<%=},%{<%})).src') . ' | ruby -c',
+ \ ale_linters#eruby#erubis#GetCommand(bufnr(''))
diff --git a/test/ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb b/test/ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/test/ruby_fixtures/valid_rails_app/app/views/my_great_view.html.erb