summaryrefslogtreecommitdiffstats
path: root/src/engine/SCons/TaskmasterTests.py
diff options
context:
space:
mode:
authorSteven Knight <knight@baldmt.com>2003-03-03 06:28:49 (GMT)
committerSteven Knight <knight@baldmt.com>2003-03-03 06:28:49 (GMT)
commitbc08cde50aee2b6a495506819b97014fdb880058 (patch)
treeb1fbe65c9b6724de14ba2415d873b5cbe8bcc6a4 /src/engine/SCons/TaskmasterTests.py
parentb2955d7ab85b8aaa5a1f2c18e8e4329a43981a34 (diff)
downloadSCons-bc08cde50aee2b6a495506819b97014fdb880058.zip
SCons-bc08cde50aee2b6a495506819b97014fdb880058.tar.gz
SCons-bc08cde50aee2b6a495506819b97014fdb880058.tar.bz2
Don't eat scanner exceptions.
Diffstat (limited to 'src/engine/SCons/TaskmasterTests.py')
-rw-r--r--src/engine/SCons/TaskmasterTests.py45
1 files changed, 39 insertions, 6 deletions
diff --git a/src/engine/SCons/TaskmasterTests.py b/src/engine/SCons/TaskmasterTests.py
index 5a19c56..2f9383a 100644
--- a/src/engine/SCons/TaskmasterTests.py
+++ b/src/engine/SCons/TaskmasterTests.py
@@ -385,8 +385,8 @@ class TaskmasterTestCase(unittest.TestCase):
n1 = Node("n1")
tm = SCons.Taskmaster.Taskmaster(targets = [n1], tasker = MyTask)
t = tm.next_task()
- assert n1.exc_type == MyException, n1.exc_type
- assert str(n1.exc_value) == "from make_ready()", n1.exc_value
+ assert tm.exc_type == MyException, tm.exc_type
+ assert str(tm.exc_value) == "from make_ready()", tm.exc_value
def test_children_errors(self):
@@ -398,8 +398,8 @@ class TaskmasterTestCase(unittest.TestCase):
n1 = MyNode("n1")
tm = SCons.Taskmaster.Taskmaster([n1])
t = tm.next_task()
- assert n1.exc_type == SCons.Errors.StopError, "Did not record StopError on node"
- assert str(n1.exc_value) == "stop!", "Unexpected exc_value `%s'" % n1.exc_value
+ assert tm.exc_type == SCons.Errors.StopError, "Did not record StopError on node"
+ assert str(tm.exc_value) == "stop!", "Unexpected exc_value `%s'" % tm.exc_value
def test_cycle_detection(self):
"""Test detecting dependency cycles
@@ -590,9 +590,9 @@ class TaskmasterTestCase(unittest.TestCase):
built_text = None
n5 = Node("n5")
- n5.exc_type = MyException
- n5.exc_value = "exception value"
tm = SCons.Taskmaster.Taskmaster([n5])
+ tm.exc_type = MyException
+ tm.exc_value = "exception value"
t = tm.next_task()
exc_caught = None
try:
@@ -603,6 +603,39 @@ class TaskmasterTestCase(unittest.TestCase):
assert exc_caught, "did not catch expected MyException"
assert built_text is None, built_text
+ def test_exception(self):
+ """Test generic Taskmaster exception handling
+
+ """
+ n1 = Node("n1")
+ tm = SCons.Taskmaster.Taskmaster([n1])
+
+ tm.exception_set(1, 2)
+ assert tm.exc_type == 1, tm.exc_type
+ assert tm.exc_value == 2, tm.exc_value
+
+ tm.exception_set(None, None)
+ assert tm.exc_type is None, tm.exc_type
+ assert tm.exc_value is None, tm.exc_value
+
+ tm.exception_set("exception 1", None)
+ try:
+ tm.exception_raise()
+ except:
+ assert sys.exc_type == "exception 1", sys.exc_type
+ assert sys.exc_value is None, sys.exc_type
+ else:
+ assert 0, "did not catch expected exception"
+
+ tm.exception_set("exception 2", "xyzzy")
+ try:
+ tm.exception_raise()
+ except:
+ assert sys.exc_type == "exception 2", sys.exc_type
+ assert sys.exc_value == "xyzzy", sys.exc_type
+ else:
+ assert 0, "did not catch expected exception"
+
if __name__ == "__main__":