Author: gert
Date: 2007-05-17 11:17:41 -0400 (Thu, 17 May 2007)
New Revision: 77569

Added:
   trunk/gert/standalone/bug81656/
   trunk/gert/standalone/bug81656/default.build
   trunk/gert/standalone/bug81656/test.cs
Modified:
   trunk/gert/standalone/known-issues
Log:
Added test for bug #81656.


Added: trunk/gert/standalone/bug81656/default.build
===================================================================
--- trunk/gert/standalone/bug81656/default.build        2007-05-17 15:08:33 UTC 
(rev 77568)
+++ trunk/gert/standalone/bug81656/default.build        2007-05-17 15:17:41 UTC 
(rev 77569)
@@ -0,0 +1,61 @@
+<project name="bug81656" default="rebuild">
+       <target name="mono-1.0">
+               <property name="csc.defines" 
value="NET_1_0,NET_1_1,ONLY_1_1,MONO" />
+       </target>
+
+       <target name="mono-2.0">
+               <property name="csc.defines" 
value="NET_1_0,NET_1_1,NET_2_0,ONLY_2_0,MONO" />
+       </target>
+
+       <target name="net-1.1">
+               <property name="csc.defines" value="NET_1_0,NET_1_1,ONLY_1_1" />
+       </target>
+
+       <target name="net-2.0">
+               <property name="csc.defines" 
value="NET_1_0,NET_1_1,NET_2_0,ONLY_2_0" />
+       </target>
+
+       <property name="frameworks" value="mono-1.0,mono-2.0,net-1.1,net-2.0" />
+       
+       <target name="clean">
+               <delete>
+                       <fileset>
+                               <include name="out" />
+                               <include name="test.exe" />
+                       </fileset>
+               </delete>
+       </target>
+
+       <target name="build">
+               <property name="original.targetframework" 
value="${nant.settings.currentframework}" />
+
+               <foreach property="framework" item="String" in="${frameworks}" 
delim=",">
+                       <if test="${framework::exists(framework)}">
+                               <property name="nant.settings.currentframework" 
value="${framework}" />
+                               <call 
target="${nant.settings.currentframework}" />
+                               <call target="run" />
+                               <call target="clean" />
+                       </if>
+               </foreach>
+
+               <property name="nant.settings.currentframework" 
value="${original.targetframework}" />
+       </target>
+
+       <target name="compile">
+               <csc target="exe" define="${csc.defines}" output="test.exe" 
warnaserror="true" warninglevel="4">
+                       <nowarn>
+                               <warning number="0618" />
+                       </nowarn>
+                       <sources>
+                               <include name="test.cs" />
+                       </sources>
+               </csc>
+       </target>
+
+       <target name="run" depends="compile">
+               <exec program="test.exe" managed="true" output="out" />
+               <fail if="${file::exists('out')}" />
+       </target>
+
+       <target name="rebuild" depends="clean, build" />
+</project>


Property changes on: trunk/gert/standalone/bug81656/default.build
___________________________________________________________________
Name: svn:eol-style
   + native

Added: trunk/gert/standalone/bug81656/test.cs
===================================================================
--- trunk/gert/standalone/bug81656/test.cs      2007-05-17 15:08:33 UTC (rev 
77568)
+++ trunk/gert/standalone/bug81656/test.cs      2007-05-17 15:17:41 UTC (rev 
77569)
@@ -0,0 +1,52 @@
+using System;
+using System.Threading;
+
+class Program
+{
+       static int Main ()
+       {
+#if NET_2_0
+               if (Thread.CurrentThread.ApartmentState != ApartmentState.MTA)
+#else
+               if (Thread.CurrentThread.ApartmentState != 
ApartmentState.Unknown)
+#endif
+                       return 1;
+
+               Thread t1 = new Thread (new ThreadStart (Run));
+               t1.Start ();
+#if NET_2_0
+               if (t1.ApartmentState != ApartmentState.MTA)
+#else
+               if (t1.ApartmentState != ApartmentState.Unknown)
+#endif
+                       return 2;
+               t1.Join ();
+
+               Thread t2 = new Thread (new ThreadStart (Run));
+               t2.ApartmentState = ApartmentState.STA;
+               t2.Start ();
+               if (t2.ApartmentState != ApartmentState.STA)
+                       return 3;
+               t2.Join ();
+
+               Thread t3 = new Thread (new ThreadStart (Run));
+               t3.ApartmentState = ApartmentState.MTA;
+               t3.Start ();
+               if (t3.ApartmentState != ApartmentState.MTA)
+                       return 4;
+               t3.Join ();
+
+#if NET_2_0
+               if (Thread.CurrentThread.ApartmentState != ApartmentState.MTA)
+#else
+               if (Thread.CurrentThread.ApartmentState != 
ApartmentState.Unknown)
+#endif
+                       return 4;
+
+               return 0;
+       }
+
+       static void Run ()
+       {
+       }
+}


Property changes on: trunk/gert/standalone/bug81656/test.cs
___________________________________________________________________
Name: svn:eol-style
   + native

Modified: trunk/gert/standalone/known-issues
===================================================================
--- trunk/gert/standalone/known-issues  2007-05-17 15:08:33 UTC (rev 77568)
+++ trunk/gert/standalone/known-issues  2007-05-17 15:17:41 UTC (rev 77569)
@@ -9,3 +9,4 @@
 bug81642/**
 bug81643/**
 bug81646/**
+bug81656/**

_______________________________________________
Mono-patches maillist  -  [email protected]
http://lists.ximian.com/mailman/listinfo/mono-patches

Reply via email to