diff options
author | Pawel Tomulik <ptomulik@meil.pw.edu.pl> | 2016-05-14 18:59:00 (GMT) |
---|---|---|
committer | Pawel Tomulik <ptomulik@meil.pw.edu.pl> | 2016-05-14 18:59:00 (GMT) |
commit | 37eb6eeaa3dc3d850b784b6f808b710836a6c244 (patch) | |
tree | 5697ac5435cf4eae10a1cfe1f52af3d13c9eedd5 | |
parent | 67769cb3a7673604be8e1ddcc8af2f3be552d905 (diff) | |
download | SCons-37eb6eeaa3dc3d850b784b6f808b710836a6c244.zip SCons-37eb6eeaa3dc3d850b784b6f808b710836a6c244.tar.gz SCons-37eb6eeaa3dc3d850b784b6f808b710836a6c244.tar.bz2 |
regression tests for #319
-rw-r--r-- | src/engine/SCons/Script/__init__.py | 1 | ||||
-rw-r--r-- | test/LINK/LDMODULEVERSIONFLAGS.py | 71 | ||||
-rw-r--r-- | test/LINK/SHLIBVERSIONFLAGS.py | 28 |
3 files changed, 91 insertions, 9 deletions
diff --git a/src/engine/SCons/Script/__init__.py b/src/engine/SCons/Script/__init__.py index a0c61c5..be6e5ce 100644 --- a/src/engine/SCons/Script/__init__.py +++ b/src/engine/SCons/Script/__init__.py @@ -354,6 +354,7 @@ GlobalDefaultBuilders = [ 'Java', 'JavaH', 'Library', + 'LoadableModule', 'M4', 'MSVSProject', 'Object', diff --git a/test/LINK/LDMODULEVERSIONFLAGS.py b/test/LINK/LDMODULEVERSIONFLAGS.py new file mode 100644 index 0000000..5a9a847 --- /dev/null +++ b/test/LINK/LDMODULEVERSIONFLAGS.py @@ -0,0 +1,71 @@ +#!/usr/bin/env python +# +# __COPYRIGHT__ +# +# Permission is hereby granted, free of charge, to any person obtaining +# a copy of this software and associated documentation files (the +# "Software"), to deal in the Software without restriction, including +# without limitation the rights to use, copy, modify, merge, publish, +# distribute, sublicense, and/or sell copies of the Software, and to +# permit persons to whom the Software is furnished to do so, subject to +# the following conditions: +# +# The above copyright notice and this permission notice shall be included +# in all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY +# KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE +# WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE +# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION +# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION +# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. +# + +__revision__ = "__FILE__ __REVISION__ __DATE__ __DEVELOPER__" + +import os +import re + +import TestSCons +import SCons.Platform +import SCons.Defaults + +foo_c_src = "void foo() {}\n" + +env = SCons.Defaults.DefaultEnvironment() +platform = SCons.Platform.platform_default() +tool_list = SCons.Platform.DefaultToolList(platform, env) + + +test = TestSCons.TestSCons() +if 'gnulink' in tool_list: + versionflags = r".+ -Wl,-Bsymbolic -Wl,-soname=libfoo.so.1( .+)+" +elif 'sunlink' in tool_list: + versionflags = r".+ -h libfoo.so.1( .+)+" +else: + test.skip_test('No testable likers found, skipping the test\n') + + +# We expect stdout to not contain LDMODULEVERSIONFLAGS if there is no +# SHLIBVERSION nor LDMODULEVERSION provided +test.write('foo.c', foo_c_src) +test.write('SConstruct', "LoadableModule('foo','foo.c')\n") +test.run() +test.fail_test(test.match_re_dotall(test.stdout(), versionflags)) +test.run(arguments = ['-c']) + +for versionvar in ['SHLIBVERSION', 'LDMODULEVERSION']: + test = TestSCons.TestSCons() + test.write('foo.c', foo_c_src) + test.write('SConstruct', "LoadableModule('foo','foo.c',%s='1.2.3')\n" % versionvar) + test.run(stdout = versionflags, match = TestSCons.match_re_dotall) + test.run(arguments = ['-c']) + +test.pass_test() + +# Local Variables: +# tab-width:4 +# indent-tabs-mode:nil +# End: +# vim: set expandtab tabstop=4 shiftwidth=4: diff --git a/test/LINK/SHLIBVERSIONFLAGS.py b/test/LINK/SHLIBVERSIONFLAGS.py index d8fd2e6..7f7975f 100644 --- a/test/LINK/SHLIBVERSIONFLAGS.py +++ b/test/LINK/SHLIBVERSIONFLAGS.py @@ -31,8 +31,6 @@ import TestSCons import SCons.Platform import SCons.Defaults -linkers = [ 'gnulink', 'cyglink', 'sunlink' ] - foo_c_src = "void foo() {}\n" env = SCons.Defaults.DefaultEnvironment() @@ -40,15 +38,27 @@ platform = SCons.Platform.platform_default() tool_list = SCons.Platform.DefaultToolList(platform, env) test = TestSCons.TestSCons() -test.write('foo.c', foo_c_src) -test.write('SConstruct', "SharedLibrary('foo','foo.c',SHLIBVERSION='1.2.3')\n") - if 'gnulink' in tool_list: - test.run(stdout = r".+ -Wl,-Bsymbolic -Wl,-soname=libfoo.so.1( .+)+", match = TestSCons.match_re_dotall) - test.run(arguments = ['-c']) + versionflags = r".+ -Wl,-Bsymbolic -Wl,-soname=libfoo.so.1( .+)+" elif 'sunlink' in tool_list: - test.run(stdout = r".+ -h libfoo.so.1( .+)+", match = TestSCons.match_re_dotall) - test.run(arguments = ['-c']) + versionflags = r".+ -h libfoo.so.1( .+)+" +else: + test.skip_test('No testable likers found, skipping the test\n') + + +# stdout must not contain SHLIBVERSIONFLAGS if there is no SHLIBVERSION provided +test.write('foo.c', foo_c_src) +test.write('SConstruct', "SharedLibrary('foo','foo.c')\n") +test.run() +test.fail_test(test.match_re_dotall(test.stdout(), versionflags)) +test.run(arguments = ['-c']) + +# stdout must contain SHLIBVERSIONFLAGS if there is SHLIBVERSION provided +test = TestSCons.TestSCons() +test.write('foo.c', foo_c_src) +test.write('SConstruct', "SharedLibrary('foo','foo.c',SHLIBVERSION='1.2.3')\n") +test.run(stdout = versionflags, match = TestSCons.match_re_dotall) +test.run(arguments = ['-c']) test.pass_test() |