* roottypes.cs: Rename from tree.cs.
[mono.git] / mcs / class / System / Test / System.Security.Cryptography.X509Certificates / PublicKeyCas.cs
1 //
2 // PublicKeyCas.cs - CAS unit tests for 
3 //      System.Security.Cryptography.X509Certificates.PublicKey
4 //
5 // Author:
6 //      Sebastien Pouliot  <sebastien@ximian.com>
7 //
8 // Copyright (C) 2005 Novell, Inc (http://www.novell.com)
9 //
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:
17 // 
18 // The above copyright notice and this permission notice shall be
19 // included in all copies or substantial portions of the Software.
20 // 
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.
28 //
29
30 #if NET_2_0
31
32 using NUnit.Framework;
33
34 using System;
35 using System.Reflection;
36 using System.Security;
37 using System.Security.Permissions;
38 using System.Security.Cryptography;
39 using System.Security.Cryptography.X509Certificates;
40
41 using MonoTests.System.Security.Cryptography.X509Certificates;
42
43 namespace MonoCasTests.System.Security.Cryptography.X509Certificates {
44
45         [TestFixture]
46         [Category ("CAS")]
47         public class PublicKeyCas {
48
49                 [SetUp]
50                 public void SetUp ()
51                 {
52                         if (!SecurityManager.SecurityEnabled)
53                                 Assert.Ignore ("SecurityManager.SecurityEnabled is OFF");
54                 }
55
56                 [Test]
57                 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
58                 public void ReuseUnitTests_Deny_Unrestricted ()
59                 {
60                         PublicKeyTest unit = new PublicKeyTest ();
61                         unit.FixtureSetUp ();
62                         unit.Constructor_RsaEmpty ();
63                         unit.Constructor_UnknownEmpty ();
64                         unit.Constructor_Rsa_FromCertificate ();
65                         unit.Constructor_Rsa_FromScratch ();
66                         unit.Constructor_Rsa_EmptyParameters ();
67                         unit.Constructor_Rsa_WeirdParameters ();
68                         unit.Constructor_Rsa_UnknownOid ();
69                         unit.Constructor_Dsa_FromCertificate ();
70                         unit.Constructor_Dsa_FromScratch ();
71                         unit.Constructor_Dsa_EmptyParameters ();
72                         unit.Constructor_Dsa_WeirdParameters ();
73                         unit.Constructor_Dsa_UnknownOid ();
74                 }
75
76                 [Test]
77                 [PermissionSet (SecurityAction.Deny, Unrestricted = true)]
78                 public void LinkDemand_Deny_Unrestricted ()
79                 {
80                         Type[] types = new Type[3] { typeof (Oid), typeof (AsnEncodedData), typeof (AsnEncodedData) };
81                         ConstructorInfo ci = typeof (PublicKey).GetConstructor (types);
82                         Assert.IsNotNull (ci, ".ctor(Oid,AsnEncodedData,AsnEncodedData)");
83                         Assert.IsNotNull (ci.Invoke (new object[3] { new Oid ("1.2.3.4"), 
84                                 new AsnEncodedData (new byte[0]), new AsnEncodedData (new byte[0]) }), "invoke");
85                 }
86         }
87 }
88
89 #endif