HttpServerUtilityTest.cs 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. //
  2. // System.Web.HttpServerUtilityTest.cs
  3. // - Unit tests for System.Web.HttpServerUtility
  4. //
  5. // Author:
  6. // Sebastien Pouliot <[email protected]>
  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. using System.Text;
  30. using System.Web;
  31. using NUnit.Framework;
  32. namespace MonoTests.System.Web {
  33. [TestFixture]
  34. public class HttpServerUtilityTest {
  35. private HttpApplication _app;
  36. [TestFixtureSetUp]
  37. public void FixtureSetUp ()
  38. {
  39. _app = new HttpApplication ();
  40. }
  41. public HttpServerUtility Server {
  42. get { return _app.Server; }
  43. }
  44. [Test]
  45. public void HtmlEncode_LtGt ()
  46. {
  47. Assert.AreEqual ("&lt;script&gt;", Server.HtmlEncode ("<script>"));
  48. }
  49. // Notes:
  50. // * this is to avoid a regression that would cause Mono to
  51. // fail item #3 of the XSS vulnerabilities listed at:
  52. // http://it-project.ru/andir/docs/aspxvuln/aspxvuln.en.xml
  53. // we didn't fall the first time so let's ensure we never will
  54. // * The author notes that Microsoft has decided not to fix
  55. // this issue (hence the NotDotNet category).
  56. [Test]
  57. [Category ("NotDotNet")]
  58. public void HtmlEncode_XSS ()
  59. {
  60. string problem = "\xff1cscript\xff1e"; // unicode looks alike <script>
  61. byte[] utf8data = Encoding.UTF8.GetBytes (problem);
  62. Encoding win1251 = Encoding.GetEncoding ("windows-1251");
  63. byte[] windata = Encoding.Convert (Encoding.UTF8, win1251, utf8data);
  64. // now it's a real problem
  65. Assert.AreEqual ("<script>", Encoding.ASCII.GetString (windata), "<script>");
  66. string encoded = Server.HtmlEncode (problem);
  67. Assert.AreEqual ("&#65308;script&#65310;", encoded, "&#65308;script&#65310;");
  68. utf8data = Encoding.UTF8.GetBytes (encoded);
  69. windata = Encoding.Convert (Encoding.UTF8, win1251, utf8data);
  70. Assert.AreEqual ("&#65308;script&#65310;", Encoding.ASCII.GetString (windata), "ok");
  71. }
  72. }
  73. }