summaryrefslogtreecommitdiff
path: root/test/option
diff options
context:
space:
mode:
authorSteven Knight <knight@baldmt.com>2008-10-17 02:20:50 +0000
committerSteven Knight <knight@baldmt.com>2008-10-17 02:20:50 +0000
commit01cab312a2fe7a052ac7dd81c56ffdfb7bf073e0 (patch)
tree9f16c8e29ffb2466c50b267a7d6f4c7c186729df /test/option
parent7c7b06f0423f8b1d32970407ac3eeda94f4516bc (diff)
downloadscons-01cab312a2fe7a052ac7dd81c56ffdfb7bf073e0.tar.gz
Issue 1568: fix a stack trace when --debug=include tries to handle
a library as an argument.
Diffstat (limited to 'test/option')
-rw-r--r--test/option/debug-includes.py24
1 files changed, 20 insertions, 4 deletions
diff --git a/test/option/debug-includes.py b/test/option/debug-includes.py
index 70857e66..41e5a842 100644
--- a/test/option/debug-includes.py
+++ b/test/option/debug-includes.py
@@ -38,8 +38,16 @@ import time
test = TestSCons.TestSCons()
test.write('SConstruct', """
-env = Environment(OBJSUFFIX = '.ooo', PROGSUFFIX = '.xxx')
-env.Program('foo', Split('foo.c bar.c'))
+env = Environment(OBJSUFFIX = '.obj',
+ SHOBJSUFFIX = '.shobj',
+ LIBPREFIX = '',
+ LIBSUFFIX = '.lib',
+ SHLIBPREFIX = '',
+ SHLIBSUFFIX = '.shlib',
+ )
+env.Program('foo.exe', ['foo.c', 'bar.c'])
+env.StaticLibrary('foo', ['foo.c', 'bar.c'])
+env.SharedLibrary('foo', ['foo.c', 'bar.c'])
""")
test.write('foo.c', r"""
@@ -78,7 +86,7 @@ includes = """
+-foo.h
+-bar.h
"""
-test.run(arguments = "--debug=includes foo.ooo")
+test.run(arguments = "--debug=includes foo.obj")
if string.find(test.stdout(), includes) == -1:
print "Did not find expected string in standard output."
@@ -88,6 +96,8 @@ if string.find(test.stdout(), includes) == -1:
print test.stdout()
test.fail_test()
+
+
# In an ideal world, --debug=includes would also work when there's a build
# failure, but this would require even more complicated logic to scan
# all of the intermediate nodes that get skipped when the build failure
@@ -102,14 +112,20 @@ if string.find(test.stdout(), includes) == -1:
#THIS SHOULD CAUSE A BUILD FAILURE
#""")
-#test.run(arguments = "--debug=includes foo.xxx",
+#test.run(arguments = "--debug=includes foo.exe",
# status = 2,
# stderr = None)
#test.fail_test(string.find(test.stdout(), includes) == -1)
+
+
# These shouldn't print out anything in particular, but
# they shouldn't crash either:
test.run(arguments = "--debug=includes .")
test.run(arguments = "--debug=includes foo.c")
+test.run(arguments = "--debug=includes foo.lib")
+test.run(arguments = "--debug=includes foo.shlib")
+
+
test.pass_test()