MutexCas.cs 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. //
  2. // MutexCas.cs - CAS unit tests for System.Threading.Mutex
  3. //
  4. // Author:
  5. // Sebastien Pouliot <[email protected]>
  6. //
  7. // Copyright (C) 2005 Novell, Inc (http://www.novell.com)
  8. //
  9. // Permission is hereby granted, free of charge, to any person obtaining
  10. // a copy of this software and associated documentation files (the
  11. // "Software"), to deal in the Software without restriction, including
  12. // without limitation the rights to use, copy, modify, merge, publish,
  13. // distribute, sublicense, and/or sell copies of the Software, and to
  14. // permit persons to whom the Software is furnished to do so, subject to
  15. // the following conditions:
  16. //
  17. // The above copyright notice and this permission notice shall be
  18. // included in all copies or substantial portions of the Software.
  19. //
  20. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  21. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  22. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  23. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  24. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  25. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  26. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  27. //
  28. using NUnit.Framework;
  29. using System;
  30. using System.Reflection;
  31. using System.Security;
  32. using System.Security.Permissions;
  33. using System.Threading;
  34. namespace MonoCasTests.System.Threading {
  35. [TestFixture]
  36. [Category ("CAS")]
  37. public class MutexCas {
  38. [SetUp]
  39. public void SetUp ()
  40. {
  41. if (!SecurityManager.SecurityEnabled)
  42. Assert.Ignore ("SecurityManager.SecurityEnabled is OFF");
  43. }
  44. // Partial Trust Tests - i.e. call "normal" unit with reduced privileges
  45. [Test]
  46. [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
  47. public void PartialTrust_DenyUnrestricted_Success ()
  48. {
  49. MonoTests.System.Threading.MutexTest mt = new MonoTests.System.Threading.MutexTest ();
  50. // call the few working unit tests
  51. mt.TestCtor1 ();
  52. mt.TestHandle ();
  53. }
  54. // we use reflection to call Mutex as it's named constructors are protected by
  55. // a LinkDemand (which will be converted into full demand, i.e. a stack walk)
  56. // when reflection is used (i.e. it gets testable).
  57. [Test]
  58. [SecurityPermission (SecurityAction.Deny, UnmanagedCode = true)]
  59. [ExpectedException (typeof (SecurityException))]
  60. public void Ctor_BoolString ()
  61. {
  62. Type[] parameters = new Type [2] { typeof (bool), typeof (string) };
  63. ConstructorInfo ci = typeof (Mutex).GetConstructor (parameters);
  64. Assert.IsNotNull (ci, "ctor(bool,string)");
  65. ci.Invoke (new object [2] { false, String.Empty });
  66. }
  67. [Test]
  68. [SecurityPermission (SecurityAction.Deny, UnmanagedCode = true)]
  69. [ExpectedException (typeof (SecurityException))]
  70. public void Ctor_BoolStringOutBool ()
  71. {
  72. ConstructorInfo ci = null;
  73. // I don't know an easier way to deal with "out bool"
  74. ConstructorInfo[] cis = typeof (Mutex).GetConstructors ();
  75. for (int i=0; i < cis.Length; i++) {
  76. ParameterInfo[] pis = cis [i].GetParameters ();
  77. if (pis.Length == 3) {
  78. ci = cis [i];
  79. break;
  80. }
  81. }
  82. Assert.IsNotNull (ci, "ctor(bool,string,out bool)");
  83. // not sure the invoke would work - but it's enough to trigger the security check
  84. ci.Invoke (new object [3] { false, String.Empty, false });
  85. }
  86. }
  87. }