summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorw0rp <devw0rp@gmail.com>2017-11-22 23:23:14 +0000
committerw0rp <devw0rp@gmail.com>2017-11-22 23:23:14 +0000
commit5160f814d929e0936c3d920087e0c4d16040ae9c (patch)
tree185d2cf775d027a29f23534a54415626608fbbbe /test
parent6318a08e08716d460f8441457813875495050023 (diff)
downloadale-5160f814d929e0936c3d920087e0c4d16040ae9c.zip
Fix #988 - Support --fix-dry-run for ESLint by processing the JSON output
Diffstat (limited to 'test')
-rw-r--r--test/fixers/test_eslint_fixer_callback.vader36
-rw-r--r--test/test_fuzzy_json_decode.vader8
2 files changed, 44 insertions, 0 deletions
diff --git a/test/fixers/test_eslint_fixer_callback.vader b/test/fixers/test_eslint_fixer_callback.vader
index 8a5eaa4e..afb267a2 100644
--- a/test/fixers/test_eslint_fixer_callback.vader
+++ b/test/fixers/test_eslint_fixer_callback.vader
@@ -69,6 +69,18 @@ Execute(The version check should be correct):
\ },
\ ale#fixers#eslint#Fix(bufnr(''))
+Execute(--fix-dry-run should be used for 4.9.0 and up):
+ call ale#test#SetFilename('../eslint-test-files/react-app/subdir/testfile.js')
+
+ AssertEqual
+ \ {
+ \ 'command': (has('win32') ? 'node.exe ' : '')
+ \ . ale#Escape(ale#path#Winify(g:dir . '/../eslint-test-files/react-app/node_modules/eslint/bin/eslint.js'))
+ \ . ' --stdin-filename %s --stdin --fix-dry-run --format=json',
+ \ 'process_with': 'ale#fixers#eslint#ProcessFixDryRunOutput',
+ \ },
+ \ ale#fixers#eslint#ApplyFixForVersion(bufnr(''), ['4.9.0'])
+
Execute(--fix-to-stdout should be used for eslint_d):
call ale#test#SetFilename('../eslint-test-files/app-with-eslint-d/testfile.js')
@@ -114,3 +126,27 @@ Execute(The version number should be cached):
\ 'command': '',
\ },
\ ale#fixers#eslint#Fix(bufnr(''))
+
+ " Call it again without the version output. We should use the newer command.
+ AssertEqual
+ \ {
+ \ 'command': (has('win32') ? 'node.exe ' : '')
+ \ . ale#Escape(ale#path#Winify(g:dir . '/../eslint-test-files/react-app/node_modules/eslint/bin/eslint.js'))
+ \ . ' --stdin-filename %s --stdin --fix-dry-run --format=json',
+ \ 'process_with': 'ale#fixers#eslint#ProcessFixDryRunOutput',
+ \ },
+ \ ale#fixers#eslint#ApplyFixForVersion(bufnr(''), [])
+
+Execute(The --fix-dry-run post-processor should handle JSON output correctly):
+ AssertEqual
+ \ [],
+ \ ale#fixers#eslint#ProcessFixDryRunOutput(bufnr(''), [])
+ AssertEqual
+ \ [],
+ \ ale#fixers#eslint#ProcessFixDryRunOutput(bufnr(''), [''])
+ AssertEqual
+ \ [],
+ \ ale#fixers#eslint#ProcessFixDryRunOutput(bufnr(''), ['[{}]'])
+ AssertEqual
+ \ ['foo', 'bar'],
+ \ ale#fixers#eslint#ProcessFixDryRunOutput(bufnr(''), ['[{"output": "foo\nbar"}]'])
diff --git a/test/test_fuzzy_json_decode.vader b/test/test_fuzzy_json_decode.vader
index 4ac0ca1b..4b1c6088 100644
--- a/test/test_fuzzy_json_decode.vader
+++ b/test/test_fuzzy_json_decode.vader
@@ -6,6 +6,14 @@ Execute(FuzzyJSONDecode should return the default for empty Strings):
AssertEqual [], ale#util#FuzzyJSONDecode('', [])
AssertEqual {}, ale#util#FuzzyJSONDecode('', {})
+Execute(FuzzyJSONDecode should return the default value for ['']):
+ AssertEqual [], ale#util#FuzzyJSONDecode([''], [])
+ AssertEqual {}, ale#util#FuzzyJSONDecode([''], {})
+
+Execute(FuzzyJSONDecode should return the default value for only whitespace lines):
+ AssertEqual [], ale#util#FuzzyJSONDecode(['', "\n"], [])
+ AssertEqual {}, ale#util#FuzzyJSONDecode(['', "\n"], {})
+
Execute(FuzzyJSONDecode should return the default for Lists with invalid JSON):
AssertEqual [], ale#util#FuzzyJSONDecode(['x'], [])
AssertEqual {}, ale#util#FuzzyJSONDecode(['x'], {})