testRender.py tests

This commit is contained in:
Ben Steadman 2019-03-29 20:03:49 +00:00
parent d11bf1306d
commit 9db2ececb8
2 changed files with 109 additions and 0 deletions

View File

@ -19,6 +19,7 @@ from test_contributors import TestContributors
from test_cyrillic_convert import TestCyrillicConvert
from test_playerInspect import TestPlayerInspect
from test_regionTrimmer import TestRegionTrimmer
from test_testRender import TestTestRender
# DISABLE THIS BLOCK TO GET LOG OUTPUT FROM TILESET FOR DEBUGGING
if 0:

108
test/test_testRender.py Normal file
View File

@ -0,0 +1,108 @@
import tempfile
import unittest
from unittest.mock import patch
from subprocess import CalledProcessError, PIPE, STDOUT
import contrib.testRender as test_render
from io import StringIO
from shlex import split
class TestTestRender(unittest.TestCase):
@patch("contrib.testRender.run")
def test_check_call_raises_CalledProcessError_from_subprocess_run(self, m_run):
m_run.side_effect = CalledProcessError(1, "python program.js")
with self.assertRaises(CalledProcessError):
test_render.check_call(["python", "program.js"])
@patch("contrib.testRender.run")
def test_check_call_captures_stdout_if_not_verbose(self, m_run):
test_render.check_call(["python", "program.py"])
args, kwargs = m_run.call_args
self.assertEqual(kwargs['stdout'], PIPE)
self.assertEqual(kwargs['stderr'], STDOUT)
@patch("contrib.testRender.run")
def test_check_call_does_not_capture_stdout_if_verbose(self, m_run):
test_render.check_call(["python", "program.py"], verbose=True)
args, kwargs = m_run.call_args
self.assertEqual(kwargs['stdout'], None)
self.assertEqual(kwargs['stderr'], None)
@patch('sys.stdout', new_callable=StringIO)
@patch("contrib.testRender.run")
def test_check_call_prints_exception_output_if_verbose(self, m_run, m_out):
m_run.side_effect = CalledProcessError(
1, "python program.js", output="SyntaxError: invalid syntax")
with self.assertRaises(CalledProcessError):
test_render.check_call(["python", "program.js"], verbose=True)
self.assertEqual(m_out.getvalue().strip(), "SyntaxError: invalid syntax")
@patch("contrib.testRender.run")
def test_check_output_captures_stdout(self, m_run):
test_render.check_call(["python", "program.py"])
args, kwargs = m_run.call_args
self.assertEqual(kwargs['stdout'], PIPE)
@patch('contrib.testRender.check_output')
def test_get_commits(self, m_check_output):
gitrange = '2eca1a5fb5fa7eeb5494abb350cd535f67acfb8b..08a86a52abfabd59ac68b37dc7e5270bd7fb328a'
m_check_output.return_value = (
"commit 2eca1a5fb5fa7eeb5494abb350cd535f67acfb8b\nAuthor: Andrew "
"<andrew@fry.(none)>\nDate: Sun Aug 22 10:16:10 2010 -0400\n\n "
" initial comit\n\n:000000 100644 0000000 c398ada A\tchunk.py\n:000000 "
"100644 0000000 d5ee6ed A\tnbt.py\n:000000 100644 0000000 8fc65c9 A\ttextures.py\n:"
"000000 100644 0000000 6934326 A\tworld.py\n\ncommit 08a86a52abfabd59ac68b37dc7e5270bd7fb328a"
"\nAuthor: Andrew <andrew@fry.(none)>\nDate: Tue Aug 24 21:11:57 2010 -0400\n\n "
"uses multiprocessing to speed up rendering. Caches chunks\n\n:1"
)
result = list(test_render.get_commits(gitrange))
self.assertListEqual(result, ['2eca1a5fb5fa7eeb5494abb350cd535f67acfb8b',
'08a86a52abfabd59ac68b37dc7e5270bd7fb328a'])
@patch('contrib.testRender.check_output', return_value="my-feature-branch")
def test_get_current_branch(self, m_check_output):
self.assertEqual(test_render.get_current_branch(), "my-feature-branch")
@patch('contrib.testRender.check_output', return_value="HEAD")
def test_get_current_branch_returns_none_for_detached_head(self, m_check_output):
self.assertIsNone(test_render.get_current_branch())
@patch('contrib.testRender.check_output', return_value="3f1f3d748e1c79843279ba18ab65a34368b95b67")
def test_get_current_commit(self, m_check_output):
self.assertEqual(
test_render.get_current_branch(),
"3f1f3d748e1c79843279ba18ab65a34368b95b67"
)
@patch('contrib.testRender.get_current_branch', return_value="my-feature-branch")
def test_get_current_ref_returns_branch_name_if_possible(self, m_branch):
self.assertEqual(test_render.get_current_ref(), "my-feature-branch")
@patch('contrib.testRender.get_current_commit', return_value="3f1f3d748e1c79843279ba18ab65a34368b95b67")
@patch('contrib.testRender.get_current_branch', return_value=None)
def test_get_current_ref_returns_current_commit_if_no_branch(self, m_branch, m_commit):
self.assertEqual(
test_render.get_current_ref(),
"3f1f3d748e1c79843279ba18ab65a34368b95b67"
)
@patch('contrib.testRender.check_output')
def test_get_commits(self, m_check_output):
m_check_output.return_value = "\n".join(
[
"41ceaeab58473416bb79680ab21211764e6f1908",
"a4d0daa91c25a51ca95182301e503c020900dafe",
"05906c81f5778a543dfab14e77231db0a99bae24",
]
)
gitrange = "41ceaeab58473416bb79680ab21211764e6f1908..05906c81f5778a543dfab14e77231db0a99bae24"
result = list(test_render.get_commits(gitrange))
self.assertListEqual(
result,
[
"41ceaeab58473416bb79680ab21211764e6f1908",
"a4d0daa91c25a51ca95182301e503c020900dafe",
"05906c81f5778a543dfab14e77231db0a99bae24"
]
)