summaryrefslogtreecommitdiff
path: root/test/test_flow_command.vader
blob: 4805e1217481ff8d9f697ddb54011e0c67841f2c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
Before:
  runtime ale_linters/javascript/flow.vim

  call ale#assert#SetUpLinterTest('javascript', 'flow')
  call ale#test#SetDirectory('/testplugin/test/')

After:
  unlet! b:ale_javascript_flow_use_respect_pragma
  call ale#assert#TearDownLinterTest()

Execute(flow should return a command to run if a .flowconfig file exists):
  call ale#test#SetFilename('flow/a/sub/dummy')

  AssertLinter 'flow',
  \ ale#Escape('flow')
  \   . ' check-contents --respect-pragma --json --from ale %s < %t'
  \   . (!has('win32') ? '; echo' : '')

Execute(flow should not use the respect pragma argument if the option is off):
  call ale#test#SetFilename('flow/a/sub/dummy')

  let b:ale_javascript_flow_use_respect_pragma = 0

  AssertLinter 'flow',
  \ ale#Escape('flow')
  \   . ' check-contents --json --from ale %s < %t'
  \   . (!has('win32') ? '; echo' : '')

Execute(flow should should not use --respect-pragma for old versions):
  call ale#test#SetFilename('flow/a/sub/dummy')

  GivenCommandOutput [
  \ 'Warning: `flow --version` is deprecated in favor of `flow version`',
  \ 'Flow, a static type checker for JavaScript, version 0.27.0',
  \]
  AssertLinter 'flow', [
  \ ale#Escape('flow') . ' --version',
  \ ale#Escape('flow')
  \   . ' check-contents --json --from ale %s < %t'
  \   . (!has('win32') ? '; echo' : ''),
  \]

Execute(flow should not return a command to run if no .flowconfig file exists):
  call ale#test#SetFilename('flow/b/sub/dummy')

  AssertLinterNotExecuted