You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

rspamd_dns_test.c 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. #include "config.h"
  2. #include "tests.h"
  3. #include "dns.h"
  4. #include "logger.h"
  5. #include "rspamd.h"
  6. #include "async_session.h"
  7. #include "cfg_file.h"
  8. static unsigned int requests = 0;
  9. extern struct ev_loop *event_loop;
  10. struct rspamd_dns_resolver *resolver;
  11. gboolean
  12. session_fin(gpointer unused)
  13. {
  14. ev_break(event_loop, EVBREAK_ALL);
  15. return TRUE;
  16. }
  17. static void
  18. test_dns_cb(struct rdns_reply *reply, gpointer arg)
  19. {
  20. struct rdns_reply_entry *cur;
  21. const struct rdns_request_name *name =
  22. rdns_request_get_name(reply->request, NULL);
  23. msg_debug("got reply with code %s for request %s",
  24. rdns_strerror(reply->code), name->name);
  25. if (reply->code == RDNS_RC_NOERROR) {
  26. cur = reply->entries;
  27. while (cur) {
  28. switch (cur->type) {
  29. case RDNS_REQUEST_A:
  30. msg_debug("got ip: %s", inet_ntoa(cur->content.a.addr));
  31. break;
  32. case RDNS_REQUEST_PTR:
  33. msg_debug("got name %s", cur->content.ptr.name);
  34. break;
  35. case RDNS_REQUEST_TXT:
  36. msg_debug("got txt %s", cur->content.txt.data);
  37. break;
  38. case RDNS_REQUEST_SPF:
  39. msg_debug("got spf %s", cur->content.txt.data);
  40. break;
  41. case RDNS_REQUEST_SRV:
  42. msg_debug("got srv pri: %d, weight: %d, port: %d, target: %s", cur->content.srv.weight,
  43. cur->content.srv.priority, cur->content.srv.port, cur->content.srv.target);
  44. break;
  45. case RDNS_REQUEST_MX:
  46. msg_debug("got mx %s:%d", cur->content.mx.name, cur->content.mx.priority);
  47. break;
  48. }
  49. cur = cur->next;
  50. }
  51. }
  52. if (--requests == 0) {
  53. session_fin(NULL);
  54. }
  55. }
  56. void rspamd_dns_test_func(void)
  57. {
  58. struct rspamd_config *cfg;
  59. rspamd_mempool_t *pool;
  60. struct rspamd_async_session *s;
  61. cfg = (struct rspamd_config *) g_malloc(sizeof(struct rspamd_config));
  62. bzero(cfg, sizeof(struct rspamd_config));
  63. cfg->cfg_pool = rspamd_mempool_new(rspamd_mempool_suggest_size(), NULL, 0);
  64. cfg->dns_retransmits = 2;
  65. cfg->dns_timeout = 0.5;
  66. pool = rspamd_mempool_new(rspamd_mempool_suggest_size(), NULL, 0);
  67. s = rspamd_session_create(pool, session_fin, NULL, NULL, NULL);
  68. resolver = rspamd_dns_resolver_init(NULL, event_loop, cfg);
  69. requests++;
  70. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_A, "google.com"));
  71. requests++;
  72. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_PTR, "81.19.70.3"));
  73. requests++;
  74. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_MX, "rambler.ru"));
  75. requests++;
  76. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_TXT, "rambler.ru"));
  77. requests++;
  78. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_TXT, "google.com"));
  79. requests++;
  80. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_SPF, "rambler.ru"));
  81. requests++;
  82. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_SRV,
  83. "_xmpp-server._tcp.jabber.org"));
  84. requests++;
  85. g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_TXT, "non-existent.arpa"));
  86. g_assert(resolver != NULL);
  87. ev_run(event_loop, 0);
  88. }