summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/LoadableModule.py117
-rw-r--r--test/SWIG/SWIG.py53
-rw-r--r--test/import.py1
3 files changed, 159 insertions, 12 deletions
diff --git a/test/LoadableModule.py b/test/LoadableModule.py
new file mode 100644
index 0000000..f3b1959
--- /dev/null
+++ b/test/LoadableModule.py
@@ -0,0 +1,117 @@
+#!/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 string
+import sys
+
+import TestCmd
+import TestSCons
+
+dll_ = TestSCons.dll_
+_dll = TestSCons._dll
+
+test = TestSCons.TestSCons()
+
+# Some systems apparently need -ldl on the link line, others don't.
+no_dl_lib = "env.Program(target = 'dlopenprog', source = 'dlopenprog.c')"
+use_dl_lib = "env.Program(target = 'dlopenprog', source = 'dlopenprog.c', LIBS=['dl'])"
+
+dlopen_line = {
+ 'darwin' : no_dl_lib,
+ 'freebsd4' : no_dl_lib,
+ 'linux2' : use_dl_lib,
+}
+platforms_with_dlopen = dlopen_line.keys()
+
+test.write('SConstruct', """
+env = Environment()
+# dlopenprog tries to dynamically load foo1 at runtime using dlopen().
+env.LoadableModule(target = 'foo1', source = 'f1.c')
+""" + dlopen_line.get(sys.platform, ''))
+
+
+test.write('f1.c', r"""
+#include <stdio.h>
+
+void
+f1(void)
+{
+ printf("f1.c\n");
+ fflush(stdout);
+}
+""")
+
+dlopenprog = r"""
+#include <errno.h>
+#include <stdio.h>
+#include <dlfcn.h>
+
+extern int errno;
+
+int
+main(int argc, char *argv[])
+{
+ argv[argc++] = "--";
+ void *foo1_shobj = dlopen("__foo1_name__", RTLD_NOW);
+ if(!foo1_shobj){
+ printf("Error loading foo1 '__foo1_name__' library at runtime, exiting.\n");
+ printf("%d\n", errno);
+ perror("");
+ return -1;
+ }
+ void (*f1)() = dlsym(foo1_shobj, "f1\0");
+ (*f1)();
+ printf("dlopenprog.c\n");
+ dlclose(foo1_shobj);
+ return 0;
+}
+"""
+
+# Darwin dlopen()s a bundle name "foo1",
+# other systems dlopen() a traditional libfoo1.so file.
+foo1_name = {'darwin' : 'foo1'}.get(sys.platform, dll_+'foo1'+_dll)
+
+test.write('dlopenprog.c',
+ string.replace(dlopenprog, '__foo1_name__', foo1_name))
+
+test.run(arguments = '.',
+ stderr=TestSCons.noisy_ar,
+ match=TestSCons.match_re_dotall)
+
+if string.find(sys.platform, 'darwin') != -1:
+ test.run(program='/usr/bin/file',
+ arguments = "foo1",
+ stdout="foo1: Mach-O bundle ppc\n")
+
+if sys.platform in platforms_with_dlopen:
+ os.environ['LD_LIBRARY_PATH'] = test.workpath()
+ test.run(program = test.workpath('dlopenprog'),
+ stdout = "f1.c\ndlopenprog.c\n")
+
+
+
+test.pass_test()
diff --git a/test/SWIG/SWIG.py b/test/SWIG/SWIG.py
index 2a0ee32..af76d6c 100644
--- a/test/SWIG/SWIG.py
+++ b/test/SWIG/SWIG.py
@@ -29,10 +29,24 @@ import string
import sys
import TestSCons
-python = TestSCons.python
+if sys.platform =='darwin':
+ # change to make it work with stock OS X python framework
+ # we can't link to static libpython because there isn't one on OS X
+ # so we link to a framework version. However, testing must also
+ # use the same version, or else you get interpreter errors.
+ python = "/System/Library/Frameworks/Python.framework/Versions/Current/bin/python"
+else:
+ python = TestSCons.python
+
_exe = TestSCons._exe
_obj = TestSCons._obj
-_dll = TestSCons._dll
+
+# swig-python expects specific filenames.
+# the platform specific suffix won't necessarily work.
+if sys.platform == 'win32':
+ _dll = '.dll'
+else:
+ _dll = '.so'
test = TestSCons.TestSCons()
@@ -106,6 +120,18 @@ if swig:
version = sys.version[:3] # see also sys.prefix documentation
+ # handle testing on other platforms:
+ frameworks = ''
+ ldmodule_prefix = ''
+ platform_sys_prefix = sys.prefix
+ if sys.platform == 'darwin':
+ # OS X has a built-in Python but no static libpython
+ # so you should link to it using apple's 'framework' scheme.
+ # (see top of file for further explanation)
+ frameworks = '-framework Python'
+ ldmodule_prefix = '_'
+ platform_sys_prefix = '/System/Library/Frameworks/Python.framework/Versions/%s/' % version
+
test.write("wrapper.py",
"""import os
import string
@@ -116,15 +142,18 @@ os.system(string.join(sys.argv[1:], " "))
test.write('SConstruct', """
foo = Environment(SWIGFLAGS='-python',
- CPPPATH='%s/include/python%s/',
+ CPPPATH='%(platform_sys_prefix)s/include/python%(version)s/',
SHCCFLAGS='',
- SHOBJSUFFIX='.o',
- SHLIBPREFIX='')
+ LDMODULEPREFIX='%(ldmodule_prefix)s',
+ LDMODULESUFFIX='%(_dll)s',
+ FRAMEWORKSFLAGS='%(frameworks)s',
+ )
+
swig = foo.Dictionary('SWIG')
-bar = foo.Copy(SWIG = r'%s wrapper.py ' + swig)
-foo.SharedLibrary(target = 'foo', source = ['foo.c', 'foo.i'])
-bar.SharedLibrary(target = 'bar', source = ['bar.c', 'bar.i'])
-""" % (sys.prefix, version, python))
+bar = foo.Copy(SWIG = r'%(python)s wrapper.py ' + swig)
+foo.LoadableModule(target = 'foo', source = ['foo.c', 'foo.i'])
+bar.LoadableModule(target = 'bar', source = ['bar.c', 'bar.i'])
+""" % locals())
test.write("foo.c", """\
char *
@@ -160,7 +189,7 @@ bar_string()
extern char *bar_string();
""")
- test.run(arguments = 'foo' + _dll)
+ test.run(arguments = ldmodule_prefix+'foo' + _dll)
test.fail_test(os.path.exists(test.workpath('wrapper.out')))
@@ -171,9 +200,9 @@ print foo.foo_string()
This is foo.c!
""")
- test.up_to_date(arguments = 'foo' + _dll)
+ test.up_to_date(arguments = ldmodule_prefix+'foo' + _dll)
- test.run(arguments = 'bar' + _dll)
+ test.run(arguments = ldmodule_prefix+'bar' + _dll)
test.fail_test(test.read('wrapper.out') != "wrapper.py\n")
diff --git a/test/import.py b/test/import.py
index a8a86bf..1aae7ce 100644
--- a/test/import.py
+++ b/test/import.py
@@ -59,6 +59,7 @@ tools = [
'aixcc',
'aixf77',
'aixlink',
+ 'applelink',
'ar',
'as',
'bcc32',