_util.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. # Copyright (c) Twisted Matrix Laboratories.
  2. # See LICENSE for details.
  3. """
  4. General helpers for L{twisted.web} unit tests.
  5. """
  6. from __future__ import division, absolute_import
  7. from twisted.internet.defer import succeed
  8. from twisted.web import server
  9. from twisted.trial.unittest import TestCase
  10. from twisted.python.failure import Failure
  11. from twisted.web._flatten import flattenString
  12. from twisted.web.error import FlattenerError
  13. def _render(resource, request):
  14. result = resource.render(request)
  15. if isinstance(result, bytes):
  16. request.write(result)
  17. request.finish()
  18. return succeed(None)
  19. elif result is server.NOT_DONE_YET:
  20. if request.finished:
  21. return succeed(None)
  22. else:
  23. return request.notifyFinish()
  24. else:
  25. raise ValueError("Unexpected return value: %r" % (result,))
  26. class FlattenTestCase(TestCase):
  27. """
  28. A test case that assists with testing L{twisted.web._flatten}.
  29. """
  30. def assertFlattensTo(self, root, target):
  31. """
  32. Assert that a root element, when flattened, is equal to a string.
  33. """
  34. d = flattenString(None, root)
  35. d.addCallback(lambda s: self.assertEqual(s, target))
  36. return d
  37. def assertFlattensImmediately(self, root, target):
  38. """
  39. Assert that a root element, when flattened, is equal to a string, and
  40. performs no asynchronus Deferred anything.
  41. This version is more convenient in tests which wish to make multiple
  42. assertions about flattening, since it can be called multiple times
  43. without having to add multiple callbacks.
  44. @return: the result of rendering L{root}, which should be equivalent to
  45. L{target}.
  46. @rtype: L{bytes}
  47. """
  48. results = []
  49. it = self.assertFlattensTo(root, target)
  50. it.addBoth(results.append)
  51. # Do our best to clean it up if something goes wrong.
  52. self.addCleanup(it.cancel)
  53. if not results:
  54. self.fail("Rendering did not complete immediately.")
  55. result = results[0]
  56. if isinstance(result, Failure):
  57. result.raiseException()
  58. return results[0]
  59. def assertFlatteningRaises(self, root, exn):
  60. """
  61. Assert flattening a root element raises a particular exception.
  62. """
  63. d = self.assertFailure(self.assertFlattensTo(root, b''), FlattenerError)
  64. d.addCallback(lambda exc: self.assertIsInstance(exc._exception, exn))
  65. return d
  66. __all__ = ["_render", "FlattenTestCase"]