2 // EventLogPermissionAttributeTest.cs -
\r
3 // NUnit Test Cases for EventLogPermissionAttribute
\r
6 // Sebastien Pouliot <sebastien@ximian.com>
\r
8 // Copyright (C) 2004-2005 Novell, Inc (http://www.novell.com)
\r
10 // Permission is hereby granted, free of charge, to any person obtaining
\r
11 // a copy of this software and associated documentation files (the
\r
12 // "Software"), to deal in the Software without restriction, including
\r
13 // without limitation the rights to use, copy, modify, merge, publish,
\r
14 // distribute, sublicense, and/or sell copies of the Software, and to
\r
15 // permit persons to whom the Software is furnished to do so, subject to
\r
16 // the following conditions:
\r
18 // The above copyright notice and this permission notice shall be
\r
19 // included in all copies or substantial portions of the Software.
\r
21 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
\r
22 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
\r
23 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
\r
24 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
\r
25 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
\r
26 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
\r
27 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
\r
30 using NUnit.Framework;
\r
32 using System.Diagnostics;
\r
33 using System.Security;
\r
34 using System.Security.Permissions;
\r
35 using System.Text.RegularExpressions;
\r
37 namespace MonoTests.System.Diagnostics {
\r
40 public class EventLogPermissionAttributeTest {
\r
43 public void Default ()
\r
45 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
46 Assert.AreEqual (a.ToString (), a.TypeId.ToString (), "TypeId");
\r
47 Assert.IsFalse (a.Unrestricted, "Unrestricted");
\r
48 Assert.AreEqual (".", a.MachineName, "MachineName");
\r
50 Assert.AreEqual (EventLogPermissionAccess.Write, a.PermissionAccess, "PermissionAccess");
\r
52 Assert.AreEqual (EventLogPermissionAccess.Browse, a.PermissionAccess, "PermissionAccess");
\r
54 EventLogPermission sp = (EventLogPermission)a.CreatePermission ();
\r
55 Assert.IsFalse (sp.IsUnrestricted (), "IsUnrestricted");
\r
59 public void Action ()
\r
61 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
62 Assert.AreEqual (SecurityAction.Assert, a.Action, "Action=Assert");
\r
63 a.Action = SecurityAction.Demand;
\r
64 Assert.AreEqual (SecurityAction.Demand, a.Action, "Action=Demand");
\r
65 a.Action = SecurityAction.Deny;
\r
66 Assert.AreEqual (SecurityAction.Deny, a.Action, "Action=Deny");
\r
67 a.Action = SecurityAction.InheritanceDemand;
\r
68 Assert.AreEqual (SecurityAction.InheritanceDemand, a.Action, "Action=InheritanceDemand");
\r
69 a.Action = SecurityAction.LinkDemand;
\r
70 Assert.AreEqual (SecurityAction.LinkDemand, a.Action, "Action=LinkDemand");
\r
71 a.Action = SecurityAction.PermitOnly;
\r
72 Assert.AreEqual (SecurityAction.PermitOnly, a.Action, "Action=PermitOnly");
\r
73 a.Action = SecurityAction.RequestMinimum;
\r
74 Assert.AreEqual (SecurityAction.RequestMinimum, a.Action, "Action=RequestMinimum");
\r
75 a.Action = SecurityAction.RequestOptional;
\r
76 Assert.AreEqual (SecurityAction.RequestOptional, a.Action, "Action=RequestOptional");
\r
77 a.Action = SecurityAction.RequestRefuse;
\r
78 Assert.AreEqual (SecurityAction.RequestRefuse, a.Action, "Action=RequestRefuse");
\r
80 a.Action = SecurityAction.DemandChoice;
\r
81 Assert.AreEqual (SecurityAction.DemandChoice, a.Action, "Action=DemandChoice");
\r
82 a.Action = SecurityAction.InheritanceDemandChoice;
\r
83 Assert.AreEqual (SecurityAction.InheritanceDemandChoice, a.Action, "Action=InheritanceDemandChoice");
\r
84 a.Action = SecurityAction.LinkDemandChoice;
\r
85 Assert.AreEqual (SecurityAction.LinkDemandChoice, a.Action, "Action=LinkDemandChoice");
\r
90 public void Action_Invalid ()
\r
92 EventLogPermissionAttribute a = new EventLogPermissionAttribute ((SecurityAction)Int32.MinValue);
\r
93 // no validation in attribute
\r
97 public void Unrestricted ()
\r
99 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
100 a.Unrestricted = true;
\r
101 EventLogPermission wp = (EventLogPermission)a.CreatePermission ();
\r
102 Assert.IsTrue (wp.IsUnrestricted (), "IsUnrestricted");
\r
104 a.Unrestricted = false;
\r
105 wp = (EventLogPermission)a.CreatePermission ();
\r
106 Assert.IsFalse (wp.IsUnrestricted (), "!IsUnrestricted");
\r
110 [ExpectedException (typeof (ArgumentException))]
\r
111 public void MachineName_Null ()
\r
113 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
114 a.MachineName = null;
\r
118 [ExpectedException (typeof (ArgumentException))]
\r
119 public void MachineName_Empty ()
\r
121 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
122 a.MachineName = String.Empty;
\r
126 public void MachineName ()
\r
128 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
129 for (int i=0; i < 256; i++) {
\r
131 a.MachineName = Convert.ToChar (i).ToString ();
\r
132 Assert.AreEqual (i, (int)a.MachineName [0], i.ToString ());
\r
147 // known invalid chars
\r
150 Assert.Fail (i.ToString());
\r
155 // all first 256 characters seems to be valid
\r
156 // is there other rules ?
\r
160 public void PermissionAccess ()
\r
162 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
163 a.PermissionAccess = EventLogPermissionAccess.Audit;
\r
164 Assert.AreEqual (EventLogPermissionAccess.Audit, a.PermissionAccess, "Audit");
\r
165 a.PermissionAccess = EventLogPermissionAccess.Browse;
\r
166 Assert.AreEqual (EventLogPermissionAccess.Browse, a.PermissionAccess, "Browse");
\r
167 a.PermissionAccess = EventLogPermissionAccess.Instrument;
\r
168 Assert.AreEqual (EventLogPermissionAccess.Instrument, a.PermissionAccess, "Instrument");
\r
169 a.PermissionAccess = EventLogPermissionAccess.None;
\r
170 Assert.AreEqual (EventLogPermissionAccess.None, a.PermissionAccess, "None");
\r
172 a.PermissionAccess = EventLogPermissionAccess.Administer;
\r
173 Assert.AreEqual (EventLogPermissionAccess.Administer, a.PermissionAccess, "Administer");
\r
174 a.PermissionAccess = EventLogPermissionAccess.Write;
\r
175 Assert.AreEqual (EventLogPermissionAccess.Write, a.PermissionAccess, "Write");
\r
180 public void PermissionAccess_Invalid ()
\r
182 EventLogPermissionAttribute a = new EventLogPermissionAttribute (SecurityAction.Assert);
\r
183 a.PermissionAccess = (EventLogPermissionAccess) Int32.MinValue;
\r
184 Assert.AreEqual ((EventLogPermissionAccess)Int32.MinValue, a.PermissionAccess, "None");
\r
185 // no exception thrown
\r
189 public void Attributes ()
\r
191 Type t = typeof (EventLogPermissionAttribute);
\r
192 Assert.IsTrue (t.IsSerializable, "IsSerializable");
\r
194 object [] attrs = t.GetCustomAttributes (typeof (AttributeUsageAttribute), false);
\r
195 Assert.AreEqual (1, attrs.Length, "AttributeUsage");
\r
196 AttributeUsageAttribute aua = (AttributeUsageAttribute)attrs [0];
\r
197 Assert.IsTrue (aua.AllowMultiple, "AllowMultiple");
\r
198 Assert.IsFalse (aua.Inherited, "Inherited");
\r
199 AttributeTargets at = (AttributeTargets.Assembly | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Event);
\r
200 Assert.AreEqual (at, aua.ValidOn, "ValidOn");
\r