// // PolicyLevelTest.cs - NUnit Test Cases for PolicyLevel // // Author: // Sebastien Pouliot // // (C) 2004 Motus Technologies Inc. (http://www.motus.com) // Copyright (C) 2004 Novell, Inc (http://www.novell.com) // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using NUnit.Framework; using System; using System.IO; using System.Security; using System.Security.Permissions; using System.Security.Policy; using System.Text; namespace MonoTests.System.Security.Policy { [TestFixture] #if MOBILE [Ignore ("Not supported")] #endif public class PolicyLevelTest { static string minimal = null; static string minimal_policy = null; static byte[] snPublicKey = { 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 }; [SetUp] public void SetUp () { if (minimal == null) { minimal_policy = "\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n"; minimal_policy += " \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n"; minimal_policy += " \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n"; minimal_policy += " \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n"; minimal = Envelope (minimal_policy); } } private string Envelope (string policy) { return "" + policy + ""; } private PolicyLevel Load (string xml, PolicyLevelType type) { return SecurityManager.LoadPolicyLevelFromString (xml, type); // return SecurityManager.LoadPolicyLevelFromFile (@"C:\WINDOWS\Microsoft.NET\Framework\v1.0.3705\CONFIG\minimal.config", type); } [Test] public void AddFullTrustAssembly () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); int n = pl.FullTrustAssemblies.Count; StrongName sn = new StrongName (new StrongNamePublicKeyBlob (snPublicKey), "First", new Version (1, 2, 3, 4)); pl.AddFullTrustAssembly (sn); Assert.AreEqual (n + 1, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count+1"); StrongNameMembershipCondition snmc = new StrongNameMembershipCondition (new StrongNamePublicKeyBlob (snPublicKey), "Second", new Version ("0.1.2.3")); pl.AddFullTrustAssembly (snmc); Assert.AreEqual (n + 2, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count+2"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void AddFullTrustAssembly_NullStrongName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongName sn = null; pl.AddFullTrustAssembly (sn); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void AddFullTrustAssembly_NullStrongNameMembershipCondition () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongNameMembershipCondition snmc = null; pl.AddFullTrustAssembly (snmc); } [Test] [ExpectedException (typeof (ArgumentException))] public void AddFullTrustAssembly_DuplicateStrongName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongName sn = new StrongName (new StrongNamePublicKeyBlob (snPublicKey), "First", new Version (1, 2, 3, 4)); pl.AddFullTrustAssembly (sn); pl.AddFullTrustAssembly (sn); } [Test] [ExpectedException (typeof (ArgumentException))] public void AddFullTrustAssembly_DuplicateStrongNameMembershipCondition () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongNameMembershipCondition snmc = new StrongNameMembershipCondition (new StrongNamePublicKeyBlob (snPublicKey), "Second", new Version ("0.1.2.3")); pl.AddFullTrustAssembly (snmc); pl.AddFullTrustAssembly (snmc); } [Test] public void AddNamedPermissionSet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); int n = pl.NamedPermissionSets.Count; NamedPermissionSet nps = new NamedPermissionSet ("Mono", PermissionState.Unrestricted); pl.AddNamedPermissionSet (nps); // ExecutionEngineException here! Assert.AreEqual (n + 1, pl.NamedPermissionSets.Count, "NamedPermissionSets.Count+1"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void AddNamedPermissionSet_Null () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.AddNamedPermissionSet (null); } [Test] [ExpectedException (typeof (ArgumentException))] public void AddNamedPermissionSet_Duplicate () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps1 = new NamedPermissionSet ("Mono", PermissionState.Unrestricted); pl.AddNamedPermissionSet (nps1); NamedPermissionSet nps2 = new NamedPermissionSet ("Mono", PermissionState.None); // ExecutionEngineException here! pl.AddNamedPermissionSet (nps2); } [Test] public void ChangeNamedPermissionSet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps1 = new NamedPermissionSet ("Mono", PermissionState.Unrestricted); pl.AddNamedPermissionSet (nps1); NamedPermissionSet nps2 = new NamedPermissionSet ("Mono", PermissionState.None); // ExecutionEngineException here! pl.ChangeNamedPermissionSet ("Mono", nps2); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void ChangeNamedPermissionSet_NullName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps2 = new NamedPermissionSet ("Mono", PermissionState.None); pl.ChangeNamedPermissionSet (null, nps2); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void ChangeNamedPermissionSet_NullPermissionSet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.ChangeNamedPermissionSet ("Mono", null); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_NotFound () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps2 = new NamedPermissionSet ("Mono", PermissionState.None); pl.ChangeNamedPermissionSet ("Mono", nps2); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_FullTrust () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("FullTrust", ps); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_LocalIntranet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("LocalIntranet", ps); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_Internet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("Internet", ps); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_SkipVerification () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("SkipVerification", ps); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_ () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("Execution", ps); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_Nothing () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("SkipVerification", ps); } [Test] [ExpectedException (typeof (ArgumentException))] public void ChangeNamedPermissionSet_Reserved_Everything () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PermissionSet ps = new PermissionSet (PermissionState.None); pl.ChangeNamedPermissionSet ("Everything", ps); } [Test] public void CreateAppDomainLevel () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); Assert.AreEqual ("AppDomain", pl.Label, "Label"); Assert.AreEqual ("FullTrust", pl.RootCodeGroup.PermissionSetName, "RootCodeGroup==FullTrust"); Assert.AreEqual (0, pl.RootCodeGroup.Children.Count, "RootCodeGroup/NoChildren"); Assert.IsTrue (pl.RootCodeGroup.PolicyStatement.PermissionSet.IsUnrestricted (), "RootCodeGroup.PolicyStatement.PermissionSet.IsUnrestricted"); } [Test] // Makes distcheck fail because there is no Mono installed into the prefix // thus making the GAC not work... [Category ("NotWorking")] public void FromXml () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); SecurityElement se = pl.ToXml (); pl.FromXml (se); Assert.AreEqual ("AppDomain", pl.Label, "Label"); Assert.AreEqual ("All_Code", pl.RootCodeGroup.Name, "RootCodeGroup"); Assert.AreEqual ("FullTrust", pl.RootCodeGroup.PermissionSetName, "PermissionSetName"); Assert.AreEqual (0, pl.RootCodeGroup.Children.Count, "Children"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void FromXml_Null () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); pl.FromXml (null); } [Test] // Makes distcheck fail because there is no Mono installed into the prefix // thus making the GAC not work... [Category ("NotWorking")] [ExpectedException (typeof (ArgumentException))] public void FromXml_Invalid () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); SecurityElement se = pl.ToXml (); se.Tag = "Mono"; // strangely this works :( pl.FromXml (se); // let's get weirder :) foreach (SecurityElement child in se.Children) { child.Tag = "Mono"; } pl.FromXml (se); // it's enough >:) } [Test] public void GetNamedPermissionSet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps = pl.GetNamedPermissionSet ("Mono"); Assert.IsNull (nps, "GetNamedPermissionSet(notfound)"); nps = new NamedPermissionSet ("Mono", PermissionState.None); pl.AddNamedPermissionSet (nps); // ExecutionEngineException here! nps = pl.GetNamedPermissionSet ("Mono"); Assert.IsNotNull (nps, "GetNamedPermissionSet(found)"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void GetNamedPermissionSet_Null () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps = pl.GetNamedPermissionSet (null); } [Test] public void Label () { PolicyLevel pl = Load (minimal, PolicyLevelType.AppDomain); Assert.AreEqual ("AppDomain", pl.Label, "Label.AppDomain"); pl = Load (minimal, PolicyLevelType.Enterprise); Assert.AreEqual ("Enterprise", pl.Label, "Label.Enterprise"); pl = Load (minimal, PolicyLevelType.Machine); Assert.AreEqual ("Machine", pl.Label, "Label.Machine"); pl = Load (minimal, PolicyLevelType.User); Assert.AreEqual ("User", pl.Label, "Label.User"); // static method pl = PolicyLevel.CreateAppDomainLevel (); Assert.AreEqual ("AppDomain", pl.Label, "Label.AppDomain"); } [Test] [ExpectedException (typeof (PolicyException))] public void Recover_LoadPolicyLevelFromFile () { string temp = Path.GetTempFileName (); using (FileStream fs = File.OpenWrite (temp)) { // that way we're sure that no back exists byte[] data = Encoding.UTF8.GetBytes (minimal); fs.Write (data, 0, data.Length); fs.Close (); } PolicyLevel pl = SecurityManager.LoadPolicyLevelFromFile (temp, PolicyLevelType.User); pl.Recover (); // can't recover if no backup exists } [Test] [ExpectedException (typeof (PolicyException))] public void Recover_LoadPolicyLevelFromString () { PolicyLevel pl = SecurityManager.LoadPolicyLevelFromString (minimal, PolicyLevelType.Enterprise); pl.Recover (); // can't recover as it's not file based } [Test] [ExpectedException (typeof (PolicyException))] public void Recover_AppDomainLevel () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); pl.Recover (); // can't recover as it's not file based } [Test] public void RemoveFullTrustAssembly () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); int n = pl.FullTrustAssemblies.Count; StrongName sn = new StrongName (new StrongNamePublicKeyBlob (snPublicKey), "First", new Version (1, 2, 3, 4)); pl.AddFullTrustAssembly (sn); Assert.AreEqual (n + 1, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count+1"); StrongNameMembershipCondition snmc = new StrongNameMembershipCondition (new StrongNamePublicKeyBlob (snPublicKey), "Second", new Version ("0.1.2.3")); pl.AddFullTrustAssembly (snmc); Assert.AreEqual (n + 2, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count+2"); pl.RemoveFullTrustAssembly (sn); Assert.AreEqual (n + 1, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count-1"); pl.RemoveFullTrustAssembly (snmc); Assert.AreEqual (n, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count-2"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void RemoveFullTrustAssembly_NullStrongName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongName sn = null; pl.RemoveFullTrustAssembly (sn); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void RemoveFullTrustAssembly_NullStrongNameMembershipCondition () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongNameMembershipCondition snmc = null; pl.RemoveFullTrustAssembly (snmc); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveFullTrustAssembly_UnknownStrongName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongName sn = new StrongName (new StrongNamePublicKeyBlob (snPublicKey), "First", new Version (1, 2, 3, 4)); pl.RemoveFullTrustAssembly (sn); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveFullTrustAssembly_UnknownStrongNameMembershipCondition () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); StrongNameMembershipCondition snmc = new StrongNameMembershipCondition (new StrongNamePublicKeyBlob (snPublicKey), "Second", new Version ("0.1.2.3")); pl.RemoveFullTrustAssembly (snmc); } [Test] public void RemoveNamedPermissionSet () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); int n = pl.NamedPermissionSets.Count; NamedPermissionSet nps = new NamedPermissionSet ("Mono", PermissionState.Unrestricted); pl.AddNamedPermissionSet (nps); // ExecutionEngineException here! pl.RemoveNamedPermissionSet (nps); Assert.AreEqual (n, pl.NamedPermissionSets.Count, "NamedPermissionSets.Count"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void RemoveNamedPermissionSet_Null () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ((NamedPermissionSet)null); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_NotFound () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); NamedPermissionSet nps = new NamedPermissionSet ("Mono", PermissionState.Unrestricted); pl.RemoveNamedPermissionSet (nps); } [Test] public void RemoveNamedPermissionSet_String () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); int n = pl.NamedPermissionSets.Count; NamedPermissionSet nps = new NamedPermissionSet ("Mono", PermissionState.Unrestricted); pl.AddNamedPermissionSet (nps); // ExecutionEngineException here! pl.RemoveNamedPermissionSet ("Mono"); Assert.AreEqual (n, pl.NamedPermissionSets.Count, "NamedPermissionSets.Count"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void RemoveNamedPermissionSet_StringNull () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ((string)null); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_StringNotFound () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("Mono"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_FullTrust_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("FullTrust"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_LocalIntranet_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("LocalIntranet"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_Internet_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("Internet"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_SkipVerification_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("SkipVerification"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_Execution_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("Execution"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_Nothing_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("Nothing"); } [Test] [ExpectedException (typeof (ArgumentException))] public void RemoveNamedPermissionSet_Everything_ReservedName () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); pl.RemoveNamedPermissionSet ("Everything"); } [Test] public void Reset () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); int n = pl.FullTrustAssemblies.Count; StrongName sn = new StrongName (new StrongNamePublicKeyBlob (snPublicKey), "First", new Version (1, 2, 3, 4)); pl.AddFullTrustAssembly (sn); Assert.AreEqual (n + 1, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count+1"); int m = pl.NamedPermissionSets.Count; NamedPermissionSet nps = new NamedPermissionSet ("Mono"); pl.AddNamedPermissionSet (nps); Assert.AreEqual (m + 1, pl.NamedPermissionSets.Count, "NamedPermissionSets.Count+1"); pl.Reset (); Assert.AreEqual (n, pl.FullTrustAssemblies.Count, "FullTrustAssemblies.Count"); Assert.AreEqual (m, pl.NamedPermissionSets.Count, "NamedPermissionSets.Count"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void Resolve_Null () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); pl.Resolve (null); } [Test] public void Resolve_Empty () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); PolicyStatement result = pl.Resolve (new Evidence ()); Assert.IsNotNull (result, "PolicyStatement"); Assert.AreEqual (PolicyStatementAttribute.Nothing, result.Attributes, "Attributes"); Assert.AreEqual (String.Empty, result.AttributeString, "AttributeString"); Assert.IsTrue (result.PermissionSet.IsUnrestricted (), "IsUnrestricted"); Assert.AreEqual (0, result.PermissionSet.Count, "Count"); } private void Resolve_Zone (PolicyLevel level, SecurityZone z, PolicyStatementAttribute attr, bool unrestricted, int count) { string prefix = z.ToString () + "-" + attr.ToString () + "-"; Evidence e = new Evidence (); e.AddHost (new Zone (z)); PolicyStatement result = level.Resolve (e); if (unrestricted) { Assert.AreEqual (attr, result.Attributes, prefix + "Attributes"); switch (attr) { case PolicyStatementAttribute.Nothing: Assert.AreEqual (String.Empty, result.AttributeString, prefix + "AttributeString"); break; case PolicyStatementAttribute.Exclusive: Assert.AreEqual ("Exclusive", result.AttributeString, prefix + "AttributeString"); break; case PolicyStatementAttribute.LevelFinal: Assert.AreEqual ("LevelFinal", result.AttributeString, prefix + "AttributeString"); break; case PolicyStatementAttribute.All: Assert.AreEqual ("Exclusive LevelFinal", result.AttributeString, prefix + "AttributeString"); break; } } else { Assert.AreEqual (PolicyStatementAttribute.Nothing, result.Attributes, prefix + "Attributes"); Assert.AreEqual (String.Empty, result.AttributeString, prefix + "AttributeString"); } Assert.AreEqual (unrestricted, result.PermissionSet.IsUnrestricted (), prefix + "IsUnrestricted"); Assert.AreEqual (count, result.PermissionSet.Count, prefix + "Count"); } private void Resolve_Zone_Unrestricted_Attribute (SecurityZone zone, PolicyStatementAttribute attr) { IMembershipCondition mc = new ZoneMembershipCondition (zone); PolicyStatement ps = new PolicyStatement (new PermissionSet (PermissionState.Unrestricted)); ps.Attributes = attr; PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); pl.RootCodeGroup = new UnionCodeGroup (mc, ps); Resolve_Zone (pl, SecurityZone.Internet, attr, (zone == SecurityZone.Internet), 0); Resolve_Zone (pl, SecurityZone.Intranet, attr, (zone == SecurityZone.Intranet), 0); Resolve_Zone (pl, SecurityZone.MyComputer, attr, (zone == SecurityZone.MyComputer), 0); Resolve_Zone (pl, SecurityZone.NoZone, attr, (zone == SecurityZone.NoZone), 0); Resolve_Zone (pl, SecurityZone.Trusted, attr, (zone == SecurityZone.Trusted), 0); Resolve_Zone (pl, SecurityZone.Untrusted, attr, (zone == SecurityZone.Untrusted), 0); } [Test] public void Resolve_MyComputerUnrestricted () { SecurityZone z = SecurityZone.MyComputer; Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.Nothing); Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.Exclusive); Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.LevelFinal); Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.All); } [Test] public void Resolve_InternetUnrestricted () { SecurityZone z = SecurityZone.Internet; Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.Nothing); Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.Exclusive); Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.LevelFinal); Resolve_Zone_Unrestricted_Attribute (z, PolicyStatementAttribute.All); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void ResolveMatchingCodeGroups_Null () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); pl.ResolveMatchingCodeGroups (null); } [Test] public void ResolveMatchingCodeGroups_Empty () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); CodeGroup result = pl.ResolveMatchingCodeGroups (new Evidence ()); Assert.IsNotNull (result, "CodeGroup"); Assert.AreEqual (String.Empty, result.AttributeString, "AttributeString"); Assert.AreEqual (0, result.Children.Count, "Count"); Assert.AreEqual ("Union", result.MergeLogic, "MergeLogic"); Assert.IsTrue (result.PolicyStatement.PermissionSet.IsUnrestricted (), "IsUnrestricted"); } [Test] [ExpectedException (typeof (ArgumentNullException))] public void RootCodeGroup_Null () { PolicyLevel pl = PolicyLevel.CreateAppDomainLevel (); pl.RootCodeGroup = null; } [Test] public void StoreLocation () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); // loaded from a string - no store Assert.IsNull (pl.StoreLocation, "StoreLocation(string)"); string filename = Path.GetFullPath (Environment.UserName + "-unittest.config"); using (StreamWriter sw = new StreamWriter (filename, false)) { sw.Write (minimal); } pl = SecurityManager.LoadPolicyLevelFromFile (filename, PolicyLevelType.Machine); Assert.AreEqual (filename, pl.StoreLocation, "StoreLocation(file)"); File.Delete (filename); } [Test] public void ToXml () { PolicyLevel pl = Load (minimal, PolicyLevelType.Machine); PolicyLevel pl2 = PolicyLevel.CreateAppDomainLevel (); SecurityElement se = pl.ToXml (); pl2.FromXml (se); Assert.AreEqual (pl.FullTrustAssemblies.Count, pl2.FullTrustAssemblies.Count, "ToXml-FullTrustAssemblies"); Assert.AreEqual (pl.NamedPermissionSets.Count, pl2.NamedPermissionSets.Count, "ToXml-NamedPermissionSets"); Assert.IsTrue (pl.RootCodeGroup.Equals (pl2.RootCodeGroup, true), "ToXml-RootCodeGroup"); Assert.AreEqual (pl.StoreLocation, pl2.StoreLocation, "ToXml-StoreLocation"); } } }