summaryrefslogtreecommitdiff
path: root/test/lsp
diff options
context:
space:
mode:
authorAndre Souto <suoto@users.noreply.github.com>2019-10-18 16:17:54 +0100
committerw0rp <w0rp@users.noreply.github.com>2019-10-18 16:17:54 +0100
commit5e69aaf4c2b4ffbfd4fbe0af820e23bf559b8e14 (patch)
tree53a9f2ea1de728310cd86b26230bf35ded413f58 /test/lsp
parent9125ec8739f58941a5d6306d51f69d677849efcb (diff)
downloadale-5e69aaf4c2b4ffbfd4fbe0af820e23bf559b8e14.zip
Adding support for LSP `window/showMessage` method (#2652)
* Added base handling for window/showMessage * Ignoring severity log * Code formatting * Added user configurable severity * Preferring ale#util#ShowMessage over echo'ing directly * Using format similar to ale_echo_msg_format for consistency * Updating docs * Added LSP log config string; improved tests * Use warning as fallback for incorrect user config
Diffstat (limited to 'test/lsp')
-rw-r--r--test/lsp/test_handling_window_requests.vader94
1 files changed, 94 insertions, 0 deletions
diff --git a/test/lsp/test_handling_window_requests.vader b/test/lsp/test_handling_window_requests.vader
new file mode 100644
index 00000000..551d5975
--- /dev/null
+++ b/test/lsp/test_handling_window_requests.vader
@@ -0,0 +1,94 @@
+Before:
+ let g:expr_list = []
+ let g:linter_name = 'some_linter'
+ let g:format = '%severity%:%linter%: %s'
+ " Get the default value to restore it
+ let g:default_severity = g:ale_lsp_show_message_severity
+ let g:ale_lsp_show_message_severity = 'information'
+
+ function! ale#util#ShowMessage(expr) abort
+ call add(g:expr_list, a:expr)
+ endfunction
+
+After:
+ unlet! g:expr_list
+ unlet! g:linter_name
+ unlet! g:format
+ let g:ale_lsp_show_message_severity = g:default_severity
+ unlet! g:default_severity
+
+Execute(ale#lsp_window#HandleShowMessage() should only show errors when severity is set to "error"):
+ let g:ale_lsp_show_message_severity = 'error'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual ['Error:some_linter: an error'], g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should only show errors and warnings when severity is set to "warning"):
+ let g:ale_lsp_show_message_severity = 'warning'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual ['Error:some_linter: an error', 'Warning:some_linter: a warning'], g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should only show errors, warnings and infos when severity is set to "information"):
+ let g:ale_lsp_show_message_severity = 'information'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual [
+ \ 'Error:some_linter: an error',
+ \ 'Warning:some_linter: a warning',
+ \ 'Info:some_linter: an info'],
+ \ g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should only show errors, warnings and infos when severity is set to "info"):
+ let g:ale_lsp_show_message_severity = 'info'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual [
+ \ 'Error:some_linter: an error',
+ \ 'Warning:some_linter: a warning',
+ \ 'Info:some_linter: an info'],
+ \ g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should show all messages is severity is set to "log"):
+ let g:ale_lsp_show_message_severity = 'log'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual [
+ \ 'Error:some_linter: an error',
+ \ 'Warning:some_linter: a warning',
+ \ 'Info:some_linter: an info',
+ \ 'Log:some_linter: a log'],
+ \ g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should not show anything if severity is configured as disabled):
+ let g:ale_lsp_show_message_severity = 'disabled'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual [], g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should use "warning" when severity is set to an invalid value):
+ let g:ale_lsp_show_message_severity = 'foo'
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':1,'message':'an error'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':2,'message':'a warning'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':'an info'})
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':4,'message':'a log'})
+ AssertEqual [
+ \ 'Error:some_linter: an error',
+ \ 'Warning:some_linter: a warning'],
+ \ g:expr_list
+
+Execute(ale#lsp_window#HandleShowMessage() should escape quotes on messages):
+ call ale#lsp_window#HandleShowMessage(g:linter_name, g:format, {'type':3,'message':"this is an 'info'"})
+ AssertEqual ['Info:some_linter: this is an ''info'''], g:expr_list