[Mono-bugs] [Bug 82025][Nor] New - The StackTrace.FrameCount returns 0 when called since another thread
bugzilla-daemon at bugzilla.ximian.com
bugzilla-daemon at bugzilla.ximian.com
Fri Jul 6 19:42:43 EDT 2007
Please do not reply to this email- if you want to comment on the bug, go to the
URL shown below and enter your comments there.
Changed by ebasconp at gmail.com.
http://bugzilla.ximian.com/show_bug.cgi?id=82025
--- shadow/82025 2007-07-06 19:42:43.000000000 -0400
+++ shadow/82025.tmp.2790 2007-07-06 19:42:43.000000000 -0400
@@ -0,0 +1,162 @@
+Bug#: 82025
+Product: Mono: Class Libraries
+Version: 1.2
+OS:
+OS Details: Linux 2.6.20-15-generic #2 SMP x86_64 GNU/Linux
+
+Status: NEW
+Resolution:
+Severity:
+Priority: Normal
+Component: Sys.Core
+AssignedTo: mono-bugs at ximian.com
+ReportedBy: ebasconp at gmail.com
+QAContact: mono-bugs at ximian.com
+TargetMilestone: ---
+URL:
+Cc:
+Summary: The StackTrace.FrameCount returns 0 when called since another thread
+
+Description of Problem:
+
+The StackTrace.FrameCount getter returns 0 when it is being called from a
+thread distinct from the application's main thread.
+
+
+Steps to reproduce the problem:
+ Execute this code:
+
+
+/*****************************************************
+ * Start code */
+
+using System;
+using System.Diagnostics;
+using System.Threading;
+
+
+namespace StackTraceTest
+{
+ public class StackTraceTest
+ {
+ public StackTraceTest()
+ {
+ MethodA();
+ }
+
+ private void MethodA()
+ {
+ MethodB();
+ }
+
+ private void MethodB()
+ {
+ StackTrace stackTrace = new StackTrace();
+ Console.WriteLine("StackTrace.FrameCount: [{0}]",
+stackTrace.FrameCount);
+ int count = stackTrace.FrameCount;
+ for (int i = 0; i < count; i++)
+ {
+ StackFrame auxFrame =
+stackTrace.GetFrame(i);
+ Console.WriteLine("StackFrame: [{0}:
+{1}]", i, auxFrame);
+ }
+ }
+
+
+ public static void RunTest()
+ {
+ RunFirstTest();
+Console.WriteLine("***************");
+ RunSecondTest();
+ }
+
+ private static void RunFirstTest()
+ {
+ Console.WriteLine("Running first test");
+ new StackTraceTest();
+ }
+
+ private static void RunSecondTest()
+ {
+ Thread thread = new Thread(new
+ThreadStart(ProcessSecondTestThread));
+ thread.Start();
+ }
+
+ private static void ProcessSecondTestThread()
+ {
+ Console.WriteLine("Running second test");
+ new StackTraceTest();
+ }
+ }
+}
+
+/* End code *
+ ****************************************************/
+
+
+Actual Results:
+
+This is the output:
+
+Running first test
+StackTrace.FrameCount: [6]
+StackFrame: [0: MethodB at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [1: MethodA at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [2: .ctor at offset 6 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [3: RunFirstTest at offset 10 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [4: RunTest at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [5: Main at offset 0 in file:line:column <filename
+unknown>:0:0]
+******************************
+Running second test
+StackTrace.FrameCount: [0]
+
+//As you can see, the code execute from the Thread, does not fill the
+StackTrace.
+
+Expected Results:
+
+Running first test
+StackTrace.FrameCount: [6]
+StackFrame: [0: MethodB at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [1: MethodA at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [2: .ctor at offset 6 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [3: RunFirstTest at offset 10 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [4: RunTest at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [5: Main at offset 0 in file:line:column <filename
+unknown>:0:0]
+******************************
+Running second test
+StackTrace.FrameCount: [6]
+StackFrame: [0: MethodB at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [1: MethodA at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [2: .ctor at offset 6 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [3: RunFirstTest at offset 10 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [4: RunTest at offset 0 in file:line:column <filename
+unknown>:0:0]
+StackFrame: [5: Main at offset 0 in file:line:column <filename
+unknown>:0:0]
+
+
+How often does this happen?
+ Always
+
+Additional Information:
+ My machine is amd64
More information about the mono-bugs
mailing list