test_handler.py 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. import pytest
  2. from redmail import EmailSender
  3. from redmail import EmailHandler
  4. import logging
  5. def _create_dummy_send(messages:list):
  6. def _dummy_send(msg):
  7. messages.append(msg)
  8. return _dummy_send
  9. def test_default_body():
  10. hdlr = EmailHandler(host="localhost", port=0, receivers=["me@example.com"], subject="Some logging")
  11. # By default, this should be body if text/html/html_template/text_template not specified
  12. assert hdlr.email.text == "{{ msg }}"
  13. @pytest.mark.parametrize("kwargs,exp_headers,exp_payload",
  14. [
  15. pytest.param(
  16. {
  17. "email": EmailSender(host="localhost", port=0),
  18. "subject": "A log record",
  19. "sender": "me@example.com",
  20. "receivers": ["he@example.com", "she@example.com"],
  21. },
  22. {
  23. "from": "me@example.com",
  24. "to": "he@example.com, she@example.com",
  25. "subject": "A log record",
  26. 'Content-Transfer-Encoding': '7bit',
  27. 'Content-Type': 'text/plain; charset="utf-8"',
  28. 'MIME-Version': '1.0',
  29. },
  30. 'a message\n',
  31. id="Minimal",
  32. ),
  33. pytest.param(
  34. {
  35. "email": EmailSender(host="localhost", port=0),
  36. "subject": "A log record",
  37. "sender": "me@example.com",
  38. "receivers": ["he@example.com", "she@example.com"],
  39. "text": "Log Record: \n{{ msg }}",
  40. "fmt": '%(name)s: %(levelname)s: %(message)s'
  41. },
  42. {
  43. "from": "me@example.com",
  44. "to": "he@example.com, she@example.com",
  45. "subject": "A log record",
  46. 'Content-Transfer-Encoding': '7bit',
  47. 'Content-Type': 'text/plain; charset="utf-8"',
  48. 'MIME-Version': '1.0',
  49. },
  50. 'Log Record: \n_test: INFO: a message\n',
  51. id="Custom message (msg)",
  52. ),
  53. pytest.param(
  54. {
  55. "email": EmailSender(host="localhost", port=0),
  56. "subject": "A log record",
  57. "sender": "me@example.com",
  58. "receivers": ["he@example.com", "she@example.com"],
  59. "text": "Log Record: \n{{ record.message }}",
  60. "fmt": '%(name)s: %(levelname)s: %(message)s'
  61. },
  62. {
  63. "from": "me@example.com",
  64. "to": "he@example.com, she@example.com",
  65. "subject": "A log record",
  66. 'Content-Transfer-Encoding': '7bit',
  67. 'Content-Type': 'text/plain; charset="utf-8"',
  68. 'MIME-Version': '1.0',
  69. },
  70. 'Log Record: \na message\n',
  71. id="Custom message (record)",
  72. ),
  73. pytest.param(
  74. {
  75. "email": EmailSender(host="localhost", port=0),
  76. "subject": "Log: {record.name} - {record.levelname}",
  77. "sender": "me@example.com",
  78. "receivers": ["he@example.com", "she@example.com"],
  79. },
  80. {
  81. "from": "me@example.com",
  82. "to": "he@example.com, she@example.com",
  83. "subject": "Log: _test - INFO",
  84. 'Content-Transfer-Encoding': '7bit',
  85. 'Content-Type': 'text/plain; charset="utf-8"',
  86. 'MIME-Version': '1.0',
  87. },
  88. 'a message\n',
  89. id="Sender with fomatted subject",
  90. ),
  91. pytest.param(
  92. {
  93. "email": EmailSender(host="localhost", port=0),
  94. "subject": "A log record",
  95. "sender": "me@example.com",
  96. "receivers": ["he@example.com", "she@example.com"],
  97. "fmt": '%(name)s: %(levelname)s: %(message)s',
  98. "html": "<h1>{{ record.levelname }}</h1><p>{{ msg }}</p>"
  99. },
  100. {
  101. "from": "me@example.com",
  102. "to": "he@example.com, she@example.com",
  103. "subject": "A log record",
  104. 'Content-Type': 'multipart/alternative',
  105. },
  106. ["<h1>INFO</h1><p>_test: INFO: a message</p>\n"],
  107. id="Custom message (HTML, msg)",
  108. ),
  109. pytest.param(
  110. {
  111. "email": EmailSender(host="localhost", port=0),
  112. "subject": "A log record",
  113. "sender": "me@example.com",
  114. "receivers": ["he@example.com", "she@example.com"],
  115. "fmt": '%(name)s: %(levelname)s: %(message)s',
  116. "html": "<h1>{{ record.levelname }}</h1><p>{{ record.message }}</p>"
  117. },
  118. {
  119. "from": "me@example.com",
  120. "to": "he@example.com, she@example.com",
  121. "subject": "A log record",
  122. 'Content-Type': 'multipart/alternative',
  123. },
  124. ["<h1>INFO</h1><p>a message</p>\n"],
  125. id="Custom message (HTML, record)",
  126. ),
  127. ]
  128. )
  129. def test_emit(logger, kwargs, exp_headers, exp_payload):
  130. msgs = []
  131. fmt = kwargs.pop("fmt", None)
  132. hdlr = EmailHandler(**kwargs)
  133. hdlr.formatter = logging.Formatter(fmt)
  134. hdlr.email.send_message = _create_dummy_send(msgs)
  135. logger.addHandler(hdlr)
  136. logger.setLevel(logging.INFO)
  137. logger.info("a message")
  138. assert len(msgs) == 1
  139. msg = msgs[0]
  140. headers = dict(msg.items())
  141. payload = msg.get_payload()
  142. assert headers == exp_headers
  143. if isinstance(payload, str):
  144. assert payload == exp_payload
  145. else:
  146. # HTML (and text) of payloads
  147. payloads = [pl.get_payload() for pl in payload]
  148. assert payloads == exp_payload