diff options
author | dgp <dgp@users.sourceforge.net> | 2014-04-30 19:54:51 (GMT) |
---|---|---|
committer | dgp <dgp@users.sourceforge.net> | 2014-04-30 19:54:51 (GMT) |
commit | 1c909a3352991d577a7164d5bb33dbe8d295ae67 (patch) | |
tree | acaeb4805a0e2fcbd41822f04c25627ccf73c65b /tests/ioCmd.test | |
parent | 1264e873bbaae9d4328826b749e459e88b32e820 (diff) | |
download | tcl-1c909a3352991d577a7164d5bb33dbe8d295ae67.zip tcl-1c909a3352991d577a7164d5bb33dbe8d295ae67.tar.gz tcl-1c909a3352991d577a7164d5bb33dbe8d295ae67.tar.bz2 |
Stop the segfaults in [close] during [gets] tests.
Not sure this is the right behavior, but it's better than crashing.
Diffstat (limited to 'tests/ioCmd.test')
-rw-r--r-- | tests/ioCmd.test | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/tests/ioCmd.test b/tests/ioCmd.test index d2c0173..bb133f9 100644 --- a/tests/ioCmd.test +++ b/tests/ioCmd.test @@ -818,10 +818,27 @@ test iocmd-21.23 {[close] in [gets] segfaults} -setup { set ch [chan create read foo] } -body { gets $ch -} -returnCodes error -cleanup { +} -cleanup { catch {close $ch} rename foo {} -} -match glob -result {*invalid argument*} +} -result {} +test iocmd-21.24 {[close] in binary [gets] segfaults} -setup { + proc foo {method chan args} { + switch -- $method initialize { + return {initialize finalize watch read} + } finalize {} watch {} read { + catch {close $chan} + return \n + } + } + set ch [chan create read foo] +} -body { + chan configure $ch -translation binary + gets $ch +} -cleanup { + catch {close $ch} + rename foo {} +} -result {} # --- --- --- --------- --------- --------- # Helper commands to record the arguments to handler methods. |