diff options
author | Nan Zhang <nanzhang@google.com> | 2018-05-24 18:59:04 -0700 |
---|---|---|
committer | android-build-merger <android-build-merger@google.com> | 2018-05-24 18:59:04 -0700 |
commit | a3209a1079bbe0d57820a93b1d2153719818c259 (patch) | |
tree | 7f63dc937b886389e53ee3b386c70baebd1da8e1 /setuptools/tests/test_build_clib.py | |
parent | e493fcf90483ade4b2a5ac331a4f89cb15ae3fd2 (diff) | |
parent | 21d497cb588c40b2a891d9a862f56e108b427e4c (diff) | |
download | setuptools-a3209a1079bbe0d57820a93b1d2153719818c259.tar.gz |
initial drop of setuptools v39.1.0 am: 8539a2ae46 am: c498e8445a
am: 21d497cb58
Change-Id: I0d9ec0d7323b37baa8a7550c6aec27e05af57415
Diffstat (limited to 'setuptools/tests/test_build_clib.py')
-rw-r--r-- | setuptools/tests/test_build_clib.py | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/setuptools/tests/test_build_clib.py b/setuptools/tests/test_build_clib.py new file mode 100644 index 0000000..aebcc35 --- /dev/null +++ b/setuptools/tests/test_build_clib.py @@ -0,0 +1,59 @@ +import pytest +import os +import shutil + +import mock +from distutils.errors import DistutilsSetupError +from setuptools.command.build_clib import build_clib +from setuptools.dist import Distribution + + +class TestBuildCLib: + @mock.patch( + 'setuptools.command.build_clib.newer_pairwise_group' + ) + def test_build_libraries(self, mock_newer): + dist = Distribution() + cmd = build_clib(dist) + + # this will be a long section, just making sure all + # exceptions are properly raised + libs = [('example', {'sources': 'broken.c'})] + with pytest.raises(DistutilsSetupError): + cmd.build_libraries(libs) + + obj_deps = 'some_string' + libs = [('example', {'sources': ['source.c'], 'obj_deps': obj_deps})] + with pytest.raises(DistutilsSetupError): + cmd.build_libraries(libs) + + obj_deps = {'': ''} + libs = [('example', {'sources': ['source.c'], 'obj_deps': obj_deps})] + with pytest.raises(DistutilsSetupError): + cmd.build_libraries(libs) + + obj_deps = {'source.c': ''} + libs = [('example', {'sources': ['source.c'], 'obj_deps': obj_deps})] + with pytest.raises(DistutilsSetupError): + cmd.build_libraries(libs) + + # with that out of the way, let's see if the crude dependency + # system works + cmd.compiler = mock.MagicMock(spec=cmd.compiler) + mock_newer.return_value = ([],[]) + + obj_deps = {'': ('global.h',), 'example.c': ('example.h',)} + libs = [('example', {'sources': ['example.c'] ,'obj_deps': obj_deps})] + + cmd.build_libraries(libs) + assert [['example.c', 'global.h', 'example.h']] in mock_newer.call_args[0] + assert not cmd.compiler.compile.called + assert cmd.compiler.create_static_lib.call_count == 1 + + # reset the call numbers so we can test again + cmd.compiler.reset_mock() + + mock_newer.return_value = '' # anything as long as it's not ([],[]) + cmd.build_libraries(libs) + assert cmd.compiler.compile.call_count == 1 + assert cmd.compiler.create_static_lib.call_count == 1 |