// // SiteIdentityPermissionAttributeTest.cs - // NUnit Test Cases for SiteIdentityPermissionAttribute // // Author: // Sebastien Pouliot // // (C) 2003 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.Security; using System.Security.Permissions; namespace MonoTests.System.Security.Permissions { [TestFixture] public class SiteIdentityPermissionAttributeTest { [Test] public void Default () { SiteIdentityPermissionAttribute a = new SiteIdentityPermissionAttribute (SecurityAction.Assert); Assert.IsNull (a.Site, "Site"); Assert.AreEqual (a.ToString (), a.TypeId.ToString (), "TypeId"); Assert.IsFalse (a.Unrestricted, "Unrestricted"); } [Test] #if !NET_2_0 [ExpectedException (typeof (NullReferenceException))] #else [Category ("NotWorking")] #endif public void DefaultPermission () { SiteIdentityPermissionAttribute a = new SiteIdentityPermissionAttribute (SecurityAction.Assert); Assert.IsNull (a.Site, "Site"); // SiteIdentityPermission would throw a ArgumentException for a null site ... SiteIdentityPermission perm = (SiteIdentityPermission) a.CreatePermission (); // ... but this works ... Assert.IsNotNull (perm, "CreatePermission(null site)"); // ... but this doesn't! (FIXED IN 2.0 NOV CTP) string site = perm.Site; } [Test] public void Action () { SiteIdentityPermissionAttribute a = new SiteIdentityPermissionAttribute (SecurityAction.Assert); Assert.AreEqual (SecurityAction.Assert, a.Action, "Action=Assert"); a.Action = SecurityAction.Demand; Assert.AreEqual (SecurityAction.Demand, a.Action, "Action=Demand"); a.Action = SecurityAction.Deny; Assert.AreEqual (SecurityAction.Deny, a.Action, "Action=Deny"); a.Action = SecurityAction.InheritanceDemand; Assert.AreEqual (SecurityAction.InheritanceDemand, a.Action, "Action=InheritanceDemand"); a.Action = SecurityAction.LinkDemand; Assert.AreEqual (SecurityAction.LinkDemand, a.Action, "Action=LinkDemand"); a.Action = SecurityAction.PermitOnly; Assert.AreEqual (SecurityAction.PermitOnly, a.Action, "Action=PermitOnly"); a.Action = SecurityAction.RequestMinimum; Assert.AreEqual (SecurityAction.RequestMinimum, a.Action, "Action=RequestMinimum"); a.Action = SecurityAction.RequestOptional; Assert.AreEqual (SecurityAction.RequestOptional, a.Action, "Action=RequestOptional"); a.Action = SecurityAction.RequestRefuse; Assert.AreEqual (SecurityAction.RequestRefuse, a.Action, "Action=RequestRefuse"); } [Test] public void Action_Invalid () { UrlIdentityPermissionAttribute a = new UrlIdentityPermissionAttribute ((SecurityAction)Int32.MinValue); // no validation in attribute } [Test] public void Site () { SiteIdentityPermissionAttribute a = new SiteIdentityPermissionAttribute (SecurityAction.Assert); a.Site = "mono"; Assert.AreEqual ("mono", a.Site, "Site-1"); a.Site = null; Assert.IsNull (a.Site, "Site-2"); a.Site = "mono again"; Assert.AreEqual ("mono again", a.Site, "Site-3"); } [Test] #if !NET_2_0 [ExpectedException (typeof (ArgumentException))] #else [Category ("NotWorking")] #endif public void Unrestricted () { SiteIdentityPermissionAttribute a = new SiteIdentityPermissionAttribute (SecurityAction.Assert); a.Unrestricted = true; IPermission perm = a.CreatePermission (); } [Test] public void Attributes () { Type t = typeof (SiteIdentityPermissionAttribute); Assert.IsTrue (t.IsSerializable, "IsSerializable"); object[] attrs = t.GetCustomAttributes (typeof (AttributeUsageAttribute), false); Assert.AreEqual (1, attrs.Length, "AttributeUsage"); AttributeUsageAttribute aua = (AttributeUsageAttribute)attrs [0]; Assert.IsTrue (aua.AllowMultiple, "AllowMultiple"); Assert.IsFalse (aua.Inherited, "Inherited"); AttributeTargets at = (AttributeTargets.Assembly | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method); Assert.AreEqual (at, aua.ValidOn, "ValidOn"); } } }