summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2016-12-13 13:33:19 +0000
committerw0rp <devw0rp@gmail.com>2016-12-13 13:33:19 +0000
commit10777d3421e3cbe942a4d9519f96a798c4ae42b4 (patch)
tree25d1a1a128542f203302850e2b900e28a52c6ff8 /test
parentf950c29035d6e47c54d9f3243b6fe15866cddcf8 (diff)
downloadale-10777d3421e3cbe942a4d9519f96a798c4ae42b4.zip
Add tests to cover definitions for linters so far.
Diffstat (limited to 'test')
-rw-r--r--test/test_linter_defintion_processing.vader125
1 files changed, 125 insertions, 0 deletions
diff --git a/test/test_linter_defintion_processing.vader b/test/test_linter_defintion_processing.vader
new file mode 100644
index 00000000..52d40530
--- /dev/null
+++ b/test/test_linter_defintion_processing.vader
@@ -0,0 +1,125 @@
+Execute (PreProcess should throw when the linter object is not a Dictionary):
+ AssertThrows call ale#linter#PreProcess('')
+ AssertEqual 'The linter object must be a Dictionary', g:vader_exception
+
+Execute (PreProcess should throw when there is no name):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \})
+ AssertEqual '`name` must be defined to name the linter', g:vader_exception
+
+Execute (PreProcess should throw when there is no callback):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \})
+ AssertEqual '`callback` must be defined with a callback to accept output', g:vader_exception
+
+Execute (PreProcess should throw when then callback is not a function):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 1,
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \})
+ AssertEqual '`callback` must be defined with a callback to accept output', g:vader_exception
+
+Execute (PreProcess should throw when there is no executable or executable_callback):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'command': 'echo',
+ \})
+ AssertEqual 'Either `executable` or `executable_callback` must be defined', g:vader_exception
+
+Execute (PreProcess should throw when executable is not a string):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 123,
+ \ 'command': 'echo',
+ \})
+ AssertEqual '`executable` must be a string if defined', g:vader_exception
+
+Execute (PreProcess should throw when executable_callback is not a callback):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable_callback': 123,
+ \ 'command': 'echo',
+ \})
+ AssertEqual '`executable_callback` must be a callback if defined', g:vader_exception
+
+Execute (PreProcess should throw when there is no command):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \})
+ AssertEqual 'Either `command`, `executable_callback`, `command_chain` must be defined', g:vader_exception
+
+Execute (PreProcess should throw when command is not a string):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': [],
+ \})
+ AssertEqual '`command` must be a string if defined', g:vader_exception
+
+Execute (PreProcess should throw when command_callback is not a callback):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command_callback': 123,
+ \})
+ AssertEqual '`command_callback` must be a callback if defined', g:vader_exception
+
+Execute (PreProcess should when the output stream isn't a valid string):
+ AssertThrows call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \ 'output_stream': 'xxx',
+ \})
+ AssertEqual "`output_stream` must be 'stdout', 'stderr', or 'both'", g:vader_exception
+
+Execute (PreProcess should not throw when everything is correct):
+ call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \})
+
+Execute (PreProcess should accept an stdout output_stream):
+ call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \ 'output_stream': 'stdout',
+ \})
+
+Execute (PreProcess should accept an stderr output_stream):
+ call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \ 'output_stream': 'stderr',
+ \})
+
+Execute (PreProcess should accept a 'both' output_stream):
+ call ale#linter#PreProcess({
+ \ 'name': 'foo',
+ \ 'callback': 'SomeFunction',
+ \ 'executable': 'echo',
+ \ 'command': 'echo',
+ \ 'output_stream': 'both',
+ \})