ReferenceTest.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. //
  2. // ReferenceTest.cs - NUnit Test Cases for Reference
  3. //
  4. // Author:
  5. // Sebastien Pouliot <[email protected]>
  6. //
  7. // (C) 2002, 2003 Motus Technologies Inc. (http://www.motus.com)
  8. // (C) 2004 Novell (http://www.novell.com)
  9. //
  10. using System;
  11. using System.Security.Cryptography;
  12. using System.Security.Cryptography.Xml;
  13. using System.Xml;
  14. using NUnit.Framework;
  15. namespace MonoTests.System.Security.Cryptography.Xml {
  16. [TestFixture]
  17. public class ReferenceTest : Assertion {
  18. protected Reference reference;
  19. [SetUp]
  20. public void SetUp ()
  21. {
  22. reference = new Reference ();
  23. }
  24. [Test]
  25. public void Properties ()
  26. {
  27. AssertNull ("Uri (null)", reference.Uri);
  28. AssertNotNull ("TransformChain", reference.TransformChain);
  29. AssertEquals ("ToString()", "System.Security.Cryptography.Xml.Reference", reference.ToString ());
  30. // test uri constructor
  31. string uri = "uri";
  32. reference = new Reference (uri);
  33. AssertEquals ("DigestMethod", "http://www.w3.org/2000/09/xmldsig#sha1", reference.DigestMethod);
  34. AssertNull ("DigestValue", reference.DigestValue);
  35. AssertNull ("Id", reference.Id);
  36. AssertNull ("Type", reference.Type);
  37. AssertEquals ("Uri", uri, reference.Uri);
  38. }
  39. [Test]
  40. public void LoadNoTransform ()
  41. {
  42. string test = "<Reference URI=\"#MyObjectId\" xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>/Vvq6sXEVbtZC8GwNtLQnGOy/VI=</DigestValue></Reference>";
  43. XmlDocument doc = new XmlDocument ();
  44. doc.LoadXml (test);
  45. reference.LoadXml (doc.DocumentElement);
  46. AssertEquals ("Load-Xml", test, (reference.GetXml().OuterXml));
  47. AssertEquals ("Load-URI", "#MyObjectId", reference.Uri);
  48. byte[] hash = { 0xFD, 0x5B, 0xEA, 0xEA, 0xC5, 0xC4, 0x55, 0xBB, 0x59, 0x0B, 0xC1, 0xB0, 0x36, 0xD2, 0xD0, 0x9C, 0x63, 0xB2, 0xFD, 0x52 };
  49. AssertCrypto.AssertEquals("Load-Digest", hash, reference.DigestValue);
  50. AssertEquals ("Load-#Transform", 0, reference.TransformChain.Count);
  51. }
  52. [Test]
  53. public void LoadBase64Transform ()
  54. {
  55. string test = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#base64\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  56. XmlDocument doc = new XmlDocument ();
  57. doc.LoadXml (test);
  58. reference.LoadXml (doc.DocumentElement);
  59. AssertEquals ("Load-Base64", test, (reference.GetXml().OuterXml));
  60. AssertEquals ("Load-#Transform", 1, reference.TransformChain.Count);
  61. }
  62. [Test]
  63. public void LoadC14NTransform ()
  64. {
  65. string test = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  66. XmlDocument doc = new XmlDocument ();
  67. doc.LoadXml (test);
  68. reference.LoadXml (doc.DocumentElement);
  69. AssertEquals ("Load-C14N", test, (reference.GetXml().OuterXml));
  70. AssertEquals ("Load-#Transform", 1, reference.TransformChain.Count);
  71. }
  72. [Test]
  73. public void LoadC14NWithCommentsTransforms ()
  74. {
  75. string test = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  76. XmlDocument doc = new XmlDocument ();
  77. doc.LoadXml (test);
  78. reference.LoadXml (doc.DocumentElement);
  79. AssertEquals ("Load-C14NWithComments", test, (reference.GetXml().OuterXml));
  80. AssertEquals ("Load-#Transform", 1, reference.TransformChain.Count);
  81. }
  82. [Test]
  83. public void LoadEnvelopedSignatureTransforms ()
  84. {
  85. string test = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  86. XmlDocument doc = new XmlDocument ();
  87. doc.LoadXml (test);
  88. reference.LoadXml (doc.DocumentElement);
  89. AssertEquals ("Load-Enveloped", test, (reference.GetXml().OuterXml));
  90. AssertEquals ("Load-#Transform", 1, reference.TransformChain.Count);
  91. }
  92. [Test]
  93. public void LoadXPathTransforms ()
  94. {
  95. // test1 (MS) is an XML equivalent to test2 (Mono)
  96. string test1 = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xpath-19991116\"><XPath></XPath></Transform></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  97. string test2 = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xpath-19991116\"><XPath /></Transform></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  98. XmlDocument doc = new XmlDocument ();
  99. doc.LoadXml (test1);
  100. reference.LoadXml (doc.DocumentElement);
  101. string result = (reference.GetXml().OuterXml);
  102. Assert (result, ((test1 == result) || (test2 == result)));
  103. AssertEquals ("Load-#Transform", 1, reference.TransformChain.Count);
  104. }
  105. [Test]
  106. public void LoadXsltTransforms ()
  107. {
  108. string test = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms>";
  109. test += "<Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xslt-19991116\">";
  110. test += "<xsl:stylesheet xmlns:xsl=\"http://www.w3.org/1999/XSL/Transform\" xmlns=\"http://www.w3.org/TR/xhtml1/strict\" exclude-result-prefixes=\"foo\" version=\"1.0\">";
  111. test += "<xsl:output encoding=\"UTF-8\" indent=\"no\" method=\"xml\" />";
  112. test += "<xsl:template match=\"/\"><html><head><title>Notaries</title>";
  113. test += "</head><body><table><xsl:for-each select=\"Notaries/Notary\">";
  114. test += "<tr><th><xsl:value-of select=\"@name\" /></th></tr></xsl:for-each>";
  115. test += "</table></body></html></xsl:template></xsl:stylesheet></Transform>";
  116. test += "</Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  117. XmlDocument doc = new XmlDocument ();
  118. doc.LoadXml (test);
  119. reference.LoadXml (doc.DocumentElement);
  120. string result = reference.GetXml().OuterXml;
  121. AssertEquals (result, test, result);
  122. AssertEquals ("Load-#Transform", 1, reference.TransformChain.Count);
  123. }
  124. [Test]
  125. public void LoadAllTransforms ()
  126. {
  127. string test1 = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#base64\" /><Transform Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><Transform Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\" /><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /><Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xpath-19991116\"><XPath></XPath></Transform>";
  128. test1 += "<Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xslt-19991116\">";
  129. test1 += "<xsl:stylesheet xmlns:xsl=\"http://www.w3.org/1999/XSL/Transform\" xmlns=\"http://www.w3.org/TR/xhtml1/strict\" exclude-result-prefixes=\"foo\" version=\"1.0\">";
  130. test1 += "<xsl:output encoding=\"UTF-8\" indent=\"no\" method=\"xml\" />";
  131. test1 += "<xsl:template match=\"/\"><html><head><title>Notaries</title>";
  132. test1 += "</head><body><table><xsl:for-each select=\"Notaries/Notary\">";
  133. test1 += "<tr><th><xsl:value-of select=\"@name\" /></th></tr></xsl:for-each>";
  134. test1 += "</table></body></html></xsl:template></xsl:stylesheet></Transform>";
  135. test1 += "</Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  136. string test2 = test1.Replace ("<XPath></XPath>", "<XPath />"); // Mono
  137. XmlDocument doc = new XmlDocument ();
  138. doc.LoadXml (test1);
  139. reference.LoadXml (doc.DocumentElement);
  140. string result = reference.GetXml().OuterXml;
  141. Assert (result, ((result == test1) || (result == test2)));
  142. AssertEquals ("Load-#Transform", 6, reference.TransformChain.Count);
  143. }
  144. [Test]
  145. #if NET_2_0
  146. [Category ("NotDotNet")]
  147. // MS throws a NullReferenceException (reported as FDBK25886) but only when executed in NUnit
  148. // http://lab.msdn.microsoft.com/ProductFeedback/viewfeedback.aspx?feedbackid=3596d1e3-362b-40bd-bca9-2e8be75261ff
  149. #endif
  150. public void AddAllTransforms ()
  151. {
  152. // adding an empty hash value
  153. byte[] hash = new byte [20];
  154. reference.DigestValue = hash;
  155. XmlElement xel = reference.GetXml ();
  156. // this is the minimal Reference (DigestValue)!
  157. AssertNotNull ("GetXml", xel);
  158. reference.AddTransform (new XmlDsigBase64Transform ());
  159. reference.AddTransform (new XmlDsigC14NTransform ());
  160. reference.AddTransform (new XmlDsigC14NWithCommentsTransform ());
  161. reference.AddTransform (new XmlDsigEnvelopedSignatureTransform ());
  162. reference.AddTransform (new XmlDsigXPathTransform ());
  163. reference.AddTransform (new XmlDsigXsltTransform ());
  164. // MS's results
  165. string test1 = "<Reference xmlns=\"http://www.w3.org/2000/09/xmldsig#\"><Transforms><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#base64\" /><Transform Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" /><Transform Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\" /><Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\" /><Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xpath-19991116\"><XPath></XPath></Transform><Transform Algorithm=\"http://www.w3.org/TR/1999/REC-xslt-19991116\" /></Transforms><DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\" /><DigestValue>AAAAAAAAAAAAAAAAAAAAAAAAAAA=</DigestValue></Reference>";
  166. // Mono's result (xml is equivalent but not identical)
  167. string test2 = test1.Replace ("<XPath></XPath>", "<XPath xmlns=\"http://www.w3.org/2000/09/xmldsig#\" />");
  168. string result = reference.GetXml().OuterXml;
  169. Assert (result, ((result == test1) || (result == test2)));
  170. // however this value cannot be loaded as it's missing some transform (xslt) parameters
  171. // can we add them again ?
  172. reference.AddTransform (new XmlDsigBase64Transform ());
  173. reference.AddTransform (new XmlDsigC14NTransform ());
  174. reference.AddTransform (new XmlDsigC14NWithCommentsTransform ());
  175. reference.AddTransform (new XmlDsigEnvelopedSignatureTransform ());
  176. reference.AddTransform (new XmlDsigXPathTransform ());
  177. reference.AddTransform (new XmlDsigXsltTransform ());
  178. // seems so ;-)
  179. AssertEquals ("# Transforms", 12, reference.TransformChain.Count);
  180. }
  181. [Test]
  182. public void Null ()
  183. {
  184. // null DigestMethod -> "" DigestMethod !!!
  185. reference.DigestMethod = null;
  186. AssertNull ("DigestMethod null", reference.DigestMethod);
  187. }
  188. [Test]
  189. [ExpectedException (typeof (NullReferenceException))]
  190. public void Bad1 ()
  191. {
  192. reference.Uri = "#MyObjectId";
  193. // not enough info
  194. XmlElement bad = reference.GetXml ();
  195. }
  196. [Test]
  197. public void Bad2 ()
  198. {
  199. // bad hash - there's no validation!
  200. reference.DigestMethod = "http://www.w3.org/2000/09/xmldsig#mono";
  201. }
  202. const string xml = @"<player bats=""left"" id=""10012"" throws=""right"">
  203. <!-- Here&apos;s a comment -->
  204. <name>Alfonso Soriano</name>
  205. <position>2B</position>
  206. <team>New York Yankees</team>
  207. <dsig:Signature xmlns=""http://www.w3.org/2000/09/xmldsig#"" xmlns:dsig=""http://www.w3.org/2000/09/xmldsig#"">"
  208. + @"<dsig:SignedInfo><dsig:CanonicalizationMethod Algorithm=""http://www.w3.org/TR/2001/REC-xml-c14n-withcomments-20010315""/><dsig:SignatureMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#rsa-sha1""/>"
  209. + @"<dsig:Reference URI=""""><dsig:Transforms><dsig:Transform Algorithm=""http://www.w3.org/2000/09/xmldsig#enveloped-signature""/></dsig:Transforms><dsig:DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1""/><dsig:DigestValue>nDF2V/bzRd0VE3EwShWtsBzTEDc=</dsig:DigestValue></dsig:Reference></dsig:SignedInfo><dsig:SignatureValue>fbye4Xm//RPUTsLd1dwJPo0gPZYX6gVYCEB/gz2348EARNk/nCCch1fFfpuqAGMKg4ayVC0yWkUyE5V4QB33jaGlh9wuNQSjxs6TIvFwSsT+0ioDgVgFv0gVeasbyNL4rFEHuAWL8QKwDT9L6b2wUvJC90DmpBs9GMR2jTZIWlM=</dsig:SignatureValue><dsig:KeyInfo><dsig:X509Data><dsig:X509Certificate>MIIC0DCCAjmgAwIBAgIDD0JBMA0GCSqGSIb3DQEBBAUAMHwxCzAJBgNVBAYTAlVTMREwDwYDVQQIEwhOZXcgWW9yazERMA8GA1UEBxMITmV3IFlvcmsxGTAXBgNVBAoTEFBoYW9zIFRlY2hub2xvZ3kxFDASBgNVBAsTC0VuZ2luZWVyaW5nMRYwFAYDVQQDEw1UZXN0IENBIChSU0EpMB4XDTAyMDQyOTE5MTY0MFoXDTEyMDQyNjE5MTY0MFowgYAxCzAJBgNVBAYTAlVTMREwDwYDVQQIEwhOZXcgWW9yazERMA8GA1UEBxMITmV3IFlvcmsxGTAXBgNVBAoTEFBoYW9zIFRlY2hub2xvZ3kxFDASBgNVBAsTC0VuZ2luZWVyaW5nMRowGAYDVQQDExFUZXN0IENsaWVudCAoUlNBKTCBnzANBgkqhkiG9w0BAQEFAAOBjQAwgYkCgYEAgIb6nAB9oS/AI5jIj6WymvQhRxiMlE07G4abmMliYi5zWzvaFE2tnU+RZIBgtoXcgDEIU/vsLQut7nzCn9mHxC8JEaV4D4U91j64AyZakShqJw7qjJfqUxxPL0yJv2oFiouPDjGuJ9JPi0NrsZq+yfWfM54s4b9SNkcOIVMybZUCAwEAAaNbMFkwDAYDVR0TAQH/BAIwADAPBgNVHQ8BAf8EBQMDB9gAMBkGA1UdEQQSMBCBDnRlY2hAcGhhb3MuY29tMB0GA1UdDgQWBBQT58rBCxPmVLeZaYGRqVROnQlFbzANBgkqhkiG9w0BAQQFAAOBgQCxbCovFST25t+ryN1RipqozxJQcguKfeCwbfgBNobzcRvoW0kSIf7zi4mtQajDM0NfslFF51/dex5Rn64HmFFshSwSvQQMyf5Cfaqv2XQ60OXq6nAFG6WbHoge6RqfIez2MWDLoSB6plsjKtMmL3mcybBhROtX5GGuLx1NtfhNFQ==</dsig:X509Certificate><dsig:X509IssuerSerial><dsig:X509IssuerName>CN=Test CA (RSA),OU=Engineering,O=Phaos Technology,L=New York,ST=New York,C=US</dsig:X509IssuerName><dsig:X509SerialNumber>1000001</dsig:X509SerialNumber></dsig:X509IssuerSerial><dsig:X509SubjectName>CN=Test Client (RSA),OU=Engineering,O=Phaos Technology,L=New York,ST=New York,C=US</dsig:X509SubjectName><dsig:X509SKI>E+fKwQsT5lS3mWmBkalUTp0JRW8=</dsig:X509SKI></dsig:X509Data></dsig:KeyInfo></dsig:Signature></player>";
  210. [Test]
  211. public void KeepDocument ()
  212. {
  213. string result = @"<dsig:Reference URI="""" xmlns:dsig=""http://www.w3.org/2000/09/xmldsig#""><dsig:Transforms><dsig:Transform Algorithm=""http://www.w3.org/2000/09/xmldsig#enveloped-signature"" /></dsig:Transforms><dsig:DigestMethod Algorithm=""http://www.w3.org/2000/09/xmldsig#sha1"" /><dsig:DigestValue>nDF2V/bzRd0VE3EwShWtsBzTEDc=</dsig:DigestValue></dsig:Reference>";
  214. XmlDocument doc = new XmlDocument ();
  215. doc.LoadXml (xml);
  216. XmlElement org = (XmlElement) doc.SelectSingleNode ("//*[local-name()='Reference']");
  217. Reference r = new Reference ();
  218. r.LoadXml (org);
  219. XmlElement el = r.GetXml ();
  220. AssertEquals (doc, el.OwnerDocument);
  221. AssertEquals (org, el);
  222. AssertEquals (result, el.OuterXml);
  223. }
  224. }
  225. }