test_tool.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. import os
  2. import pytest
  3. import re
  4. import tempfile
  5. import checkpackagelib.tool as m
  6. workdir_regex = re.compile(r'/tmp/tmp[^/]*-checkpackagelib-test-tool')
  7. def check_file(tool, filename, string, permissions=None):
  8. with tempfile.TemporaryDirectory(suffix='-checkpackagelib-test-tool') as workdir:
  9. script = os.path.join(workdir, filename)
  10. with open(script, 'wb') as f:
  11. f.write(string.encode())
  12. if permissions:
  13. os.chmod(script, permissions)
  14. obj = tool(script)
  15. result = obj.run()
  16. if result is None:
  17. return []
  18. return [workdir_regex.sub('dir', r) for r in result]
  19. NotExecutable = [
  20. ('664',
  21. 'package.mk',
  22. 0o664,
  23. '',
  24. []),
  25. ('775',
  26. 'package.mk',
  27. 0o775,
  28. '',
  29. ["dir/package.mk:0: This file does not need to be executable"]),
  30. ]
  31. @pytest.mark.parametrize('testname,filename,permissions,string,expected', NotExecutable)
  32. def test_NotExecutable(testname, filename, permissions, string, expected):
  33. warnings = check_file(m.NotExecutable, filename, string, permissions)
  34. assert warnings == expected
  35. NotExecutable_hint = [
  36. ('no hint',
  37. "",
  38. 'sh-shebang.sh',
  39. 0o775,
  40. '#!/bin/sh',
  41. ["dir/sh-shebang.sh:0: This file does not need to be executable"]),
  42. ('hint',
  43. ", very special hint",
  44. 'sh-shebang.sh',
  45. 0o775,
  46. '#!/bin/sh',
  47. ["dir/sh-shebang.sh:0: This file does not need to be executable, very special hint"]),
  48. ]
  49. @pytest.mark.parametrize('testname,hint,filename,permissions,string,expected', NotExecutable_hint)
  50. def test_NotExecutable_hint(testname, hint, filename, permissions, string, expected):
  51. class NotExecutable(m.NotExecutable):
  52. def hint(self):
  53. return hint
  54. warnings = check_file(NotExecutable, filename, string, permissions)
  55. assert warnings == expected