2021-12-26 19:49:16 +01:00
|
|
|
import os
|
|
|
|
import pytest
|
|
|
|
import re
|
|
|
|
import tempfile
|
|
|
|
import checkpackagelib.tool as m
|
|
|
|
|
|
|
|
workdir_regex = re.compile(r'/tmp/tmp[^/]*-checkpackagelib-test-tool')
|
|
|
|
|
|
|
|
|
|
|
|
def check_file(tool, filename, string, permissions=None):
|
|
|
|
with tempfile.TemporaryDirectory(suffix='-checkpackagelib-test-tool') as workdir:
|
|
|
|
script = os.path.join(workdir, filename)
|
|
|
|
with open(script, 'wb') as f:
|
|
|
|
f.write(string.encode())
|
|
|
|
if permissions:
|
|
|
|
os.chmod(script, permissions)
|
|
|
|
obj = tool(script)
|
|
|
|
result = obj.run()
|
|
|
|
if result is None:
|
|
|
|
return []
|
|
|
|
return [workdir_regex.sub('dir', r) for r in result]
|
|
|
|
|
|
|
|
|
|
|
|
NotExecutable = [
|
|
|
|
('664',
|
|
|
|
'package.mk',
|
|
|
|
0o664,
|
|
|
|
'',
|
|
|
|
[]),
|
|
|
|
('775',
|
|
|
|
'package.mk',
|
|
|
|
0o775,
|
|
|
|
'',
|
|
|
|
["dir/package.mk:0: This file does not need to be executable"]),
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('testname,filename,permissions,string,expected', NotExecutable)
|
|
|
|
def test_NotExecutable(testname, filename, permissions, string, expected):
|
|
|
|
warnings = check_file(m.NotExecutable, filename, string, permissions)
|
|
|
|
assert warnings == expected
|
2021-12-26 19:49:17 +01:00
|
|
|
|
|
|
|
|
|
|
|
NotExecutable_hint = [
|
|
|
|
('no hint',
|
|
|
|
"",
|
|
|
|
'sh-shebang.sh',
|
|
|
|
0o775,
|
|
|
|
'#!/bin/sh',
|
|
|
|
["dir/sh-shebang.sh:0: This file does not need to be executable"]),
|
|
|
|
('hint',
|
|
|
|
", very special hint",
|
|
|
|
'sh-shebang.sh',
|
|
|
|
0o775,
|
|
|
|
'#!/bin/sh',
|
|
|
|
["dir/sh-shebang.sh:0: This file does not need to be executable, very special hint"]),
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('testname,hint,filename,permissions,string,expected', NotExecutable_hint)
|
|
|
|
def test_NotExecutable_hint(testname, hint, filename, permissions, string, expected):
|
|
|
|
class NotExecutable(m.NotExecutable):
|
|
|
|
def hint(self):
|
|
|
|
return hint
|
|
|
|
warnings = check_file(NotExecutable, filename, string, permissions)
|
|
|
|
assert warnings == expected
|
2021-12-26 19:49:19 +01:00
|
|
|
|
|
|
|
|
|
|
|
Shellcheck = [
|
|
|
|
('missing shebang',
|
|
|
|
'empty.sh',
|
|
|
|
'',
|
|
|
|
["dir/empty.sh:0: run 'shellcheck' and fix the warnings",
|
|
|
|
"In dir/empty.sh line 1:",
|
|
|
|
"^-- SC2148: Tips depend on target shell and yours is unknown. Add a shebang or a 'shell' directive.",
|
|
|
|
"For more information:",
|
|
|
|
" https://www.shellcheck.net/wiki/SC2148 -- Tips depend on target shell and y..."]),
|
|
|
|
('sh shebang',
|
|
|
|
'sh-shebang.sh',
|
|
|
|
'#!/bin/sh',
|
|
|
|
[]),
|
|
|
|
('bash shebang',
|
|
|
|
'bash-shebang.sh',
|
|
|
|
'#!/bin/bash',
|
|
|
|
[]),
|
|
|
|
('2 warnings',
|
|
|
|
'unused.sh',
|
|
|
|
'unused=""',
|
|
|
|
["dir/unused.sh:0: run 'shellcheck' and fix the warnings",
|
|
|
|
"In dir/unused.sh line 1:",
|
|
|
|
'unused=""',
|
|
|
|
"^-- SC2148: Tips depend on target shell and yours is unknown. Add a shebang or a 'shell' directive.",
|
|
|
|
"^----^ SC2034: unused appears unused. Verify use (or export if used externally).",
|
|
|
|
"For more information:",
|
|
|
|
" https://www.shellcheck.net/wiki/SC2148 -- Tips depend on target shell and y...",
|
|
|
|
" https://www.shellcheck.net/wiki/SC2034 -- unused appears unused. Verify use..."]),
|
|
|
|
('tab',
|
|
|
|
'tab.sh',
|
|
|
|
'\t#!/bin/sh',
|
|
|
|
["dir/tab.sh:0: run 'shellcheck' and fix the warnings",
|
|
|
|
"In dir/tab.sh line 1:",
|
|
|
|
'\t#!/bin/sh',
|
|
|
|
"^-- SC1114: Remove leading spaces before the shebang.",
|
|
|
|
"For more information:",
|
|
|
|
" https://www.shellcheck.net/wiki/SC1114 -- Remove leading spaces before the ..."]),
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize('testname,filename,string,expected', Shellcheck)
|
|
|
|
def test_Shellcheck(testname, filename, string, expected):
|
|
|
|
warnings = check_file(m.Shellcheck, filename, string)
|
|
|
|
assert warnings == expected
|