using NUnit.Framework;
using System;
using System.Collections;
+using System.Collections.Generic;
+using System.Configuration.Assemblies;
+using System.Globalization;
using System.IO;
using System.Reflection;
using System.Reflection.Emit;
+using System.Runtime.InteropServices;
using System.Security;
using System.Security.Permissions;
using System.Security.Policy;
using System.Security.Principal;
-namespace MonoTests.System {
-
+namespace MonoTests.System
+{
[TestFixture]
- public class AppDomainTest {
-
+ public class AppDomainTest
+ {
private AppDomain ad;
private ArrayList files = new ArrayList ();
+ private string tempDir;
+
+ [SetUp]
+ public void SetUp ()
+ {
+ tempDir = Path.Combine (Path.GetTempPath (), Environment.UserName);
+ tempDir = Path.Combine (tempDir, "MonoTests.System.AppDomainTest");
+ if (!Directory.Exists (tempDir)) {
+ Directory.CreateDirectory (tempDir);
+ }
+ }
[TearDown]
- public void TearDown ()
+ public void TearDown ()
{
if (ad != null) {
try {
-// FIXME: Lots of GC warning when unloading
-// AppDomain.Unload (ad);
+ AppDomain.Unload (ad);
ad = null;
+ } catch { } // do not affect unit test results in TearDown
+ }
+ foreach (string fname in files) {
+ File.Delete (fname);
+ }
+ files.Clear ();
+ }
+
+ [Test] // bug #80934
+ public void ConfigurationFile_Relative ()
+ {
+ // Note:
+ // We use Environment.GetCommandLineArgs () to get the location of
+ // the entry assembly in the default domain (since the default domain
+ // is not exposed by any API)
+ //
+ // MS returns a lower-case path in Environment.GetCommandLineArgs ()
+ // and hence we need to perform a case-insensitive comparison
+ // if the Assert involves that path
+
+ string configFile = "test.config";
+ string appBase = null;
+ string expectedConfigFile = null;
+ string expectedAppBase = null;
+
+ // do not set ApplicationBase
+ appBase = Path.GetDirectoryName (Environment.GetCommandLineArgs () [0]);
+ expectedAppBase = appBase [appBase.Length - 1] == Path.DirectorySeparatorChar ?
+ appBase : appBase + Path.DirectorySeparatorChar;
+ expectedConfigFile = Path.Combine (appBase, configFile);
+ AppDomainSetup setup = new AppDomainSetup();
+ setup.ConfigurationFile = configFile;
+ ad = CreateTestDomain (setup, true);
+ CrossDomainTester cdt = CreateCrossDomainTester (ad);
+ if (RunningOnUnix) {
+ Assert.AreEqual (expectedConfigFile, cdt.GetConfigurationFile (), "#A1");
+ Assert.AreEqual (expectedAppBase, cdt.GetApplicationBase (), "#A2");
+ } else {
+ Assert.IsTrue (string.Compare (expectedConfigFile, cdt.GetConfigurationFile (), true) == 0, "#A1");
+ Assert.IsTrue (string.Compare (expectedAppBase, cdt.GetApplicationBase (), true) == 0, "#A2");
+ }
+ AppDomain.Unload (ad);
+
+ // set ApplicationBase
+ appBase = Path.GetTempPath ();
+ expectedAppBase = appBase [appBase.Length - 1] == Path.DirectorySeparatorChar ?
+ appBase : appBase + Path.DirectorySeparatorChar;
+ expectedConfigFile = Path.Combine (appBase, configFile);
+ setup = new AppDomainSetup ();
+ setup.ApplicationBase = appBase;
+ setup.ConfigurationFile = configFile;
+ ad = CreateTestDomain (setup, true);
+ cdt = CreateCrossDomainTester (ad);
+ Assert.AreEqual (expectedConfigFile, cdt.GetConfigurationFile (), "#B1");
+ Assert.AreEqual (expectedAppBase, cdt.GetApplicationBase (), "#B2");
+ AppDomain.Unload (ad);
+ }
+
+ [Test] // bug #80934
+ public void ConfigurationFile_Absolute ()
+ {
+ // Note:
+ // We use Environment.GetCommandLineArgs () to get the location of
+ // the entry assembly in the default domain (since the default domain
+ // is not exposed by any API)
+ //
+ // MS returns a lower-case path in Environment.GetCommandLineArgs ()
+ // and hence on Windows we need to perform a case-insensitive
+ // comparison if the Assert involves that path
+
+ string configFile = Path.Combine (tempDir, "test.config");
+ string appBase = null;
+ string expectedAppBase = null;
+
+ // do not set ApplicationBase
+ appBase = Path.GetDirectoryName (Environment.GetCommandLineArgs () [0]);
+ expectedAppBase = appBase [appBase.Length - 1] == Path.DirectorySeparatorChar ?
+ appBase : appBase + Path.DirectorySeparatorChar;
+ AppDomainSetup setup = new AppDomainSetup ();
+ setup.ConfigurationFile = configFile;
+ ad = CreateTestDomain (setup, true);
+ CrossDomainTester cdt = CreateCrossDomainTester (ad);
+ Assert.AreEqual (configFile, cdt.GetConfigurationFile (), "#A1");
+ if (RunningOnUnix) {
+ Assert.AreEqual (expectedAppBase, cdt.GetApplicationBase (), "#A2");
+ } else {
+ Assert.IsTrue (string.Compare (expectedAppBase, cdt.GetApplicationBase (), true) == 0, "#A2");
+ }
+ AppDomain.Unload (ad);
+
+ // set ApplicationBase
+ appBase = Path.GetTempPath ();
+ expectedAppBase = appBase [appBase.Length - 1] == Path.DirectorySeparatorChar ?
+ appBase : appBase + Path.DirectorySeparatorChar;
+ setup = new AppDomainSetup ();
+ setup.ApplicationBase = appBase;
+ setup.ConfigurationFile = configFile;
+ ad = CreateTestDomain (setup, true);
+ cdt = CreateCrossDomainTester (ad);
+ Assert.AreEqual (configFile, cdt.GetConfigurationFile (), "#B1");
+ Assert.AreEqual (expectedAppBase, cdt.GetApplicationBase (), "#B2");
+ AppDomain.Unload (ad);
+ }
+
+ [Test] // bug #80934
+ public void ConfigurationFile_Null ()
+ {
+ // Note:
+ // We use Environment.GetCommandLineArgs () to get the location of
+ // the entry assembly in the default domain (since the default domain
+ // is not exposed by any API)
+ //
+ // MS returns a lower-case path in Environment.GetCommandLineArgs ()
+ // and hence we need to perform a case-insensitive comparison
+ // if the Assert involves that path
+
+ string appBase = null;
+ string expectedAppBase = null;
+ string expectedConfigFile = null;
+
+ // do not set ApplicationBase
+ appBase = Path.GetDirectoryName (Environment.GetCommandLineArgs () [0]);
+ expectedAppBase = appBase [appBase.Length - 1] == Path.DirectorySeparatorChar ?
+ appBase : appBase + Path.DirectorySeparatorChar;
+ expectedConfigFile = Environment.GetCommandLineArgs () [0] + ".config";
+ AppDomainSetup setup = new AppDomainSetup ();
+ setup.ConfigurationFile = null;
+ ad = CreateTestDomain (setup, true);
+ CrossDomainTester cdt = CreateCrossDomainTester (ad);
+ if (RunningOnUnix) {
+ Assert.AreEqual (expectedConfigFile, cdt.GetConfigurationFile (), "#A1");
+ Assert.AreEqual (expectedAppBase, cdt.GetApplicationBase (), "#A2");
+ } else {
+ Assert.IsTrue (string.Compare (expectedConfigFile, cdt.GetConfigurationFile (), true) == 0, "#A1");
+ Assert.IsTrue (string.Compare (expectedAppBase, cdt.GetApplicationBase (), true) == 0, "#A2");
+ }
+ AppDomain.Unload (ad);
+
+ // set ApplicationBase
+ appBase = Path.GetTempPath ();
+ expectedAppBase = appBase [appBase.Length - 1] == Path.DirectorySeparatorChar ?
+ appBase : appBase + Path.DirectorySeparatorChar;
+ expectedConfigFile = Path.Combine (appBase, Path.GetFileName (Environment.GetCommandLineArgs () [0]) + ".config");
+ setup = new AppDomainSetup ();
+ setup.ApplicationBase = appBase;
+ setup.ConfigurationFile = null;
+ ad = CreateTestDomain (setup, true);
+ cdt = CreateCrossDomainTester (ad);
+ if (RunningOnUnix) {
+ Assert.AreEqual (expectedConfigFile, cdt.GetConfigurationFile (), "#B1");
+ } else {
+ Assert.IsTrue (string.Compare (expectedConfigFile, cdt.GetConfigurationFile (), true) == 0, "#B1");
+ }
+ Assert.AreEqual (expectedAppBase, cdt.GetApplicationBase (), "#B2");
+ AppDomain.Unload (ad);
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess)
+ public void DefineDynamicAssembly1_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly1";
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess)
+ public void DefineDynamicAssembly1_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess)
+ public void DefineDynamicAssembly1_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, Evidence)
+ public void DefineDynamicAssembly2_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly2";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ AppDomain.CurrentDomain.Evidence);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, Evidence)
+ public void DefineDynamicAssembly2_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, Evidence)
+ public void DefineDynamicAssembly2_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String)
+ public void DefineDynamicAssembly3_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly3";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath ());
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath ());
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String)
+ public void DefineDynamicAssembly3_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath ());
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String)
+ public void DefineDynamicAssembly3_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath ());
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath ());
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath ());
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence)
+ public void DefineDynamicAssembly4_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly4";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence)
+ public void DefineDynamicAssembly4_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence)
+ public void DefineDynamicAssembly4_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly5_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly5";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly5_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly5_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, Evidence, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly6_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly6";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, Evidence, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly6_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, Evidence, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly6_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly7_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly7";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly7_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly7_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly8_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly8";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly8_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet)
+ public void DefineDynamicAssembly8_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean)
+ public void DefineDynamicAssembly9_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly9";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true);
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true);
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean)
+ public void DefineDynamicAssembly9_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true);
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
}
- catch {} // do not affect unit test results in TearDown
}
- foreach (string fname in files) {
- File.Delete (fname);
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean)
+ public void DefineDynamicAssembly9_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true);
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true);
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true);
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+#if NET_2_0
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly10_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly10";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true,
+ new List<CustomAttributeBuilder> ());
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly10_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly10_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ Path.GetTempPath (),
+ AppDomain.CurrentDomain.Evidence,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ (PermissionSet) null,
+ true,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName name, AssemblyBuilderAccess, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly11 ()
+ {
+ List<CustomAttributeBuilder> cattrs;
+ AssemblyBuilder ab;
+ Attribute attr;
+ AssemblyName name;
+ string assemblyFile;
+ string current_dir = Directory.GetCurrentDirectory ();
+
+ name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly11A";
+
+ cattrs = new List<CustomAttributeBuilder> ();
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyVersionAttribute).
+ GetConstructor (new Type [] { typeof (string) }),
+ new object [] { "1.2.3.4"}));
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyCultureAttribute).
+ GetConstructor (new Type [] { typeof (string) }),
+ new object [] { "nl-BE"}));
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyAlgorithmIdAttribute).
+ GetConstructor (new Type [] { typeof (AssemblyHashAlgorithm) }),
+ new object [] { AssemblyHashAlgorithm.MD5 }));
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyFlagsAttribute).
+ GetConstructor (new Type [] { typeof (uint) }),
+ new object [] { (uint)0x0100 }));
+ cattrs.Add (new CustomAttributeBuilder (typeof (CLSCompliantAttribute).
+ GetConstructor (new Type [] { typeof (bool) }),
+ new object [] { true }));
+
+ ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Save, cattrs);
+
+ ab.SetCustomAttribute (new CustomAttributeBuilder (typeof (ComVisibleAttribute).
+ GetConstructor (new Type [] { typeof (bool) }),
+ new object [] { true }));
+
+ ab.Save ("DefineDynamicAssembly11A.dll");
+
+ assemblyFile = Path.Combine (current_dir, "DefineDynamicAssembly11A.dll");
+
+ try {
+ AssemblyName an = AssemblyName.GetAssemblyName (assemblyFile);
+ Assert.AreEqual (CultureInfo.InvariantCulture, an.CultureInfo, "#A1");
+ Assert.AreEqual (AssemblyNameFlags.None, an.Flags, "#A2");
+ Assert.AreEqual ("DefineDynamicAssembly11A, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null", an.FullName, "#A3");
+ Assert.IsNull (an.GetPublicKey (), "#A4");
+ Assert.AreEqual (new byte [0], an.GetPublicKeyToken (), "#A5");
+ Assert.AreEqual (AssemblyHashAlgorithm.SHA1, an.HashAlgorithm, "#A6");
+ Assert.IsNull (an.KeyPair, "#A7");
+ Assert.AreEqual ("DefineDynamicAssembly11A", an.Name, "#A8");
+ //Assert.AreEqual (ProcessorArchitecture.MSIL, an.ProcessorArchitecture, "#A9");
+ Assert.AreEqual (an.FullName, an.ToString (), "#A10");
+ Assert.AreEqual (new Version (0, 0, 0, 0), an.Version, "#A11");
+ Assert.AreEqual (AssemblyVersionCompatibility.SameMachine, an.VersionCompatibility, "#A12");
+
+ Assembly a;
+
+ using (FileStream fs = File.OpenRead (assemblyFile)) {
+ byte [] buffer = new byte [fs.Length];
+ fs.Read (buffer, 0, buffer.Length);
+ a = Assembly.Load (buffer);
+ }
+
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyVersionAttribute));
+ Assert.IsNotNull (attr, "#A13a");
+ Assert.AreEqual ("1.2.3.4", ((AssemblyVersionAttribute) attr).Version, "#A13b");
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyCultureAttribute));
+ Assert.IsNotNull (attr, "#A14a");
+ Assert.AreEqual ("nl-BE", ((AssemblyCultureAttribute) attr).Culture, "#A14b");
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyAlgorithmIdAttribute));
+ Assert.IsNotNull (attr, "#A15a");
+ Assert.AreEqual ((uint) AssemblyHashAlgorithm.MD5, ((AssemblyAlgorithmIdAttribute) attr).AlgorithmId, "#A15b");
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyFlagsAttribute));
+ Assert.IsNotNull (attr, "#A16a");
+ Assert.AreEqual ((uint) 0x0100, ((AssemblyFlagsAttribute) attr).Flags, "#A16b");
+ attr = Attribute.GetCustomAttribute (a, typeof (CLSCompliantAttribute));
+ Assert.IsNotNull (attr, "#A17a");
+ Assert.IsTrue (((CLSCompliantAttribute) attr).IsCompliant, "#A17b");
+ attr = Attribute.GetCustomAttribute (a, typeof (ComVisibleAttribute));
+ Assert.IsNotNull (attr, "#A18a");
+ Assert.IsTrue (((ComVisibleAttribute) attr).Value, "#A18b");
+ } finally {
+ File.Delete (assemblyFile);
+ }
+
+ name = new AssemblyName ();
+ name.CultureInfo = new CultureInfo ("fr-BE");
+ name.KeyPair = new StrongNameKeyPair (keyPair);
+ name.Name = "DefineDynamicAssembly11B";
+ name.Version = new Version (3, 2, 4, 1);
+
+ cattrs = new List<CustomAttributeBuilder> ();
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyVersionAttribute).
+ GetConstructor (new Type [] { typeof (string) }),
+ new object [] { "1.2.3.4"}));
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyCultureAttribute).
+ GetConstructor (new Type [] { typeof (string) }),
+ new object [] { "nl-BE"}));
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyAlgorithmIdAttribute).
+ GetConstructor (new Type [] { typeof (AssemblyHashAlgorithm) }),
+ new object [] { AssemblyHashAlgorithm.MD5 }));
+ cattrs.Add (new CustomAttributeBuilder (typeof (AssemblyFlagsAttribute).
+ GetConstructor (new Type [] { typeof (uint) }),
+ new object [] { (uint)0x0100 }));
+ cattrs.Add (new CustomAttributeBuilder (typeof (CLSCompliantAttribute).
+ GetConstructor (new Type [] { typeof (bool) }),
+ new object [] { true }));
+
+ ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Save, cattrs);
+
+ ab.SetCustomAttribute (new CustomAttributeBuilder (typeof (ComVisibleAttribute).
+ GetConstructor (new Type [] { typeof (bool) }),
+ new object [] { true }));
+
+ ab.Save ("DefineDynamicAssembly11B.dll");
+
+ assemblyFile = Path.Combine (current_dir, "DefineDynamicAssembly11B.dll");
+
+ try {
+ AssemblyName an = AssemblyName.GetAssemblyName (assemblyFile);
+ Assert.AreEqual ("fr-BE", an.CultureInfo.Name, "#B1");
+ Assert.AreEqual (AssemblyNameFlags.PublicKey, an.Flags, "#B2");
+ Assert.AreEqual ("DefineDynamicAssembly11B, Version=3.2.4.1, Culture=fr-BE, PublicKeyToken=ce5276d8687ec6dc", an.FullName, "#B3");
+ Assert.AreEqual (publicKey, an.GetPublicKey (), "#B4");
+ Assert.AreEqual (pk_token, an.GetPublicKeyToken (), "#B5");
+ Assert.AreEqual (AssemblyHashAlgorithm.SHA1, an.HashAlgorithm, "#B6");
+ Assert.IsNull (an.KeyPair, "#B7");
+ Assert.AreEqual ("DefineDynamicAssembly11B", an.Name, "#B8");
+ //Assert.AreEqual (ProcessorArchitecture.MSIL, an.ProcessorArchitecture, "#B9");
+ Assert.AreEqual (an.FullName, an.ToString (), "#B10");
+ Assert.AreEqual (new Version (3, 2, 4, 1), an.Version, "#B11");
+ Assert.AreEqual (AssemblyVersionCompatibility.SameMachine, an.VersionCompatibility, "#B12");
+
+ Assembly a;
+
+ using (FileStream fs = File.OpenRead (assemblyFile)) {
+ byte [] buffer = new byte [fs.Length];
+ fs.Read (buffer, 0, buffer.Length);
+ a = Assembly.Load (buffer);
+ }
+
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyVersionAttribute));
+ Assert.IsNotNull (attr, "#B13a");
+ Assert.AreEqual ("1.2.3.4", ((AssemblyVersionAttribute) attr).Version, "#B13b");
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyCultureAttribute));
+ Assert.IsNotNull (attr, "#B14a");
+ Assert.AreEqual ("nl-BE", ((AssemblyCultureAttribute) attr).Culture, "#B14b");
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyAlgorithmIdAttribute));
+ Assert.IsNotNull (attr, "#B15a");
+ Assert.AreEqual ((uint) AssemblyHashAlgorithm.MD5, ((AssemblyAlgorithmIdAttribute) attr).AlgorithmId, "#B15b");
+ attr = Attribute.GetCustomAttribute (a, typeof (AssemblyFlagsAttribute));
+ Assert.IsNotNull (attr, "#B16a");
+ Assert.AreEqual ((uint) 0x0100, ((AssemblyFlagsAttribute) attr).Flags, "#B16b");
+ attr = Attribute.GetCustomAttribute (a, typeof (CLSCompliantAttribute));
+ Assert.IsNotNull (attr, "#B17a");
+ Assert.IsTrue (((CLSCompliantAttribute) attr).IsCompliant, "#B17b");
+ attr = Attribute.GetCustomAttribute (a, typeof (ComVisibleAttribute));
+ Assert.IsNotNull (attr, "#B18a");
+ Assert.IsTrue (((ComVisibleAttribute) attr).Value, "#B18b");
+ } finally {
+ File.Delete (assemblyFile);
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName name, AssemblyBuilderAccess, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly11_Access_Invalid ()
+ {
+ AssemblyName name = new AssemblyName ();
+ name.Name = "DefineDynamicAssembly11";
+
+#if NET_2_0
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#1");
+ } catch (ArgumentException ex) {
+ // Illegal enum value: 667
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf ("667") != -1, "#5");
+ Assert.IsNotNull (ex.ParamName, "#6");
+ Assert.AreEqual ("access", ex.ParamName, "#7");
+ }
+#else
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name, AssemblyBuilderAccess.Run |
+ (AssemblyBuilderAccess) 666,
+ new List<CustomAttributeBuilder> ());
+ Assert.IsNotNull (ab, "#1");
+#endif
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName name, AssemblyBuilderAccess, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly11_Name_InvalidChars ()
+ {
+ string [] invalid_char_names = new string [] {
+ "\tAB",
+ " AB",
+ "\rAB",
+ "A/B",
+ ":AB",
+ "B:A",
+ "B\\A",
+ "BA\\"};
+
+ AssemblyName name = new AssemblyName ();
+
+ foreach (string invalid_name in invalid_char_names) {
+ name.Name = invalid_name;
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#1:" + invalid_name);
+ } catch (ArgumentException ex) {
+ // Assembly names may not begin with whitespace
+ // or contain the characters '/', '\' or ':'
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:" + invalid_name);
+ Assert.IsNull (ex.InnerException, "#3:" + invalid_name);
+ Assert.IsNotNull (ex.Message, "#4:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'/'") != -1, "#5:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("'\\'") != -1, "#6:" + invalid_name);
+ Assert.IsTrue (ex.Message.IndexOf ("':'") != -1, "#7:" + invalid_name);
+ Assert.IsNull (ex.ParamName, "#8:" + invalid_name);
+ }
+ }
+ }
+
+ [Test] // DefineDynamicAssembly (AssemblyName, AssemblyBuilderAccess, String, Evidence, PermissionSet, PermissionSet, PermissionSet, Boolean, IEnumerable<CustomAttributeBuilder>)
+ public void DefineDynamicAssembly11_Name_Null ()
+ {
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ (AssemblyName) null,
+ AssemblyBuilderAccess.Run,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#A1");
+ } catch (ArgumentNullException ex) {
+ Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
+ Assert.IsNull (ex.InnerException, "#A3");
+ Assert.IsNotNull (ex.Message, "#A4");
+ Assert.IsNotNull (ex.ParamName, "#A5");
+ Assert.AreEqual ("name", ex.ParamName, "#A6");
+ }
+
+ AssemblyName name = new AssemblyName ();
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#B1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#B2");
+ Assert.IsNull (ex.InnerException, "#B3");
+ Assert.IsNotNull (ex.Message, "#B4");
+ Assert.IsNull (ex.ParamName, "#B5");
+ }
+
+ name.Name = string.Empty;
+
+ try {
+ AppDomain.CurrentDomain.DefineDynamicAssembly (
+ name,
+ AssemblyBuilderAccess.Run,
+ new List<CustomAttributeBuilder> ());
+ Assert.Fail ("#C1");
+ } catch (ArgumentException ex) {
+ // AssemblyName.Name cannot be null or an empty string
+ Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2");
+ Assert.IsNull (ex.InnerException, "#C3");
+ Assert.IsNotNull (ex.Message, "#C4");
+ Assert.IsNull (ex.ParamName, "#C5");
+ }
+ }
+
+ [Test] // ExecuteAssemblyByName (String)
+ public void ExecuteAssemblyByName1_NoEntryPoint ()
+ {
+ try {
+ AppDomain.CurrentDomain.ExecuteAssemblyByName ("mscorlib");
+ Assert.Fail ("#1");
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (Consts.AssemblyCorlib) != -1, "#5");
+ }
+ }
+
+ [Test] // ExecuteAssemblyByName (String, Evidence)
+ public void ExecuteAssemblyByName2_NoEntryPoint ()
+ {
+ try {
+ AppDomain.CurrentDomain.ExecuteAssemblyByName (
+ "mscorlib", (Evidence) null);
+ Assert.Fail ("#1");
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (Consts.AssemblyCorlib) != -1, "#5");
+ }
+ }
+
+ [Test] // ExecuteAssemblyByName (String, Evidence, String [])
+ public void ExecuteAssemblyByName3_NoEntryPoint ()
+ {
+ try {
+ AppDomain.CurrentDomain.ExecuteAssemblyByName (
+ "mscorlib", (Evidence) null,
+ new string [0]);
+ Assert.Fail ("#1");
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (Consts.AssemblyCorlib) != -1, "#5");
+ }
+ }
+
+ [Test] // ExecuteAssemblyByName (AssemblyName, Evidence, String [])
+ public void ExecuteAssemblyByName4_NoEntryPoint ()
+ {
+ AssemblyName aname = new AssemblyName ("mscorlib");
+
+ try {
+ AppDomain.CurrentDomain.ExecuteAssemblyByName (
+ aname, (Evidence) null, new string [0]);
+ Assert.Fail ("#1");
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (Consts.AssemblyCorlib) != -1, "#5");
+ }
+ }
+#endif
+
+ [Test]
+ public void SetThreadPrincipal ()
+ {
+ IIdentity i = new GenericIdentity ("sebastien@ximian.com", "rfc822");
+ IPrincipal p = new GenericPrincipal (i, null);
+ ad = AppDomain.CreateDomain ("SetThreadPrincipal");
+ ad.SetThreadPrincipal (p);
+ }
+
+ [Test]
+ [ExpectedException (typeof (ArgumentNullException))]
+ public void SetThreadPrincipalNull ()
+ {
+ AppDomain.CurrentDomain.SetThreadPrincipal (null);
+ }
+
+ [Test]
+ [ExpectedException (typeof (PolicyException))]
+ public void SetThreadPrincipalTwice ()
+ {
+ IIdentity i = new GenericIdentity ("sebastien@ximian.com", "rfc822");
+ IPrincipal p = new GenericPrincipal (i, null);
+ ad = AppDomain.CreateDomain ("SetThreadPrincipalTwice");
+ ad.SetThreadPrincipal (p);
+ // you only live twice (or so James told me ;-)
+ ad.SetThreadPrincipal (p);
+ }
+
+ [Test]
+ [ExpectedException (typeof (AppDomainUnloadedException))]
+ public void SetThreadPrincipalUnloaded ()
+ {
+ ad = AppDomain.CreateDomain ("Ximian");
+ AppDomain.Unload (ad);
+ IIdentity i = new GenericIdentity ("sebastien@ximian.com", "rfc822");
+ IPrincipal p = new GenericPrincipal (i, null);
+ ad.SetThreadPrincipal (p);
+ }
+
+ [Test]
+ public void SetPrincipalPolicy_NoPrincipal ()
+ {
+ AppDomain.CurrentDomain.SetPrincipalPolicy (PrincipalPolicy.NoPrincipal);
+ }
+
+ [Test]
+ public void SetPrincipalPolicy_UnauthenticatedPrincipal ()
+ {
+ AppDomain.CurrentDomain.SetPrincipalPolicy (PrincipalPolicy.UnauthenticatedPrincipal);
+ }
+
+ [Test]
+ public void SetPrincipalPolicy_WindowsPrincipal ()
+ {
+ AppDomain.CurrentDomain.SetPrincipalPolicy (PrincipalPolicy.WindowsPrincipal);
+ }
+
+ [Test]
+ [ExpectedException (typeof (AppDomainUnloadedException))]
+ public void SetPrincipalPolicyUnloaded ()
+ {
+ ad = AppDomain.CreateDomain ("Ximian");
+ AppDomain.Unload (ad);
+ ad.SetPrincipalPolicy (PrincipalPolicy.NoPrincipal);
+ }
+
+ [Test]
+ public void CreateDomain_String ()
+ {
+ ad = AppDomain.CreateDomain ("CreateDomain_String");
+ Assert.IsNotNull (ad.Evidence, "Evidence");
+ // Evidence are copied (or referenced?) from default app domain
+ // we can't get default so we use the current (which should have copied the default)
+ Assert.AreEqual (AppDomain.CurrentDomain.Evidence.Count, ad.Evidence.Count, "Evidence.Count");
+ }
+
+ [Test]
+ [ExpectedException (typeof (ArgumentNullException))]
+ public void CreateDomain_String_Null ()
+ {
+ ad = AppDomain.CreateDomain (null);
+ }
+
+ [Test]
+ [Category ("NotDotNet")]
+ public void CreateDomain_StringEvidence ()
+ {
+ Evidence e = new Evidence ();
+ ad = AppDomain.CreateDomain ("CreateDomain_StringEvidence", e);
+ Assert.IsNotNull (ad.Evidence, "Evidence");
+ Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
+
+ e.AddHost (new Zone (SecurityZone.MyComputer));
+ Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
+ // evidence isn't copied but referenced
+ }
+
+ [Test]
+ [ExpectedException (typeof (ArgumentNullException))]
+ public void CreateDomain_StringNullEvidence ()
+ {
+ ad = AppDomain.CreateDomain (null, new Evidence ());
+ }
+
+ [Test]
+ public void CreateDomain_StringEvidenceNull ()
+ {
+ ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceNull", null);
+ Assert.IsNotNull (ad.Evidence, "Evidence");
+ // Evidence are copied (or referenced?) from default app domain
+ // we can't get default so we use the current (which should have copied the default)
+ Evidence e = AppDomain.CurrentDomain.Evidence;
+ Assert.AreEqual (e.Count, ad.Evidence.Count, "Evidence.Count-1");
+ e.AddHost (new Zone (SecurityZone.MyComputer));
+ Assert.AreEqual (e.Count - 1, ad.Evidence.Count, "Evidence.Count-2");
+ // evidence are copied
+ }
+
+ [Test]
+ [Category ("NotDotNet")]
+ public void CreateDomain_StringEvidenceAppDomainSetup ()
+ {
+ Evidence e = new Evidence ();
+ AppDomainSetup info = new AppDomainSetup ();
+ info.ApplicationName = "ApplicationName";
+
+ ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceAppDomainSetup", e, info);
+ Assert.IsNotNull (ad.Evidence, "Evidence");
+ Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
+ Assert.IsNotNull (ad.SetupInformation, "SetupInformation");
+ Assert.AreEqual ("ApplicationName", ad.SetupInformation.ApplicationName);
+
+ e.AddHost (new Zone (SecurityZone.MyComputer));
+ Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
+ // evidence isn't copied but referenced
+ }
+
+ [Test]
+ [ExpectedException (typeof (ArgumentNullException))]
+ public void CreateDomain_StringNullEvidenceAppDomainSetup ()
+ {
+ AppDomainSetup info = new AppDomainSetup ();
+ ad = AppDomain.CreateDomain (null, new Evidence (), info);
+ }
+
+ [Test]
+ public void CreateDomain_StringEvidenceNullAppDomainSetup ()
+ {
+ AppDomainSetup info = new AppDomainSetup ();
+ info.ApplicationName = "ApplicationName";
+ ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceNullAppDomainSetup", null, info);
+ Assert.IsNotNull (ad.Evidence, "Evidence");
+ // Evidence are copied (or referenced?) from default app domain
+ // we can't get default so we use the current (which should have copied the default)
+ Assert.AreEqual (AppDomain.CurrentDomain.Evidence.Count, ad.Evidence.Count, "Evidence.Count");
+ Assert.AreEqual ("ApplicationName", ad.SetupInformation.ApplicationName, "ApplicationName-1");
+ info.ApplicationName = "Test";
+ Assert.AreEqual ("Test", info.ApplicationName, "ApplicationName-2");
+ Assert.AreEqual ("ApplicationName", ad.SetupInformation.ApplicationName, "ApplicationName-3");
+ // copied
+ }
+
+ [Test]
+ [Category ("NotDotNet")]
+ public void CreateDomain_StringEvidenceAppDomainSetupNull ()
+ {
+ Evidence e = new Evidence ();
+ ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceAppDomainSetupNull", e, null);
+ Assert.IsNotNull (ad.Evidence, "Evidence");
+ Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
+ // SetupInformation is copied from default app domain
+ Assert.IsNotNull (ad.SetupInformation, "SetupInformation");
+ }
+
+ [Test] // ExecuteAssembly (String)
+ public void ExecuteAssembly1_NoEntryPoint ()
+ {
+ Assembly assembly = typeof (AppDomainTest).Assembly;
+
+ try {
+ AppDomain.CurrentDomain.ExecuteAssembly (
+ assembly.Location);
+ Assert.Fail ("#1");
+#if NET_2_0
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (assembly.FullName) != -1, "#5");
+ }
+#else
+ } catch (COMException ex) {
+ // Unspecified error
+ Assert.AreEqual (typeof (COMException), ex.GetType (), "#2");
+ Assert.AreEqual (-2147467259, ex.ErrorCode, "#3");
+ Assert.IsNull (ex.InnerException, "#4");
+ Assert.IsNotNull (ex.Message, "#5");
+ }
+#endif
+ }
+
+ [Test] // ExecuteAssembly (String, Evidence)
+ public void ExecuteAssembly2_NoEntryPoint ()
+ {
+ Assembly assembly = typeof (AppDomainTest).Assembly;
+
+ try {
+ AppDomain.CurrentDomain.ExecuteAssembly (
+ assembly.Location,
+ (Evidence) null);
+ Assert.Fail ("#1");
+#if NET_2_0
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (assembly.FullName) != -1, "#5");
+ }
+#else
+ } catch (COMException ex) {
+ // Unspecified error
+ Assert.AreEqual (typeof (COMException), ex.GetType (), "#2");
+ Assert.AreEqual (-2147467259, ex.ErrorCode, "#3");
+ Assert.IsNull (ex.InnerException, "#4");
+ Assert.IsNotNull (ex.Message, "#5");
+ }
+#endif
+ }
+
+ [Test] // ExecuteAssembly (String, Evidence, String [])
+ public void ExecuteAssembly3_NoEntryPoint ()
+ {
+ Assembly assembly = typeof (AppDomainTest).Assembly;
+
+ try {
+ AppDomain.CurrentDomain.ExecuteAssembly (
+ assembly.Location,
+ (Evidence) null,
+ new string [0]);
+ Assert.Fail ("#1");
+#if NET_2_0
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (assembly.FullName) != -1, "#5");
+ }
+#else
+ } catch (COMException ex) {
+ // Unspecified error
+ Assert.AreEqual (typeof (COMException), ex.GetType (), "#2");
+ Assert.AreEqual (-2147467259, ex.ErrorCode, "#3");
+ Assert.IsNull (ex.InnerException, "#4");
+ Assert.IsNotNull (ex.Message, "#5");
+ }
+#endif
+ }
+
+ [Test] // ExecuteAssembly (String, Evidence, String [], Byte [], AssemblyHashAlgorithm)
+ [Category ("NotWorking")] // Not implemented
+ public void ExecuteAssembly4_NoEntryPoint ()
+ {
+ Assembly assembly = typeof (AppDomainTest).Assembly;
+
+ try {
+ AppDomain.CurrentDomain.ExecuteAssembly (
+ assembly.Location,
+ (Evidence) null,
+ new string [0],
+ (byte []) null,
+ AssemblyHashAlgorithm.SHA1);
+ Assert.Fail ("#1");
+#if NET_2_0
+ } catch (MissingMethodException ex) {
+ // Entry point not found in assembly '...'
+ Assert.AreEqual (typeof (MissingMethodException), ex.GetType (), "#2");
+ Assert.IsNull (ex.InnerException, "#3");
+ Assert.IsNotNull (ex.Message, "#4");
+ Assert.IsTrue (ex.Message.IndexOf (assembly.FullName) != -1, "#5");
+ }
+#else
+ } catch (COMException ex) {
+ // Unspecified error
+ Assert.AreEqual (typeof (COMException), ex.GetType (), "#2");
+ Assert.AreEqual (-2147467259, ex.ErrorCode, "#3");
+ Assert.IsNull (ex.InnerException, "#4");
+ Assert.IsNotNull (ex.Message, "#5");
+ }
+#endif
+ }
+
+ [Test] // bug #79720
+ [Category ("NotWorking")]
+ public void Load_Loaded_Ignore ()
+ {
+ int assemblyStartCount = AppDomain.CurrentDomain.GetAssemblies ().Length;
+
+ // PART A
+
+ string assemblyFile = Path.Combine (tempDir, "bug79720A.dll");
+ AssemblyName aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (2, 4);
+
+ GenerateAssembly (aname, assemblyFile);
+
+ Assert.AreEqual (assemblyStartCount, AppDomain.CurrentDomain.GetAssemblies ().Length, "#A1");
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A2");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (0, 0, 0, 0);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A3");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (2, 4);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A4");
+ } catch (FileNotFoundException) {
+ }
+
+ Assert.AreEqual (assemblyStartCount, AppDomain.CurrentDomain.GetAssemblies ().Length, "#A5");
+
+ Assembly.LoadFrom (assemblyFile);
+
+ Assert.AreEqual (assemblyStartCount + 1, AppDomain.CurrentDomain.GetAssemblies ().Length, "#A6");
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A7");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (0, 0, 0, 0);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A8");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (2, 4);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A9");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (2, 4);
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A10");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720A";
+ aname.Version = new Version (2, 4, 0, 0);
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A11");
+ } catch (FileNotFoundException) {
+ }
+
+ Assert.AreEqual (assemblyStartCount + 1, AppDomain.CurrentDomain.GetAssemblies ().Length, "#A12");
+
+ // PART B
+
+ assemblyFile = Path.Combine (tempDir, "bug79720B.dll");
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (2, 4, 1);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+
+ GenerateAssembly (aname, assemblyFile);
+
+ Assert.AreEqual (assemblyStartCount + 1, AppDomain.CurrentDomain.GetAssemblies ().Length, "#B1");
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B2");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (0, 0, 0, 0);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B3");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (2, 4, 1);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B4");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (2, 4, 1);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B5");
+ } catch (FileNotFoundException) {
+ }
+
+ Assert.AreEqual (assemblyStartCount + 1, AppDomain.CurrentDomain.GetAssemblies ().Length, "#B6");
+
+ Assembly.LoadFrom (assemblyFile);
+
+ Assert.AreEqual (assemblyStartCount + 2, AppDomain.CurrentDomain.GetAssemblies ().Length, "#B7");
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B8");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (0, 0, 0, 0);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B9");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (2, 4, 1);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B10");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720B";
+ aname.Version = new Version (2, 4, 1);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B11");
+ } catch (FileNotFoundException) {
+ }
+
+ Assert.AreEqual (assemblyStartCount + 2, AppDomain.CurrentDomain.GetAssemblies ().Length, "#B12");
+
+ // PART C
+
+ assemblyFile = Path.Combine (tempDir, "bug79720C.dll");
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4);
+ aname.KeyPair = new StrongNameKeyPair (keyPair);
+
+ GenerateAssembly (aname, assemblyFile);
+
+ Assert.AreEqual (assemblyStartCount + 2, AppDomain.CurrentDomain.GetAssemblies ().Length, "#C1");
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C2");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (0, 0, 0, 0);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C3");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (2, 4, 1);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C4");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (2, 4, 1);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C5");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (2, 4, 1);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.SetPublicKey (publicKey);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C6");
+ } catch (FileNotFoundException) {
+ }
+
+ Assert.AreEqual (assemblyStartCount + 2, AppDomain.CurrentDomain.GetAssemblies ().Length, "#C7");
+
+ Assembly.LoadFrom (assemblyFile);
+
+ Assert.AreEqual (assemblyStartCount + 3, AppDomain.CurrentDomain.GetAssemblies ().Length, "#C8");
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C9");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (0, 0, 0, 0);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C10");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (2, 4);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C11");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (2, 4);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C12");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79720C";
+ aname.Version = new Version (2, 4);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.SetPublicKey (publicKey);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C13");
+ } catch (FileNotFoundException) {
+ }
+
+ Assert.AreEqual (assemblyStartCount + 3, AppDomain.CurrentDomain.GetAssemblies ().Length, "#C14");
+ }
+
+ [Test]
+ [Category ("NotWorking")]
+ public void Load_Loaded_Multiple ()
+ {
+ string cultureDir = Path.Combine (tempDir, "nl-BE");
+ if (!Directory.Exists (cultureDir))
+ Directory.CreateDirectory (cultureDir);
+
+ AppDomain ad = CreateTestDomain (tempDir, true);
+ try {
+ CrossDomainTester cdt = CreateCrossDomainTester (ad);
+
+ int assemblyCount = cdt.AssemblyCount;
+
+ // PART A
+
+ AssemblyName aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ aname.Version = new Version (1, 2, 3, 4);
+ cdt.GenerateAssembly (aname, Path.Combine (tempDir, "multipleA.dll"));
+
+ Assert.AreEqual (assemblyCount + 1, cdt.AssemblyCount, "#A1");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A2");
+
+ Assert.AreEqual (assemblyCount + 2, cdt.AssemblyCount, "#A3");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A4");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A5");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A6");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ aname.Version = new Version (1, 2, 3, 4);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A7");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleA";
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ aname.Version = new Version (1, 2, 3, 4);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A8");
+
+ Assert.AreEqual (assemblyCount + 2, cdt.AssemblyCount, "#A9");
+
+ // PART B
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 1, 0);
+ cdt.GenerateAssembly (aname, Path.Combine (tempDir, "nl-BE/multipleB.dll"));
+
+ Assert.AreEqual (assemblyCount + 3, cdt.AssemblyCount, "#B1");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B2");
+
+ Assert.AreEqual (assemblyCount + 4, cdt.AssemblyCount, "#B3");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B4");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B5");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B6");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 1, 0);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B7");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleB";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 1, 0);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B8");
+
+ Assert.AreEqual (assemblyCount + 4, cdt.AssemblyCount, "#B9");
+
+ // PART C
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleC";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 0, 0);
+ aname.KeyPair = new StrongNameKeyPair (keyPair);
+ cdt.GenerateAssembly (aname, Path.Combine (tempDir, "nl-BE/multipleC.dll"));
+
+ Assert.AreEqual (assemblyCount + 5, cdt.AssemblyCount, "#C1");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleC";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 0, 0);
+ aname.SetPublicKey (publicKey);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#C2");
+
+ Assert.AreEqual (assemblyCount + 6, cdt.AssemblyCount, "#C3");
+
+ aname = new AssemblyName ();
+ aname.Name = "multipleC";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 0, 0);
+ aname.SetPublicKey (publicKey);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#C4");
+
+ Assert.AreEqual (assemblyCount + 6, cdt.AssemblyCount, "#C5");
+ } finally {
+ AppDomain.Unload (ad);
+ }
+ }
+
+ [Test] // bug #79522
+ [Category ("NotWorking")]
+ public void Load_Manifest_Mismatch ()
+ {
+ string assemblyFile = Path.Combine (tempDir, "bug79522A.dll");
+ AssemblyName aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.Version = new Version (2, 4);
+
+ GenerateAssembly (aname, assemblyFile);
+
+ aname = new AssemblyName ();
+ aname.CodeBase = assemblyFile;
+ aname.Name = "whateveryouwant";
+ aname.Version = new Version (1, 1);
+
+ // despite the fact that no assembly with the specified name
+ // exists, the assembly pointed to by the CodeBase of the
+ // AssemblyName will be loaded
+ //
+ // however the display name of the loaded assembly does not
+ // match the display name of the AssemblyName, and as a result
+ // a FileLoadException is thrown
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A1");
+ } catch (FileLoadException) {
+ }
+
+ // if we set CodeBase to some garbage, then we'll get a
+ // FileNotFoundException instead
+ aname.CodeBase = "whatever";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A2");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A3");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 5);
+#if NET_2_0
+ // the version number is not considered when comparing the manifest
+ // of the assembly found using codebase
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A4");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 4, 1);
+#if NET_2_0
+ // the version number is not considered when comparing the manifest
+ // of the assembly found using codebase
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A5");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ // if version is set, then culture must also be set
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 4);
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A6");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ // version number does not need to be set
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ AppDomain.CurrentDomain.Load (aname);
+
+ // if set, the version number must match exactly
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ aname.Version = new Version (2, 4);
+ AppDomain.CurrentDomain.Load (aname);
+
+ // if both culture and version are set, then the version diff
+ // is ignored
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ aname.Version = new Version (2, 5);
+ AppDomain.CurrentDomain.Load (aname);
+
+ // loaded assembly is not signed
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = CultureInfo.InvariantCulture;
+ aname.Version = new Version (2, 4);
+ aname.SetPublicKey (publicKey);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A7");
+ } catch (FileLoadException) {
+ }
+
+ // if set, the culture must match
+ aname = new AssemblyName ();
+ aname.Name = "bug79522A";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 4);
+ aname.CultureInfo = new CultureInfo ("en-US");
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#A8");
+ } catch (FileLoadException) {
+ }
+
+ // PART B
+
+ assemblyFile = Path.Combine (tempDir, "bug79522B.dll");
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4, 1);
+
+ GenerateAssembly (aname, assemblyFile);
+
+ aname = new AssemblyName ();
+ aname.CodeBase = assemblyFile;
+ aname.Name = "whateveryouwant";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (1, 1);
+
+ // despite the fact that no assembly with the specified name
+ // exists, the assembly pointed to by the CodeBase of the
+ // AssemblyName will be loaded
+ //
+ // however the display name of the loaded assembly does not
+ // match the display name of the AssemblyName, and as a result
+ // a FileLoadException is thrown
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B1");
+ } catch (FileLoadException) {
+ }
+
+ // if we set CodeBase to some garbage, then we'll get a
+ // FileNotFoundException instead
+ aname.CodeBase = "whatever";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B2");
+ } catch (FileNotFoundException) {
+ }
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+#if NET_2_0
+ // the version number is not considered when comparing the manifest
+ // of the assembly found using codebase
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B3");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (5, 5);
+#if NET_2_0
+ // the version number is not considered when comparing the manifest
+ // of the assembly found using codebase
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B3");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 4, 1);
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ // when the loaded assembly has a specific culture, then that
+ // culture must be set if you set the Version on the aname
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B4");
+ } catch (FileLoadException) {
+ }
+#endif
+
+ // version does not need to be set
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ AppDomain.CurrentDomain.Load (aname);
+
+ // if both culture and version are set, then the version diff
+ // is ignored
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (6, 5);
+ AppDomain.CurrentDomain.Load (aname);
+
+ // loaded assembly is not signed
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.SetPublicKey (publicKey);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B5");
+ } catch (FileLoadException) {
+ }
+
+ // if set, the culture must match
+ aname = new AssemblyName ();
+ aname.Name = "bug79522B";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 4, 1);
+ aname.CultureInfo = new CultureInfo ("en-US");
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#B6");
+ } catch (FileLoadException) {
}
- files.Clear ();
- }
- [Test]
- public void SetThreadPrincipal ()
- {
- IIdentity i = new GenericIdentity ("sebastien@ximian.com", "rfc822");
- IPrincipal p = new GenericPrincipal (i, null);
- ad = AppDomain.CreateDomain ("SetThreadPrincipal");
- ad.SetThreadPrincipal (p);
- }
+ // PART C
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void SetThreadPrincipalNull ()
- {
- AppDomain.CurrentDomain.SetThreadPrincipal (null);
- }
+ assemblyFile = Path.Combine (tempDir, "bug79522C.dll");
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4);
+ aname.KeyPair = new StrongNameKeyPair (keyPair);
- [Test]
- [ExpectedException (typeof (PolicyException))]
- public void SetThreadPrincipalTwice ()
- {
- IIdentity i = new GenericIdentity ("sebastien@ximian.com", "rfc822");
- IPrincipal p = new GenericPrincipal (i, null);
- ad = AppDomain.CreateDomain ("SetThreadPrincipalTwice");
- ad.SetThreadPrincipal (p);
- // you only live twice (or so James told me ;-)
- ad.SetThreadPrincipal (p);
- }
+ GenerateAssembly (aname, assemblyFile);
- [Test]
- [ExpectedException (typeof (AppDomainUnloadedException))]
- [Ignore ("Unloading cause lots of GC warning")]
- public void SetThreadPrincipalUnloaded ()
- {
- ad = AppDomain.CreateDomain ("Ximian");
- AppDomain.Unload (ad);
- IIdentity i = new GenericIdentity ("sebastien@ximian.com", "rfc822");
- IPrincipal p = new GenericPrincipal (i, null);
- ad.SetThreadPrincipal (p);
- }
+ aname = new AssemblyName ();
+ aname.CodeBase = assemblyFile;
+ aname.Name = "whateveryouwant";
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (1, 1);
+ aname.SetPublicKey (publicKey);
- [Test]
- public void SetPrincipalPolicy_NoPrincipal ()
- {
- AppDomain.CurrentDomain.SetPrincipalPolicy (PrincipalPolicy.NoPrincipal);
- }
+ // despite the fact that no assembly with the specified name
+ // exists, the assembly pointed to by the CodeBase of the
+ // AssemblyName will be loaded
+ //
+ // however the display name of the loaded assembly does not
+ // match the display name of the AssemblyName, and as a result
+ // a FileLoadException is thrown
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C1");
+ } catch (FileLoadException) {
+ }
- [Test]
- public void SetPrincipalPolicy_UnauthenticatedPrincipal ()
- {
- AppDomain.CurrentDomain.SetPrincipalPolicy (PrincipalPolicy.UnauthenticatedPrincipal);
- }
+ // if we set CodeBase to some garbage, then we'll get a
+ // FileNotFoundException instead
+ aname.CodeBase = "whatever";
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C2");
+ } catch (FileNotFoundException) {
+ }
- [Test]
- public void SetPrincipalPolicy_WindowsPrincipal ()
- {
- AppDomain.CurrentDomain.SetPrincipalPolicy (PrincipalPolicy.WindowsPrincipal);
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C3");
+ } catch (FileLoadException) {
+ }
+#endif
- [Test]
- [ExpectedException (typeof (AppDomainUnloadedException))]
- [Ignore ("Unloading cause lots of GC warning")]
- public void SetPrincipalPolicyUnloaded ()
- {
- ad = AppDomain.CreateDomain ("Ximian");
- AppDomain.Unload (ad);
- ad.SetPrincipalPolicy (PrincipalPolicy.NoPrincipal);
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (5, 5);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C3");
+ } catch (FileLoadException) {
+ }
- [Test]
- public void CreateDomain_String ()
- {
- ad = AppDomain.CreateDomain ("CreateDomain_String");
- Assert.IsNotNull (ad.Evidence, "Evidence");
- // Evidence are copied (or referenced?) from default app domain
- // we can't get default so we use the current (which should have copied the default)
- Assert.AreEqual (AppDomain.CurrentDomain.Evidence.Count, ad.Evidence.Count, "Evidence.Count");
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.Version = new Version (2, 4);
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ // when the loaded assembly has a specific culture/publickey,
+ // then that culture/publickey must be set if you set the
+ // Version on the aname
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C4");
+ } catch (FileLoadException) {
+ }
+#endif
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void CreateDomain_String_Null ()
- {
- ad = AppDomain.CreateDomain (null);
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4);
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ // if loaded assembly is signed, then the public key must be set
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C5");
+ } catch (FileLoadException) {
+ }
+#endif
- [Test]
- public void CreateDomain_StringEvidence ()
- {
- Evidence e = new Evidence ();
- ad = AppDomain.CreateDomain ("CreateDomain_StringEvidence", e);
- Assert.IsNotNull (ad.Evidence, "Evidence");
- Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.SetPublicKey (publicKey);
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ // if public key is set, then version must be set
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C6");
+ } catch (FileLoadException) {
+ }
+#endif
- e.AddHost (new Zone (SecurityZone.MyComputer));
- Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
- // evidence isn't copied but referenced
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+#if NET_2_0
+ AppDomain.CurrentDomain.Load (aname);
+#else
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C7");
+ } catch (FileLoadException) {
+ }
+#endif
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void CreateDomain_StringNullEvidence ()
- {
- ad = AppDomain.CreateDomain (null, new Evidence ());
- }
+ // if culture and version are set, then the version must match
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.SetPublicKey (publicKey);
+ aname.Version = new Version (5, 6);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C8");
+ } catch (FileLoadException) {
+ }
- [Test]
- public void CreateDomain_StringEvidenceNull ()
- {
- ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceNull", null);
- Assert.IsNotNull (ad.Evidence, "Evidence");
- // Evidence are copied (or referenced?) from default app domain
- // we can't get default so we use the current (which should have copied the default)
- Evidence e = AppDomain.CurrentDomain.Evidence;
- Assert.AreEqual (e.Count, ad.Evidence.Count, "Evidence.Count-1");
- e.AddHost (new Zone (SecurityZone.MyComputer));
- Assert.AreEqual (e.Count - 1, ad.Evidence.Count, "Evidence.Count-2");
- // evidence are copied
+ // publickey must match
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4);
+ aname.SetPublicKey (publicKey2);
+ try {
+ AppDomain.CurrentDomain.Load (aname);
+ Assert.Fail ("#C9");
+#if NET_2_0
+ } catch (SecurityException) {
+ // Invalid assembly public key
+ }
+#else
+ } catch (FileLoadException) {
+ }
+#endif
+
+ aname = new AssemblyName ();
+ aname.Name = "bug79522C";
+ aname.CodeBase = assemblyFile;
+ aname.SetPublicKey (publicKey);
+ aname.CultureInfo = new CultureInfo ("nl-BE");
+ aname.Version = new Version (2, 4);
+ AppDomain.CurrentDomain.Load (aname);
}
- [Test]
- public void CreateDomain_StringEvidenceAppDomainSetup ()
+ [Test] // bug #79715
+ public void Load_PartialVersion ()
{
- Evidence e = new Evidence ();
- AppDomainSetup info = new AppDomainSetup ();
- info.ApplicationName = "ApplicationName";
+ AppDomain ad = CreateTestDomain (tempDir, true);
+ try {
+ CrossDomainTester cdt = CreateCrossDomainTester (ad);
- ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceAppDomainSetup", e, info);
- Assert.IsNotNull (ad.Evidence, "Evidence");
- Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
- Assert.IsNotNull (ad.SetupInformation, "SetupInformation");
- Assert.AreEqual ("ApplicationName", ad.SetupInformation.ApplicationName);
+ AssemblyName aname = new AssemblyName ();
+ aname.Name = "bug79715";
+ aname.Version = new Version (1, 2, 3, 4);
+ cdt.GenerateAssembly (aname, Path.Combine (tempDir, "bug79715.dll"));
- e.AddHost (new Zone (SecurityZone.MyComputer));
- Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
- // evidence isn't copied but referenced
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79715";
+ aname.Version = new Version (1, 2);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#A1");
+ Assert.IsTrue (cdt.AssertLoad (aname.FullName), "#A2");
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void CreateDomain_StringNullEvidenceAppDomainSetup ()
- {
- AppDomainSetup info = new AppDomainSetup ();
- ad = AppDomain.CreateDomain (null, new Evidence (), info);
- }
+ aname = new AssemblyName ();
+ aname.Name = "bug79715";
+ aname.Version = new Version (1, 2, 3);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#B1");
+ Assert.IsTrue (cdt.AssertLoad (aname.FullName), "#B2");
- [Test]
- public void CreateDomain_StringEvidenceNullAppDomainSetup ()
- {
- AppDomainSetup info = new AppDomainSetup ();
- info.ApplicationName = "ApplicationName";
- ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceNullAppDomainSetup", null, info);
- Assert.IsNotNull (ad.Evidence, "Evidence");
- // Evidence are copied (or referenced?) from default app domain
- // we can't get default so we use the current (which should have copied the default)
- Assert.AreEqual (AppDomain.CurrentDomain.Evidence.Count, ad.Evidence.Count, "Evidence.Count");
- Assert.AreEqual ("ApplicationName", ad.SetupInformation.ApplicationName, "ApplicationName-1");
- info.ApplicationName = "Test";
- Assert.AreEqual ("Test", info.ApplicationName, "ApplicationName-2");
- Assert.AreEqual ("ApplicationName", ad.SetupInformation.ApplicationName, "ApplicationName-3");
- // copied
+ aname = new AssemblyName ();
+ aname.Name = "bug79715";
+ aname.Version = new Version (1, 2, 3, 4);
+ Assert.IsTrue (cdt.AssertLoad (aname), "#C1");
+ Assert.IsTrue (cdt.AssertLoad (aname.FullName), "#C2");
+ } finally {
+ AppDomain.Unload (ad);
+ }
}
-
+
[Test]
- public void CreateDomain_StringEvidenceAppDomainSetupNull ()
+ [ExpectedException (typeof (ArgumentException))]
+ public void Load_EmptyString ()
{
- Evidence e = new Evidence ();
- ad = AppDomain.CreateDomain ("CreateDomain_StringEvidenceAppDomainSetupNull", e, null);
- Assert.IsNotNull (ad.Evidence, "Evidence");
- Assert.AreEqual (0, ad.Evidence.Count, "Evidence.Count");
- // SetupInformation is copied from default app domain
- Assert.IsNotNull (ad.SetupInformation, "SetupInformation");
+ AppDomain.CurrentDomain.Load ("");
}
[Test]
}
[Test]
-#if ! NET_2_0
- // MS bug for 2.x ???
[ExpectedException (typeof (PolicyException))]
-#endif
public void SetAppDomainPolicy_Dual ()
{
ad = AppDomain.CreateDomain ("SetAppDomainPolicy_Dual");
[Test]
[ExpectedException (typeof (AppDomainUnloadedException))]
- [Ignore ("Unloading cause lots of GC warning")]
public void SetAppDomainPolicy_Unloaded ()
{
ad = AppDomain.CreateDomain ("SetAppDomainPolicy_Unloaded");
}
#if NET_2_0
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void Activate_Null ()
- {
- AppDomain.Activate (null);
- }
-
- [Test]
- [ExpectedException (typeof (ArgumentNullException))]
- public void ActivateNewProcess_Null ()
- {
- AppDomain.ActivateNewProcess (null);
- }
-
[Test]
public void ApplyPolicy ()
{
ad = AppDomain.CreateDomain ("ReflectionOnlyGetAssemblies");
Assembly [] a = ad.ReflectionOnlyGetAssemblies ();
Assert.IsNotNull (a, "ReflectionOnlyGetAssemblies");
- Assert.AreEqual (0, a.Length, "Count");
+ Assert.AreEqual (0, a.Length, "Count");
+
+ string assemblyFile = Path.Combine (tempDir, "bug499013.dll");
+ AssemblyName aname = new AssemblyName ();
+ aname.Name = "bug499013";
+ aname.Version = new Version (2, 4);
+
+ GenerateAssembly (aname, assemblyFile);
+
+ Assembly.ReflectionOnlyLoadFrom (assemblyFile);
+ foreach (Assembly assembly in AppDomain.CurrentDomain.GetAssemblies ())
+ Assert.IsTrue (assembly.GetName ().Name != "bug499013");
+ }
+
+ [Test]
+ public void ReflectionOnlyAssemblyResolve ()
+ {
+ AppDomain.CurrentDomain.ReflectionOnlyAssemblyResolve += new ResolveEventHandler(CurrentDomain_ReflectionOnlyAssemblyResolve);
+ Assembly asm = Assembly.ReflectionOnlyLoad(Assembly.LoadWithPartialName("System").FullName);
+ asm.GetTypes();
+ }
+
+ private static Assembly CurrentDomain_ReflectionOnlyAssemblyResolve(object sender, ResolveEventArgs args)
+ {
+ return Assembly.ReflectionOnlyLoad(args.Name);
}
#endif
+
+ private static AppDomain CreateTestDomain (string baseDirectory, bool assemblyResolver)
+ {
+ AppDomainSetup setup = new AppDomainSetup ();
+ setup.ApplicationBase = baseDirectory;
+ setup.ApplicationName = "testdomain";
+ return CreateTestDomain (setup, assemblyResolver);
+ }
+
+ private static AppDomain CreateTestDomain (AppDomainSetup setup, bool assemblyResolver)
+ {
+ AppDomain ad = AppDomain.CreateDomain ("testdomain",
+ AppDomain.CurrentDomain.Evidence, setup);
+
+ if (assemblyResolver) {
+ Assembly ea = Assembly.GetExecutingAssembly ();
+ ad.CreateInstanceFrom (ea.CodeBase,
+ typeof (AssemblyResolveHandler).FullName,
+ false,
+ BindingFlags.Public | BindingFlags.Instance,
+ null,
+ new object [] { ea.Location, ea.FullName },
+ CultureInfo.InvariantCulture,
+ null,
+ null);
+ }
+
+ return ad;
+ }
+
+
+ private static CrossDomainTester CreateCrossDomainTester (AppDomain domain)
+ {
+ Type testerType = typeof (CrossDomainTester);
+ return (CrossDomainTester) domain.CreateInstanceAndUnwrap (
+ testerType.Assembly.FullName, testerType.FullName, false,
+ BindingFlags.Public | BindingFlags.Instance, null, new object [0],
+ CultureInfo.InvariantCulture, new object [0], null);
+ }
+
+ private static void GenerateAssembly (AssemblyName aname, string path)
+ {
+ AppDomain ad = CreateTestDomain (AppDomain.CurrentDomain.BaseDirectory,
+ false);
+ try {
+ CrossDomainTester cdt = CreateCrossDomainTester (ad);
+ cdt.GenerateAssembly (aname, path);
+ } finally {
+ AppDomain.Unload (ad);
+ }
+ }
+
+ private bool RunningOnUnix {
+ get {
+ // check for Unix platforms - see FAQ for more details
+ // http://www.mono-project.com/FAQ:_Technical#How_to_detect_the_execution_platform_.3F
+ int platform = (int) Environment.OSVersion.Platform;
+ return ((platform == 4) || (platform == 128) || (platform == 6));
+ }
+ }
+
+ private class CrossDomainTester : MarshalByRefObject
+ {
+ public void GenerateAssembly (AssemblyName aname, string path)
+ {
+ AssemblyBuilder ab = AppDomain.CurrentDomain.DefineDynamicAssembly (
+ aname, AssemblyBuilderAccess.Save, Path.GetDirectoryName (path));
+ ab.Save (Path.GetFileName (path));
+ }
+
+ public int AssemblyCount {
+ get {
+ return AppDomain.CurrentDomain.GetAssemblies ().Length;
+ }
+ }
+
+ public string GetApplicationBase ()
+ {
+ return AppDomain.CurrentDomain.SetupInformation.ApplicationBase;
+ }
+
+ public string GetConfigurationFile ()
+ {
+ return AppDomain.CurrentDomain.SetupInformation.ConfigurationFile;
+ }
+
+ public void Load (AssemblyName assemblyRef)
+ {
+ AppDomain.CurrentDomain.Load (assemblyRef);
+ }
+
+ public void LoadFrom (string assemblyFile)
+ {
+ Assembly.LoadFrom (assemblyFile);
+ }
+
+ public bool AssertLoad (AssemblyName assemblyRef)
+ {
+ try {
+ AppDomain.CurrentDomain.Load (assemblyRef);
+ return true;
+ } catch {
+ return false;
+ }
+ }
+
+ public bool AssertLoad (string assemblyString)
+ {
+ try {
+ AppDomain.CurrentDomain.Load (assemblyString);
+ return true;
+ } catch {
+ return false;
+ }
+ }
+
+ public bool AssertFileLoadException (AssemblyName assemblyRef)
+ {
+ try {
+ AppDomain.CurrentDomain.Load (assemblyRef);
+ return false;
+ } catch (FileLoadException) {
+ return true;
+ }
+ }
+
+ public bool AssertFileNotFoundException (AssemblyName assemblyRef)
+ {
+ try {
+ AppDomain.CurrentDomain.Load (assemblyRef);
+ return false;
+ } catch (FileNotFoundException) {
+ return true;
+ }
+ }
+ }
+
+ [Serializable ()]
+ private class AssemblyResolveHandler
+ {
+ public AssemblyResolveHandler (string assemblyFile, string assemblyName)
+ {
+ _assemblyFile = assemblyFile;
+ _assemblyName = assemblyName;
+
+ AppDomain.CurrentDomain.AssemblyResolve +=
+ new ResolveEventHandler (ResolveAssembly);
+ }
+
+ private Assembly ResolveAssembly (object sender, ResolveEventArgs args)
+ {
+ if (args.Name == _assemblyName)
+ return Assembly.LoadFrom (_assemblyFile);
+
+ return null;
+ }
+
+ private readonly string _assemblyFile;
+ private readonly string _assemblyName;
+ }
+
+ static byte [] keyPair = {
+ 0x07, 0x02, 0x00, 0x00, 0x00, 0x24, 0x00, 0x00, 0x52, 0x53, 0x41,
+ 0x32, 0x00, 0x04, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x3D, 0xBD,
+ 0x72, 0x08, 0xC6, 0x2B, 0x0E, 0xA8, 0xC1, 0xC0, 0x58, 0x07, 0x2B,
+ 0x63, 0x5F, 0x7C, 0x9A, 0xBD, 0xCB, 0x22, 0xDB, 0x20, 0xB2, 0xA9,
+ 0xDA, 0xDA, 0xEF, 0xE8, 0x00, 0x64, 0x2F, 0x5D, 0x8D, 0xEB, 0x78,
+ 0x02, 0xF7, 0xA5, 0x36, 0x77, 0x28, 0xD7, 0x55, 0x8D, 0x14, 0x68,
+ 0xDB, 0xEB, 0x24, 0x09, 0xD0, 0x2B, 0x13, 0x1B, 0x92, 0x6E, 0x2E,
+ 0x59, 0x54, 0x4A, 0xAC, 0x18, 0xCF, 0xC9, 0x09, 0x02, 0x3F, 0x4F,
+ 0xA8, 0x3E, 0x94, 0x00, 0x1F, 0xC2, 0xF1, 0x1A, 0x27, 0x47, 0x7D,
+ 0x10, 0x84, 0xF5, 0x14, 0xB8, 0x61, 0x62, 0x1A, 0x0C, 0x66, 0xAB,
+ 0xD2, 0x4C, 0x4B, 0x9F, 0xC9, 0x0F, 0x3C, 0xD8, 0x92, 0x0F, 0xF5,
+ 0xFF, 0xCE, 0xD7, 0x6E, 0x5C, 0x6F, 0xB1, 0xF5, 0x7D, 0xD3, 0x56,
+ 0xF9, 0x67, 0x27, 0xA4, 0xA5, 0x48, 0x5B, 0x07, 0x93, 0x44, 0x00,
+ 0x4A, 0xF8, 0xFF, 0xA4, 0xCB, 0x73, 0xC0, 0x6A, 0x62, 0xB4, 0xB7,
+ 0xC8, 0x92, 0x58, 0x87, 0xCD, 0x07, 0x0C, 0x7D, 0x6C, 0xC1, 0x4A,
+ 0xFC, 0x82, 0x57, 0x0E, 0x43, 0x85, 0x09, 0x75, 0x98, 0x51, 0xBB,
+ 0x35, 0xF5, 0x64, 0x83, 0xC7, 0x79, 0x89, 0x5C, 0x55, 0x36, 0x66,
+ 0xAB, 0x27, 0xA4, 0xD9, 0xD4, 0x7E, 0x6B, 0x67, 0x64, 0xC1, 0x54,
+ 0x4E, 0x37, 0xF1, 0x4E, 0xCA, 0xB3, 0xE5, 0x63, 0x91, 0x57, 0x12,
+ 0x14, 0xA6, 0xEA, 0x8F, 0x8F, 0x2B, 0xFE, 0xF3, 0xE9, 0x16, 0x08,
+ 0x2B, 0x86, 0xBC, 0x26, 0x0D, 0xD0, 0xC6, 0xC4, 0x1A, 0x72, 0x43,
+ 0x76, 0xDC, 0xFF, 0x28, 0x52, 0xA1, 0xDE, 0x8D, 0xFA, 0xD5, 0x1F,
+ 0x0B, 0xB5, 0x4F, 0xAF, 0x06, 0x79, 0x11, 0xEE, 0xA8, 0xEC, 0xD3,
+ 0x74, 0x55, 0xA2, 0x80, 0xFC, 0xF8, 0xD9, 0x50, 0x69, 0x48, 0x01,
+ 0xC2, 0x5A, 0x04, 0x56, 0xB4, 0x3E, 0x24, 0x32, 0x20, 0xB5, 0x2C,
+ 0xDE, 0xBB, 0xBD, 0x13, 0xFD, 0x13, 0xF7, 0x03, 0x3E, 0xE3, 0x37,
+ 0x84, 0x74, 0xE7, 0xD0, 0x5E, 0x9E, 0xB6, 0x26, 0xAE, 0x6E, 0xB0,
+ 0x55, 0x6A, 0x52, 0x63, 0x6F, 0x5A, 0x9D, 0xF2, 0x67, 0xD6, 0x61,
+ 0x4F, 0x7A, 0x45, 0xEE, 0x5C, 0x3D, 0x2B, 0x7C, 0xB2, 0x40, 0x79,
+ 0x54, 0x84, 0xD1, 0xBE, 0x61, 0x3E, 0x5E, 0xD6, 0x18, 0x8E, 0x14,
+ 0x98, 0xFC, 0x35, 0xBF, 0x5F, 0x1A, 0x20, 0x2E, 0x1A, 0xD8, 0xFF,
+ 0xC4, 0x6B, 0xC0, 0xC9, 0x7D, 0x06, 0xEF, 0x09, 0xF9, 0xF3, 0x69,
+ 0xFC, 0xBC, 0xA2, 0xE6, 0x80, 0x22, 0xB9, 0x79, 0x7E, 0xEF, 0x57,
+ 0x9F, 0x49, 0xE1, 0xBC, 0x0D, 0xB6, 0xA1, 0xFE, 0x8D, 0xBC, 0xBB,
+ 0xA3, 0x05, 0x02, 0x6B, 0x04, 0x45, 0xF7, 0x5D, 0xEE, 0x43, 0x06,
+ 0xD6, 0x9C, 0x94, 0x48, 0x1A, 0x0B, 0x9C, 0xBC, 0xB4, 0x4E, 0x93,
+ 0x60, 0x87, 0xCD, 0x58, 0xD6, 0x9A, 0x39, 0xA6, 0xC0, 0x7F, 0x8E,
+ 0xFF, 0x25, 0xC1, 0xD7, 0x2C, 0xF6, 0xF4, 0x6F, 0x24, 0x52, 0x0B,
+ 0x39, 0x42, 0x1B, 0x0D, 0x04, 0xC1, 0x93, 0x2A, 0x19, 0x1C, 0xF0,
+ 0xB1, 0x9B, 0xC1, 0x24, 0x6D, 0x1B, 0x0B, 0xDA, 0x1C, 0x8B, 0x72,
+ 0x48, 0xF0, 0x3E, 0x52, 0xBF, 0x0A, 0x84, 0x3A, 0x9B, 0xC8, 0x6D,
+ 0x13, 0x1E, 0x72, 0xF4, 0x46, 0x93, 0x88, 0x1A, 0x5F, 0x4C, 0x3C,
+ 0xE5, 0x9D, 0x6E, 0xBB, 0x4E, 0xDD, 0x5D, 0x1F, 0x11, 0x40, 0xF4,
+ 0xD7, 0xAF, 0xB3, 0xAB, 0x9A, 0x99, 0x15, 0xF0, 0xDC, 0xAA, 0xFF,
+ 0x9F, 0x2D, 0x9E, 0x56, 0x4F, 0x35, 0x5B, 0xBA, 0x06, 0x99, 0xEA,
+ 0xC6, 0xB4, 0x48, 0x51, 0x17, 0x1E, 0xD1, 0x95, 0x84, 0x81, 0x18,
+ 0xC0, 0xF1, 0x71, 0xDE, 0x44, 0x42, 0x02, 0x06, 0xAC, 0x0E, 0xA8,
+ 0xE2, 0xF3, 0x1F, 0x96, 0x1F, 0xBE, 0xB6, 0x1F, 0xB5, 0x3E, 0xF6,
+ 0x81, 0x05, 0x20, 0xFA, 0x2E, 0x40, 0x2E, 0x4D, 0xA0, 0x0E, 0xDA,
+ 0x42, 0x9C, 0x05, 0xAA, 0x9E, 0xAF, 0x5C, 0xF7, 0x3A, 0x3F, 0xBB,
+ 0x91, 0x73, 0x45, 0x27, 0xA8, 0xA2, 0x07, 0x4A, 0xEF, 0x59, 0x1E,
+ 0x97, 0x9D, 0xE0, 0x30, 0x5A, 0x83, 0xCE, 0x1E, 0x57, 0x32, 0x89,
+ 0x43, 0x41, 0x28, 0x7D, 0x14, 0x8D, 0x8B, 0x41, 0x1A, 0x56, 0x76,
+ 0x43, 0xDB, 0x64, 0x86, 0x41, 0x64, 0x8D, 0x4C, 0x91, 0x83, 0x4E,
+ 0xF5, 0x6C };
+
+ static byte [] publicKey2 = {
+ 0x07, 0x02, 0x00, 0x00, 0x00, 0x24, 0x00, 0x00, 0x52, 0x53, 0x41,
+ 0x32, 0x00, 0x04, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x7F, 0x7C,
+ 0xEA, 0x4A, 0x28, 0x33, 0xD8, 0x3C, 0x86, 0x90, 0x86, 0x91, 0x11,
+ 0xBB, 0x30, 0x0D, 0x3D, 0x69, 0x04, 0x4C, 0x48, 0xF5, 0x4F, 0xE7,
+ 0x64, 0xA5, 0x82, 0x72, 0x5A, 0x92, 0xC4, 0x3D, 0xC5, 0x90, 0x93,
+ 0x41, 0xC9, 0x1D, 0x34, 0x16, 0x72, 0x2B, 0x85, 0xC1, 0xF3, 0x99,
+ 0x62, 0x07, 0x32, 0x98, 0xB7, 0xE4, 0xFA, 0x75, 0x81, 0x8D, 0x08,
+ 0xB9, 0xFD, 0xDB, 0x00, 0x25, 0x30, 0xC4, 0x89, 0x13, 0xB6, 0x43,
+ 0xE8, 0xCC, 0xBE, 0x03, 0x2E, 0x1A, 0x6A, 0x4D, 0x36, 0xB1, 0xEB,
+ 0x49, 0x26, 0x6C, 0xAB, 0xC4, 0x29, 0xD7, 0x8F, 0x25, 0x11, 0xA4,
+ 0x7C, 0x81, 0x61, 0x97, 0xCB, 0x44, 0x2D, 0x80, 0x49, 0x93, 0x48,
+ 0xA7, 0xC9, 0xAB, 0xDB, 0xCF, 0xA3, 0x34, 0xCB, 0x6B, 0x86, 0xE0,
+ 0x4D, 0x27, 0xFC, 0xA7, 0x4F, 0x36, 0xCA, 0x13, 0x42, 0xD3, 0x83,
+ 0xC4, 0x06, 0x6E, 0x12, 0xE0, 0xA1, 0x3D, 0x9F, 0xA9, 0xEC, 0xD1,
+ 0xC6, 0x08, 0x1B, 0x3D, 0xF5, 0xDB, 0x4C, 0xD4, 0xF0, 0x2C, 0xAA,
+ 0xFC, 0xBA, 0x18, 0x6F, 0x48, 0x7E, 0xB9, 0x47, 0x68, 0x2E, 0xF6,
+ 0x1E, 0x67, 0x1C, 0x7E, 0x0A, 0xCE, 0x10, 0x07, 0xC0, 0x0C, 0xAD,
+ 0x5E, 0xC1, 0x53, 0x70, 0xD5, 0xE7, 0x25, 0xCA, 0x37, 0x5E, 0x49,
+ 0x59, 0xD0, 0x67, 0x2A, 0xBE, 0x92, 0x36, 0x86, 0x8A, 0xBF, 0x3E,
+ 0x17, 0x04, 0xFB, 0x1F, 0x46, 0xC8, 0x10, 0x5C, 0x93, 0x02, 0x43,
+ 0x14, 0x96, 0x6A, 0xD9, 0x87, 0x17, 0x62, 0x7D, 0x3A, 0x45, 0xBE,
+ 0x35, 0xDE, 0x75, 0x0B, 0x2A, 0xCE, 0x7D, 0xF3, 0x19, 0x85, 0x4B,
+ 0x0D, 0x6F, 0x8D, 0x15, 0xA3, 0x60, 0x61, 0x28, 0x55, 0x46, 0xCE,
+ 0x78, 0x31, 0x04, 0x18, 0x3C, 0x56, 0x4A, 0x3F, 0xA4, 0xC9, 0xB1,
+ 0x41, 0xED, 0x22, 0x80, 0xA1, 0xB3, 0xE2, 0xC7, 0x1B, 0x62, 0x85,
+ 0xE4, 0x81, 0x39, 0xCB, 0x1F, 0x95, 0xCC, 0x61, 0x61, 0xDF, 0xDE,
+ 0xF3, 0x05, 0x68, 0xB9, 0x7D, 0x4F, 0xFF, 0xF3, 0xC0, 0x0A, 0x25,
+ 0x62, 0xD9, 0x8A, 0x8A, 0x9E, 0x99, 0x0B, 0xFB, 0x85, 0x27, 0x8D,
+ 0xF6, 0xD4, 0xE1, 0xB9, 0xDE, 0xB4, 0x16, 0xBD, 0xDF, 0x6A, 0x25,
+ 0x9C, 0xAC, 0xCD, 0x91, 0xF7, 0xCB, 0xC1, 0x81, 0x22, 0x0D, 0xF4,
+ 0x7E, 0xEC, 0x0C, 0x84, 0x13, 0x5A, 0x74, 0x59, 0x3F, 0x3E, 0x61,
+ 0x00, 0xD6, 0xB5, 0x4A, 0xA1, 0x04, 0xB5, 0xA7, 0x1C, 0x29, 0xD0,
+ 0xE1, 0x11, 0x19, 0xD7, 0x80, 0x5C, 0xEE, 0x08, 0x15, 0xEB, 0xC9,
+ 0xA8, 0x98, 0xF5, 0xA0, 0xF0, 0x92, 0x2A, 0xB0, 0xD3, 0xC7, 0x8C,
+ 0x8D, 0xBB, 0x88, 0x96, 0x4F, 0x18, 0xF0, 0x8A, 0xF9, 0x31, 0x9E,
+ 0x44, 0x94, 0x75, 0x6F, 0x78, 0x04, 0x10, 0xEC, 0xF3, 0xB0, 0xCE,
+ 0xA0, 0xBE, 0x7B, 0x25, 0xE1, 0xF7, 0x8A, 0xA8, 0xD4, 0x63, 0xC2,
+ 0x65, 0x47, 0xCC, 0x5C, 0xED, 0x7D, 0x8B, 0x07, 0x4D, 0x76, 0x29,
+ 0x53, 0xAC, 0x27, 0x8F, 0x5D, 0x78, 0x56, 0xFA, 0x99, 0x45, 0xA2,
+ 0xCC, 0x65, 0xC4, 0x54, 0x13, 0x9F, 0x38, 0x41, 0x7A, 0x61, 0x0E,
+ 0x0D, 0x34, 0xBC, 0x11, 0xAF, 0xE2, 0xF1, 0x8B, 0xFA, 0x2B, 0x54,
+ 0x6C, 0xA3, 0x6C, 0x09, 0x1F, 0x0B, 0x43, 0x9B, 0x07, 0x95, 0x83,
+ 0x3F, 0x97, 0x99, 0x89, 0xF5, 0x51, 0x41, 0xF6, 0x8E, 0x5D, 0xEF,
+ 0x6D, 0x24, 0x71, 0x41, 0x7A, 0xAF, 0xBE, 0x81, 0x71, 0xAB, 0x76,
+ 0x2F, 0x1A, 0x5A, 0xBA, 0xF3, 0xA6, 0x65, 0x7A, 0x80, 0x50, 0xCE,
+ 0x23, 0xC3, 0xC7, 0x53, 0xB0, 0x7C, 0x97, 0x77, 0x27, 0x70, 0x98,
+ 0xAE, 0xB5, 0x24, 0x66, 0xE1, 0x60, 0x39, 0x41, 0xDA, 0x54, 0x01,
+ 0x64, 0xFB, 0x10, 0x33, 0xCE, 0x8B, 0xBE, 0x27, 0xD4, 0x21, 0x57,
+ 0xCC, 0x0F, 0x1A, 0xC1, 0x3D, 0xF3, 0xCC, 0x39, 0xF0, 0x2F, 0xAE,
+ 0xF1, 0xC0, 0xCD, 0x3B, 0x23, 0x87, 0x49, 0x7E, 0x40, 0x32, 0x6A,
+ 0xD3, 0x96, 0x4A, 0xE5, 0x5E, 0x6E, 0x26, 0xFD, 0x8A, 0xCF, 0x7E,
+ 0xFC, 0x37, 0xDE, 0x39, 0x0C, 0x53, 0x81, 0x75, 0x08, 0xAF, 0x6B,
+ 0x39, 0x6C, 0xFB, 0xC9, 0x79, 0xC0, 0x9B, 0x5F, 0x34, 0x86, 0xB2,
+ 0xDE, 0xC4, 0x19, 0x84, 0x5F, 0x0E, 0xED, 0x9B, 0xB8, 0xD3, 0x17,
+ 0xDA, 0x78 };
+
+ static byte [] publicKey = {
+ 0x00, 0x24, 0x00, 0x00, 0x04, 0x80, 0x00, 0x00, 0x94, 0x00, 0x00,
+ 0x00, 0x06, 0x02, 0x00, 0x00, 0x00, 0x24, 0x00, 0x00, 0x52, 0x53,
+ 0x41, 0x31, 0x00, 0x04, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x3d,
+ 0xbd, 0x72, 0x08, 0xc6, 0x2b, 0x0e, 0xa8, 0xc1, 0xc0, 0x58, 0x07,
+ 0x2b, 0x63, 0x5f, 0x7c, 0x9a, 0xbd, 0xcb, 0x22, 0xdb, 0x20, 0xb2,
+ 0xa9, 0xda, 0xda, 0xef, 0xe8, 0x00, 0x64, 0x2f, 0x5d, 0x8d, 0xeb,
+ 0x78, 0x02, 0xf7, 0xa5, 0x36, 0x77, 0x28, 0xd7, 0x55, 0x8d, 0x14,
+ 0x68, 0xdb, 0xeb, 0x24, 0x09, 0xd0, 0x2b, 0x13, 0x1b, 0x92, 0x6e,
+ 0x2e, 0x59, 0x54, 0x4a, 0xac, 0x18, 0xcf, 0xc9, 0x09, 0x02, 0x3f,
+ 0x4f, 0xa8, 0x3e, 0x94, 0x00, 0x1f, 0xc2, 0xf1, 0x1a, 0x27, 0x47,
+ 0x7d, 0x10, 0x84, 0xf5, 0x14, 0xb8, 0x61, 0x62, 0x1a, 0x0c, 0x66,
+ 0xab, 0xd2, 0x4c, 0x4b, 0x9f, 0xc9, 0x0f, 0x3c, 0xd8, 0x92, 0x0f,
+ 0xf5, 0xff, 0xce, 0xd7, 0x6e, 0x5c, 0x6f, 0xb1, 0xf5, 0x7d, 0xd3,
+ 0x56, 0xf9, 0x67, 0x27, 0xa4, 0xa5, 0x48, 0x5b, 0x07, 0x93, 0x44,
+ 0x00, 0x4a, 0xf8, 0xff, 0xa4, 0xcb };
+
+ static byte [] pk_token = { 0xce, 0x52, 0x76, 0xd8, 0x68, 0x7e, 0Xc6, 0xdc };
}
}