summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2017-11-11 13:44:05 +0000
committerw0rp <devw0rp@gmail.com>2017-11-11 13:44:12 +0000
commit8c1d6eda81d408de767916c00d20139ddf6fc9c6 (patch)
tree71922e7a086219ead03fc8a5fcf76d43f527f37f /test
parent6c014a25e86c864c893c59ee3f30ce80cfd5fbb6 (diff)
downloadale-8c1d6eda81d408de767916c00d20139ddf6fc9c6.zip
#1095 Apply all patterns for g:ale_pattern_options, instead of just the first match
Diffstat (limited to 'test')
-rw-r--r--test/test_autocmd_commands.vader23
-rw-r--r--test/test_pattern_options.vader68
2 files changed, 73 insertions, 18 deletions
diff --git a/test/test_autocmd_commands.vader b/test/test_autocmd_commands.vader
index 88504a9b..e7e9e86e 100644
--- a/test/test_autocmd_commands.vader
+++ b/test/test_autocmd_commands.vader
@@ -108,17 +108,28 @@ Execute (g:ale_lint_on_insert_leave = 0 should bind no events):
AssertEqual [], CheckAutocmd('ALERunOnInsertLeave')
-Execute (g:ale_pattern_options_enabled = 0 should bind no events):
+Execute (g:ale_pattern_options_enabled = 1 should bind BufReadPost and BufEnter):
+ let g:ale_pattern_options_enabled = 1
+
+ AssertEqual [
+ \ 'BufEnter * call ale#pattern_options#SetOptions(str2nr(expand(''<abuf>'')))',
+ \ 'BufReadPost * call ale#pattern_options#SetOptions(str2nr(expand(''<abuf>'')))',
+ \], CheckAutocmd('ALEPatternOptionsGroup')
+
+Execute (g:ale_pattern_options_enabled = 0 should still bind events):
let g:ale_pattern_options_enabled = 0
- AssertEqual [], CheckAutocmd('ALEPatternOptionsGroup')
+ AssertEqual [
+ \ 'BufEnter * call ale#pattern_options#SetOptions(str2nr(expand(''<abuf>'')))',
+ \ 'BufReadPost * call ale#pattern_options#SetOptions(str2nr(expand(''<abuf>'')))',
+ \], CheckAutocmd('ALEPatternOptionsGroup')
-Execute (g:ale_pattern_options_enabled = 1 should bind BufReadPost and BufEnter):
- let g:ale_pattern_options_enabled = 1
+Execute (g:ale_enabled = 0 should still bind pattern events):
+ let g:ale_enabled = 0
AssertEqual [
- \ 'BufEnter * call ale#pattern_options#SetOptions()',
- \ 'BufReadPost * call ale#pattern_options#SetOptions()',
+ \ 'BufEnter * call ale#pattern_options#SetOptions(str2nr(expand(''<abuf>'')))',
+ \ 'BufReadPost * call ale#pattern_options#SetOptions(str2nr(expand(''<abuf>'')))',
\], CheckAutocmd('ALEPatternOptionsGroup')
Execute (g:ale_lint_on_enter = 0 should bind only the BufEnter event):
diff --git a/test/test_pattern_options.vader b/test/test_pattern_options.vader
index 164e5aa7..0ad4415f 100644
--- a/test/test_pattern_options.vader
+++ b/test/test_pattern_options.vader
@@ -3,30 +3,74 @@ Before:
Save g:ale_pattern_options_enabled
Save &filetype
+ let g:ale_pattern_options_enabled = 1
+ let g:ale_pattern_options = {}
+
+ let b:ale_enabled = 0
+ let b:some_option = 0
+
+ call ale#test#SetDirectory('/testplugin/test')
+
After:
Restore
unlet! b:ale_enabled
unlet! b:some_option
-Execute(Buffer variables should be set when filename patterns match):
- let g:ale_pattern_options = {'baz.*\.js': {
- \ 'ale_enabled': 1,
- \ 'some_option': 347,
- \ '&filetype': 'pattern_option_set_filetype',
- \}}
+ call ale#test#RestoreDirectory()
- silent! file foobar.js
+Execute(The pattern options function should work when there are no patterns):
+ call ale#test#SetFilename('foobar.js')
+ call ale#pattern_options#SetOptions(bufnr(''))
- call ale#pattern_options#SetOptions()
+Execute(Buffer variables should be set when filename patterns match):
+ let g:ale_pattern_options = {
+ \ 'baz.*\.js': {
+ \ 'ale_enabled': 1,
+ \ 'some_option': 347,
+ \ '&filetype': 'pattern_option_set_filetype',
+ \ },
+ \}
- Assert !exists('b:ale_enabled')
- Assert !exists('b:some_option')
+ call ale#test#SetFilename('foobar.js')
+ call ale#pattern_options#SetOptions(bufnr(''))
- silent! file bazboz.js
+ AssertEqual 0, b:ale_enabled
+ AssertEqual 0, b:some_option
- call ale#pattern_options#SetOptions()
+ call ale#test#SetFilename('bazboz.js')
+ call ale#pattern_options#SetOptions(bufnr(''))
AssertEqual 1, b:ale_enabled
AssertEqual 347, b:some_option
AssertEqual 'pattern_option_set_filetype', &filetype
+
+Execute(Multiple pattern matches should be applied):
+ let g:ale_pattern_options = {
+ \ 'foo': {
+ \ 'some_option': 666,
+ \ },
+ \ 'bar': {
+ \ 'ale_enabled': 1,
+ \ 'some_option': 123,
+ \ },
+ \ 'notmatched': {
+ \ 'some_option': 489,
+ \ 'ale_enabled': 0,
+ \ },
+ \}
+
+ call ale#test#SetFilename('foobar.js')
+ call ale#pattern_options#SetOptions(bufnr(''))
+
+ AssertEqual 1, b:ale_enabled
+ AssertEqual 666, b:some_option
+
+Execute(Patterns should not be applied when the setting is disabled):
+ let g:ale_pattern_options_enabled = 0
+ let g:ale_pattern_options = {'foo': {'some_option': 666}}
+
+ call ale#test#SetFilename('foobar.js')
+ call ale#pattern_options#SetOptions(bufnr(''))
+
+ AssertEqual 0, b:some_option