summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorw0rp <w0rp@users.noreply.github.com>2017-09-28 13:29:55 +0100
committerGitHub <noreply@github.com>2017-09-28 13:29:55 +0100
commit9fc01bd2469f7243f5147385783d59494e61a0df (patch)
tree33c2b038877327d6c20c021b8bf5360ef3b436d6 /test
parent49b6805b090a4903212ec13a314ebdb6e3790e5b (diff)
parent8f6044b8b64b608196a28b8125719be8736932bd (diff)
downloadale-9fc01bd2469f7243f5147385783d59494e61a0df.zip
Merge pull request #952 from hernot/master
Add mcsc for checking C# code.
Diffstat (limited to 'test')
-rw-r--r--test/command_callback/test_cs_mcs_command_callbacks.vader34
-rw-r--r--test/command_callback/test_cs_mcsc_command_callbacks.vader120
-rw-r--r--test/handler/test_mcs_handler.vader34
-rw-r--r--test/handler/test_mcsc_handler.vader44
4 files changed, 232 insertions, 0 deletions
diff --git a/test/command_callback/test_cs_mcs_command_callbacks.vader b/test/command_callback/test_cs_mcs_command_callbacks.vader
new file mode 100644
index 00000000..30f067ea
--- /dev/null
+++ b/test/command_callback/test_cs_mcs_command_callbacks.vader
@@ -0,0 +1,34 @@
+Before:
+ Save g:ale_cs_mcs_options
+
+ unlet! g:ale_cs_mcs_options
+
+ runtime ale_linters/cs/mcs.vim
+
+ let b:command_tail = ' -unsafe --parse'
+
+After:
+ Restore
+ unlet! b:command_tail
+ unlet! b:ale_cs_mcs_options
+ call ale#linter#Reset()
+
+Execute(Check for proper default command):
+
+ let b:command = ale_linters#cs#mcs#GetCommand(bufnr(''))
+ let b:command = substitute(b:command,'\s\+',' ','g')
+
+ AssertEqual
+ \ b:command,
+ \ 'mcs -unsafe --parse %t'
+
+Execute(The options should be be used in the command):
+
+ let b:ale_cs_mcs_options = '-pkg:dotnet'
+ let b:command = ale_linters#cs#mcs#GetCommand(bufnr(''))
+ let b:command = substitute(b:command,'\s\+',' ','g')
+
+ AssertEqual
+ \ b:command,
+ \ 'mcs' . b:command_tail . ' ' . b:ale_cs_mcs_options . ' %t',
+
diff --git a/test/command_callback/test_cs_mcsc_command_callbacks.vader b/test/command_callback/test_cs_mcsc_command_callbacks.vader
new file mode 100644
index 00000000..b513b655
--- /dev/null
+++ b/test/command_callback/test_cs_mcsc_command_callbacks.vader
@@ -0,0 +1,120 @@
+Before:
+ Save g:ale_cs_mcsc_options
+ Save g:ale_cs_mcsc_source
+ Save g:ale_cs_mcsc_assembly_path
+ Save g:ale_cs_mcsc_assemblies
+
+ unlet! g:ale_cs_mcsc_options
+ unlet! g:ale_cs_mcsc_source
+ unlet! g:ale_cs_mcsc_assembly_path
+ unlet! g:ale_cs_mcsc_assemblies
+
+ let g:temppath = fnamemodify(tempname(), ':p:h')
+ let g:temppathpattern = substitute(escape(g:temppath, '\\/.*$^~[]'), '[\\/]*$', '[\\\\/]\\+\\S\\+','')
+ let g:sometempfile = fnamemodify(g:temppath .'/some_temp_file.tmp', ':p')
+
+ runtime ale_linters/cs/mcsc.vim
+
+After:
+ Restore
+ unlet! b:ale_cs_mcsc_options
+ unlet! g:ale_cs_mcsc_source
+ unlet! g:ale_cs_mcsc_assembly_path
+ unlet! g:ale_cs_mcsc_assemblies
+ unlet! g:temppath
+ unlet! g:temppathpattern
+ unlet! g:sometempfile
+ call ale#linter#Reset()
+
+Execute(Check for proper default command):
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command, '\s\+', ' ', 'g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd ".";mcs -unsafe -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
+Execute(The options should be be used in the command):
+
+ let g:ale_cs_mcsc_options = '-pkg:dotnet'
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command, '\s\+', ' ', 'g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd ".";mcs -unsafe ' . g:ale_cs_mcsc_options . ' -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
+Execute(The souce path should be be used in the command):
+ call ale#engine#Cleanup(bufnr(''))
+ call ale#engine#InitBufferInfo(bufnr(''))
+
+ let g:ale_cs_mcsc_source='../foo/bar'
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command, '\s\+', ' ', 'g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd "' . g:ale_cs_mcsc_source . '";mcs -unsafe -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
+Execute(The list of search pathes for assemblies should be be used in the command if not empty):
+ call ale#engine#Cleanup(bufnr(''))
+ call ale#engine#InitBufferInfo(bufnr(''))
+
+ let g:ale_cs_mcsc_assembly_path = [
+ \ '/usr/lib/mono',
+ \ '../foo/bar'
+ \]
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command, '\s\+', ' ', 'g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd ".";mcs -unsafe -lib:"' . join(g:ale_cs_mcsc_assembly_path,'","') . '" -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
+ let g:ale_cs_mcsc_assembly_path = [
+ \]
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command, '\s\+', ' ', 'g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd ".";mcs -unsafe -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
+Execute(The list of assemblies should be be used in the command if not empty):
+ call ale#engine#Cleanup(bufnr(''))
+ call ale#engine#InitBufferInfo(bufnr(''))
+
+ let g:ale_cs_mcsc_assemblies = [
+ \ 'foo.dll',
+ \ 'bar.dll'
+ \]
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command,'\s\+',' ','g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd ".";mcs -unsafe -r:"' . join(g:ale_cs_mcsc_assemblies,'","') . '" -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
+ let g:ale_cs_mcsc_assemblies = [
+ \]
+
+ let b:command = ale_linters#cs#mcsc#GetCommand(bufnr(''))
+ let b:command = substitute(b:command, '-out:' . g:temppathpattern, '-out:' . g:sometempfile, '')
+ let b:command = substitute(b:command,'\s\+',' ','g')
+
+ AssertEqual
+ \ b:command,
+ \ 'cd ".";mcs -unsafe -out:' . g:sometempfile . ' -t:module -recurse:"*.cs"'
+
diff --git a/test/handler/test_mcs_handler.vader b/test/handler/test_mcs_handler.vader
new file mode 100644
index 00000000..75a764a3
--- /dev/null
+++ b/test/handler/test_mcs_handler.vader
@@ -0,0 +1,34 @@
+Before:
+ runtime ale_linters/cs/mcs.vim
+
+After:
+ call ale#linter#Reset()
+
+Execute(The mcs handler should handle cannot find symbol errors):
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 12,
+ \ 'col' : 29,
+ \ 'text': 'error CS1001: ; expected',
+ \ 'type': 'E',
+ \ },
+ \ {
+ \ 'lnum': 101,
+ \ 'col': 0,
+ \ 'text': 'error CS1028: Unexpected processor directive (no #if for this #endif)',
+ \ 'type': 'E',
+ \ },
+ \ {
+ \ 'lnum': 10,
+ \ 'col': 12,
+ \ 'text': 'warning CS0123: some warning',
+ \ 'type': 'W',
+ \ },
+ \ ],
+ \ ale_linters#cs#mcs#Handle(347, [
+ \ 'Tests.cs(12,29): error CS1001: ; expected',
+ \ 'Tests.cs(101,0): error CS1028: Unexpected processor directive (no #if for this #endif)',
+ \ 'Tests.cs(10,12): warning CS0123: some warning',
+ \ 'Compilation failed: 2 error(s), 1 warnings',
+ \ ])
diff --git a/test/handler/test_mcsc_handler.vader b/test/handler/test_mcsc_handler.vader
new file mode 100644
index 00000000..a65185ca
--- /dev/null
+++ b/test/handler/test_mcsc_handler.vader
@@ -0,0 +1,44 @@
+Before:
+ Save g:ale_cs_mcsc_source
+
+ unlet! g:ale_cs_mcsc_source
+
+ runtime ale_linters/cs/mcsc.vim
+
+After:
+ unlet! g:ale_cs_mcsc_source
+ call ale#linter#Reset()
+
+Execute(The mcs handler should handle cannot find symbol errors):
+ let g:ale_cs_mcsc_source='/home/foo/project/bar'
+
+ AssertEqual
+ \ [
+ \ {
+ \ 'lnum': 12,
+ \ 'col' : 29,
+ \ 'text': 'error CS1001: ; expected',
+ \ 'type': 'E',
+ \ 'filename': '/home/foo/project/bar/Test.cs'
+ \ },
+ \ {
+ \ 'lnum': 101,
+ \ 'col': 0,
+ \ 'text': 'error CS1028: Unexpected processor directive (no #if for this #endif)',
+ \ 'type': 'E',
+ \ 'filename': '/home/foo/project/bar/Test.cs'
+ \ },
+ \ {
+ \ 'lnum': 10,
+ \ 'col': 12,
+ \ 'text': 'warning CS0123: some warning',
+ \ 'type': 'W',
+ \ 'filename': '/home/foo/project/bar/Test.cs'
+ \ },
+ \ ],
+ \ ale_linters#cs#mcsc#Handle(347, [
+ \ 'Test.cs(12,29): error CS1001: ; expected',
+ \ 'Test.cs(101,0): error CS1028: Unexpected processor directive (no #if for this #endif)',
+ \ 'Test.cs(10,12): warning CS0123: some warning',
+ \ 'Compilation failed: 2 error(s), 1 warnings',
+ \ ])