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.example.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));