2 // SecurityExceptionCas.cs - CAS unit tests for
3 // System.Security.SecurityException
6 // Sebastien Pouliot <sebastien@ximian.com>
8 // Copyright (C) 2005 Novell, Inc (http://www.novell.com)
10 // Permission is hereby granted, free of charge, to any person obtaining
11 // a copy of this software and associated documentation files (the
12 // "Software"), to deal in the Software without restriction, including
13 // without limitation the rights to use, copy, modify, merge, publish,
14 // distribute, sublicense, and/or sell copies of the Software, and to
15 // permit persons to whom the Software is furnished to do so, subject to
16 // the following conditions:
18 // The above copyright notice and this permission notice shall be
19 // included in all copies or substantial portions of the Software.
21 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
25 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
27 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
30 using NUnit.Framework;
33 using System.Reflection;
34 using System.Runtime.Serialization;
35 using System.Security;
36 using System.Security.Permissions;
38 namespace MonoCasTests.System.Security {
42 public class SecurityExceptionCas {
44 private SecurityException se;
49 if (!SecurityManager.SecurityEnabled)
50 Assert.Ignore ("SecurityManager.SecurityEnabled is OFF");
52 se = new SecurityException ();
57 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
58 public void GetAction ()
60 SecurityAction sa = se.Action;
64 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
65 public void SetAction ()
67 se.Action = SecurityAction.RequestRefuse;
71 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
72 public void GetDemanded_Pass ()
74 object o = se.Demanded;
78 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
79 [ExpectedException (typeof (SecurityException))]
80 public void GetDemanded_Fail_ControlEvidence ()
82 object o = se.Demanded;
86 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
87 [ExpectedException (typeof (SecurityException))]
88 public void GetDemanded_Fail_ControlPolicy ()
90 object o = se.Demanded;
94 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
95 public void SetDemanded ()
97 se.Demanded = new PermissionSet (PermissionState.None);
101 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
102 public void GetDenySetInstance_Pass ()
104 object o = se.DenySetInstance;
108 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
109 [ExpectedException (typeof (SecurityException))]
110 public void GetDenySetInstance_Fail_ControlEvidence ()
112 object o = se.DenySetInstance;
116 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
117 [ExpectedException (typeof (SecurityException))]
118 public void GetDenySetInstance_Fail_ControlPolicy ()
120 object o = se.DenySetInstance;
124 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
125 public void SetDenySetInstance ()
127 se.DenySetInstance = new PermissionSet (PermissionState.None);
131 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
132 public void GetFailedAssemblyInfo_Pass ()
134 AssemblyName an = se.FailedAssemblyInfo;
138 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
139 [ExpectedException (typeof (SecurityException))]
140 public void GetFailedAssemblyInfo_Fail_ControlEvidence ()
142 AssemblyName an = se.FailedAssemblyInfo;
146 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
147 [ExpectedException (typeof (SecurityException))]
148 public void GetFailedAssemblyInfo_Fail_ControlPolicy ()
150 AssemblyName an = se.FailedAssemblyInfo;
154 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
155 public void SetFailedAssemblyInfo ()
157 se.FailedAssemblyInfo = null;
161 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
162 public void GetFirstPermissionThatFailed_Pass ()
164 IPermission p = se.FirstPermissionThatFailed;
168 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
169 [ExpectedException (typeof (SecurityException))]
170 public void GetFirstPermissionThatFailed_Fail_ControlEvidence ()
172 IPermission p = se.FirstPermissionThatFailed;
176 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
177 [ExpectedException (typeof (SecurityException))]
178 public void GetFirstPermissionThatFailed_Fail_ControlPolicy ()
180 IPermission p = se.FirstPermissionThatFailed;
184 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
185 public void SetFirstPermissionThatFailed ()
187 se.FirstPermissionThatFailed = null;
190 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
191 public void GetGrantedSet_Pass ()
193 string s = se.GrantedSet;
197 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
198 [ExpectedException (typeof (SecurityException))]
199 public void GetGrantedSet_Fail_ControlEvidence ()
201 string s = se.GrantedSet;
205 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
206 [ExpectedException (typeof (SecurityException))]
207 public void GetGrantedSet_Fail_ControlPolicy ()
209 string s = se.GrantedSet;
212 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
213 public void SetGrantedSet ()
215 se.GrantedSet = String.Empty;
219 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
220 public void GetMethod_Pass ()
222 MethodInfo mi = se.Method;
226 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
227 [ExpectedException (typeof (SecurityException))]
228 public void GetMethod_Fail_ControlEvidence ()
230 MethodInfo mi = se.Method;
234 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
235 [ExpectedException (typeof (SecurityException))]
236 public void GetMethod_Fail_ControlPolicy ()
238 MethodInfo mi = se.Method;
242 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
243 public void SetMethod ()
248 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
249 public void GetPermissionState_Pass ()
251 string s = se.PermissionState;
255 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
256 [ExpectedException (typeof (SecurityException))]
257 public void GetPermissionState_Fail_ControlEvidence ()
259 string s = se.PermissionState;
263 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
264 [ExpectedException (typeof (SecurityException))]
265 public void GetPermissionState_Fail_ControlPolicy ()
267 string s = se.PermissionState;
270 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
271 public void SetPermissionState ()
273 se.PermissionState = String.Empty;
277 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
278 public void GetPermitOnlySetInstance_Pass ()
280 object s = se.PermitOnlySetInstance;
284 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
285 [ExpectedException (typeof (SecurityException))]
286 public void GetPermitOnlySetInstance_Fail_ControlEvidence ()
288 object s = se.PermitOnlySetInstance;
292 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
293 [ExpectedException (typeof (SecurityException))]
294 public void GetPermitOnlySetInstance_Fail_ControlPolicy ()
296 object s = se.PermitOnlySetInstance;
300 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
301 public void SetPermitOnlySetInstance ()
303 se.PermitOnlySetInstance = null;
306 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
307 public void GetRefusedSet_Pass ()
309 string s = se.RefusedSet;
313 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
314 [ExpectedException (typeof (SecurityException))]
315 public void GetRefusedSet_Fail_ControlEvidence ()
317 string s = se.RefusedSet;
321 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
322 [ExpectedException (typeof (SecurityException))]
323 public void GetRefusedSet_Fail_ControlPolicy ()
325 string s = se.RefusedSet;
328 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
329 public void SetRefusedSet ()
331 se.RefusedSet = String.Empty;
335 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
336 public void GetUrl_Pass ()
342 [SecurityPermission (SecurityAction.Deny, ControlEvidence = true)]
343 [ExpectedException (typeof (SecurityException))]
344 public void GetUrl_Fail_ControlEvidence ()
350 [SecurityPermission (SecurityAction.Deny, ControlPolicy = true)]
351 [ExpectedException (typeof (SecurityException))]
352 public void GetUrl_Fail_ControlPolicy ()
358 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
359 public void SetUrl ()
361 se.Url = "http://www.mono-project.com/";
365 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
366 public void GetZone ()
368 SecurityZone sz = se.Zone;
372 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
373 public void SetZone ()
375 se.Zone = SecurityZone.Untrusted;
378 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
379 public void ToString_Empty ()
381 string s = se.ToString ();
385 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
386 public void ToString_WithSuppliedSensitiveInformation1 ()
388 // here we supply something *sensitive* as the state
389 string sensitive = "*SENSITIVE*";
390 SecurityException se = new SecurityException ("message", typeof (Object), sensitive);
391 // and we don't expect it to be shown in the output
392 Assert.IsTrue (se.ToString ().IndexOf (sensitive) == -1, sensitive);
396 [SecurityPermission (SecurityAction.PermitOnly, ControlEvidence = true, ControlPolicy = true)]
397 public void ToString_WithSuppliedSensitiveInformation2 ()
399 // here we supply something *sensitive* as the state
400 string sensitive = "*SENSITIVE*";
401 SecurityException se = new SecurityException ("message", typeof (Object), sensitive);
402 // and we EXPECT it to be shown in the output
403 // as we pass the security checks for PermissionState property
404 Assert.IsFalse (se.ToString ().IndexOf (sensitive) == -1, sensitive);
408 public void GetObjectData ()
410 SecurityException se = new SecurityException ("message", typeof (string), "state");
411 SerializationInfo info = new SerializationInfo (typeof (SecurityException), new FormatterConverter ());
412 se.GetObjectData (info, new StreamingContext (StreamingContextStates.All));
413 Assert.AreEqual ("state", info.GetValue ("PermissionState", typeof (string)), "PermissionState");
417 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
418 [ExpectedException (typeof (SerializationException))]
419 public void GetObjectData_Deny_Unrestricted ()
421 SecurityException se = new SecurityException ("message", typeof (string), "state");
422 SerializationInfo info = new SerializationInfo (typeof (SecurityException), new FormatterConverter ());
423 se.GetObjectData (info, new StreamingContext (StreamingContextStates.All));
424 // "PermissionState" hasn't been serialized because it's access was restricted
425 info.GetValue ("PermissionState", typeof (string));