[#18186] [req] Marshal — keiju@... (Keiju ISHITSUKA)

けいじゅ@日本ラショナルソフトウェアです.

14 messages 2002/09/05
[#18190] Re: [req] Marshal — matz@... (Yukihiro Matsumoto) 2002/09/05

まつもと ゆきひろです

[#18229] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — "U.Nakamura" <usa@...>

こんにちは、なかむら(う)です。

22 messages 2002/09/09
[#18230] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — nobu.nakada@... 2002/09/09

なかだです。

[#18231] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — "U.Nakamura" <usa@...> 2002/09/09

こんにちは、なかむら(う)です。

[#18232] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — nobu.nakada@... 2002/09/09

なかだです。

[#18233] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — "U.Nakamura" <usa@...> 2002/09/09

こんにちは、なかむら(う)です。

[#18234] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — WATANABE Hirofumi <eban@...> 2002/09/09

わたなべです。

[#18236] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — "U.Nakamura" <usa@...> 2002/09/09

こんにちは、なかむら(う)です。

[#18238] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — WATANABE Hirofumi <eban@...> 2002/09/09

わたなべです。

[#18241] Re: [ruby-cvs] rough/ext/stringio: * ruby-stringio.spec: 0.0.7, added changelog. — "U.Nakamura" <usa@...> 2002/09/09

こんにちは、なかむら(う)です。

[#18285] rubicon on EWS4800 — Koji Arai <JCA02266@...>

新井です。

59 messages 2002/09/13
[#18322] Re: rubicon on EWS4800 — Koji Arai <JCA02266@...> 2002/09/21

新井です。

[#18333] Re: rubicon on EWS4800 — kjana@...4lab.to (YANAGAWA Kazuhisa) 2002/09/21

In message <20020921.152641.11483667.JCA02266@nifty.ne.jp>

[#18336] Re: rubicon on EWS4800 — nobu.nakada@... 2002/09/21

なかだです。

[#18337] Re: rubicon on EWS4800 — Tanaka Akira <akr@...17n.org> 2002/09/21

In article <200209211605.g8LG52p04564@sharui.nakada.kanuma.tochigi.jp>,

[#18338] Re: rubicon on EWS4800 — nobu.nakada@... 2002/09/21

なかだです。

[#18341] Re: rubicon on EWS4800 — Tanaka Akira <akr@...17n.org> 2002/09/21

In article <200209211628.g8LGSxp04786@sharui.nakada.kanuma.tochigi.jp>,

[#18342] Re: rubicon on EWS4800 — nobu.nakada@... 2002/09/21

なかだです。

[#18343] Re: rubicon on EWS4800 — Tanaka Akira <akr@...17n.org> 2002/09/21

In article <200209211739.g8LHdKp05495@sharui.nakada.kanuma.tochigi.jp>,

[#18345] Re: rubicon on EWS4800 — nobu.nakada@... 2002/09/22

なかだです。

[#18349] Re: rubicon on EWS4800 — Tanaka Akira <akr@...17n.org> 2002/09/22

In article <200209220415.g8M4Fkp24392@sharui.nakada.kanuma.tochigi.jp>,

[#18374] Re: [ruby-cvs] ruby/ext/tcltklib: * eval.c (ruby_run): should set toplevel visibility again here. — WATANABE Hirofumi <eban@...>

わたなべです。

20 messages 2002/09/25
[#18376] Re: [ruby-cvs] ruby/ext/tcltklib: * eval.c (ruby_run): should set toplevel visibility again here. — matz@... (Yukihiro Matsumoto) 2002/09/25

まつもと ゆきひろです

[#18377] Re: [ruby-cvs] ruby/ext/tcltklib: * eval.c (ruby_run): should set toplevel visibility again here. — nobu.nakada@... 2002/09/25

なかだです。

[#18378] Re: [ruby-cvs] ruby/ext/tcltklib: * eval.c (ruby_run): should set toplevel visibility again here. — WATANABE Hirofumi <eban@...> 2002/09/25

わたなべです。

[ruby-dev:18339] Re: rubicon on EWS4800

From: nobu.nakada@...
Date: 2002-09-21 16:54:21 UTC
List: ruby-dev #18339
なかだです。

At Sun, 22 Sep 2002 00:50:26 +0900,
Yukihiro Matsumoto wrote:
> |んで、テスト自体は失敗することがあるようなんですがこれはどうなんでしょう?
> |あ、失敗するんじゃなくて、メッセージが出てしまうだけか。
> 
> TestThreadはなんかタイミングに依存する部分があるようでときど
> き失敗します。これはそういうものだと解釈してます。つまり、一
> 流のソフトウェアコンサルタント(Dave Thomas)にもバグなしには
> かけないほどThreadは難しいと。

メッセージが出てしまうのは、Threadとは別の問題のようです。タイ
ミングに依存してるのはThread.passの順序に頼ってるところではない
かと。


Index: TestThread.rb
===================================================================
RCS file: /cvs/ruby/src/rubicon/builtin/TestThread.rb,v
retrieving revision 1.19
diff -u -2 -p -Fdef -r1.19 TestThread.rb
--- rubicon/builtin/TestThread.rb	10 Nov 2001 04:53:16 -0000	1.19
+++ rubicon/builtin/TestThread.rb	21 Sep 2002 16:44:37 -0000
@@ -90,6 +90,4 @@     # Test default
 
   def test_abort_on_exception=()
-    skipping("Can't find a test for all platforms")
-    return
     save_stderr = nil
     begin
@@ -103,19 +101,22 @@   def test_abort_on_exception=()
         assert_fail("Thread exception propogated to main thread")
       end
-      
+
+      msg = nil
       begin
-        Thread.new do
+        t = Thread.new do
           Thread.current.abort_on_exception = true
-          save_stderr = $stderr
-          $stderr = nil
+          save_stderr = $stderr.dup
+          $stderr.reopen(open("xyzzy.dat", "w"))
           raise MyException, "boom"
         end
-        Thread.pass
+        Thread.pass while t.alive?
         assert_fail("Exception should have interrupted main thread")
-      rescue TestThread::MyException
-        assert(true)
+      rescue SystemExit
+        msg = open("xyzzy.dat") {|f| f.gets}
       ensure
-        $stderr = save_stderr
+        $stderr.reopen(save_stderr)
+        File.unlink("xyzzy.dat")
       end
+      assert_match(msg, /\(TestThread::MyException\)$/)
     rescue Exception
       assert_fail($!.to_s)
@@ -299,7 +300,7 @@   def test_safe_level
       Thread.pass
     end
+    t.join rescue nil
     assert_equals(0, Thread.current.safe_level)
     assert_equals(4, t.safe_level)
-    t.kill
   end
 
@@ -377,4 +378,5 @@   def test_s_abort_on_exception=
 	raise "boom"
       end
+      Thread.pass
       assert(true)
     rescue Exception
@@ -382,18 +384,22 @@   def test_s_abort_on_exception=
     end
 
+    msg = nil
     begin
       Thread.abort_on_exception = true
-      Thread.new do
-	save_stderr = $stderr
-	$stderr = nil
-	raise "boom"
+      t = Thread.new do
+	save_stderr = $stderr.dup
+	$stderr.reopen(open("xyzzy.dat", "w"))
+	raise MyException, "boom"
       end
+      Thread.pass while t.alive?
       fail("Exception should have interrupted main thread")
-    rescue Exception
-      assert(true)
+    rescue SystemExit
+      msg = open("xyzzy.dat") {|f| f.gets}
     ensure
       Thread.abort_on_exception = false
-      $stderr = save_stderr
+      $stderr.reopen(save_stderr)
+      File.unlink("xyzzy.dat")
     end
+    assert_match(msg, /\(TestThread::MyException\)$/)
   end
 


-- 
--- 僕の前にBugはない。
--- 僕の後ろにBugはできる。
    中田 伸悦

In This Thread