// // AttributeUsageAttributeTest.cs // // Authors: // Alexander Köplinger (alkpli@microsoft.com) // // (c) 2017 Microsoft // // 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 System; using System.Threading; using System.Reflection; using System.Reflection.Emit; using NUnit.Framework; namespace MonoTests.System { /// /// Summary description for AttributeUsageAttributeTest. /// [TestFixture] public class AttributeUsageAttributeTest { #if !MOBILE private AssemblyBuilder dynAssembly; AssemblyName dynAsmName = new AssemblyName (); AttributeUsageAttribute attr; public AttributeUsageAttributeTest () { //create a dynamic assembly with the required attribute //and check for the validity dynAsmName.Name = "TestAssembly"; dynAssembly = Thread.GetDomain ().DefineDynamicAssembly ( dynAsmName,AssemblyBuilderAccess.Run ); // Set the required Attribute of the assembly. Type attribute = typeof (AttributeUsageAttribute); ConstructorInfo ctrInfo = attribute.GetConstructor ( new Type [] { typeof (AttributeTargets) } ); CustomAttributeBuilder attrBuilder = new CustomAttributeBuilder (ctrInfo, new object [1] { AttributeTargets.Assembly }); dynAssembly.SetCustomAttribute (attrBuilder); object [] attributes = dynAssembly.GetCustomAttributes (true); attr = attributes [0] as AttributeUsageAttribute; } [Test] public void AttributeUsageTest () { Assert.AreEqual ( attr.ValidOn, AttributeTargets.Assembly, "#1"); Assert.AreEqual ( attr.AllowMultiple, false, "#2"); Assert.AreEqual ( attr.Inherited, true, "#3"); } [Test] public void TypeIdTest () { Assert.AreEqual ( attr.TypeId, typeof (AttributeUsageAttribute), "#1" ); } [Test] public void MatchTestForTrue () { Assert.AreEqual ( attr.Match (attr), true, "#1"); } [Test] public void MatchTestForFalse () { Assert.AreEqual ( attr.Match (new AttributeUsageAttribute (AttributeTargets.Method)), false, "#1"); } #endif [Test] public void CtorTest () { var a = new AttributeUsageAttribute (AttributeTargets.Method); Assert.AreEqual (AttributeTargets.Method, a.ValidOn); Assert.False (a.AllowMultiple); Assert.True (a.Inherited); } [Test] public void PropertyTest () { var a = new AttributeUsageAttribute (AttributeTargets.Method | AttributeTargets.Class); a.AllowMultiple = true; a.Inherited = false; Assert.AreEqual (AttributeTargets.Method | AttributeTargets.Class, a.ValidOn); Assert.True (a.AllowMultiple); Assert.False (a.Inherited); } } }