123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
-
- #include "config.h"
- #include "tests.h"
- #include "dns.h"
- #include "logger.h"
- #include "rspamd.h"
- #include "async_session.h"
- #include "cfg_file.h"
-
- static unsigned int requests = 0;
- extern struct ev_loop *event_loop;
- struct rspamd_dns_resolver *resolver;
-
- gboolean
- session_fin(gpointer unused)
- {
- ev_break(event_loop, EVBREAK_ALL);
-
- return TRUE;
- }
-
- static void
- test_dns_cb(struct rdns_reply *reply, gpointer arg)
- {
- struct rdns_reply_entry *cur;
- const struct rdns_request_name *name =
- rdns_request_get_name(reply->request, NULL);
-
- msg_debug("got reply with code %s for request %s",
- rdns_strerror(reply->code), name->name);
- if (reply->code == RDNS_RC_NOERROR) {
- cur = reply->entries;
- while (cur) {
- switch (cur->type) {
- case RDNS_REQUEST_A:
- msg_debug("got ip: %s", inet_ntoa(cur->content.a.addr));
- break;
- case RDNS_REQUEST_PTR:
- msg_debug("got name %s", cur->content.ptr.name);
- break;
- case RDNS_REQUEST_TXT:
- msg_debug("got txt %s", cur->content.txt.data);
- break;
- case RDNS_REQUEST_SPF:
- msg_debug("got spf %s", cur->content.txt.data);
- break;
- case RDNS_REQUEST_SRV:
- msg_debug("got srv pri: %d, weight: %d, port: %d, target: %s", cur->content.srv.weight,
- cur->content.srv.priority, cur->content.srv.port, cur->content.srv.target);
- break;
- case RDNS_REQUEST_MX:
- msg_debug("got mx %s:%d", cur->content.mx.name, cur->content.mx.priority);
- break;
- }
- cur = cur->next;
- }
- }
- if (--requests == 0) {
- session_fin(NULL);
- }
- }
-
- void rspamd_dns_test_func(void)
- {
-
- struct rspamd_config *cfg;
- rspamd_mempool_t *pool;
- struct rspamd_async_session *s;
-
- cfg = (struct rspamd_config *) g_malloc(sizeof(struct rspamd_config));
- bzero(cfg, sizeof(struct rspamd_config));
- cfg->cfg_pool = rspamd_mempool_new(rspamd_mempool_suggest_size(), NULL, 0);
- cfg->dns_retransmits = 2;
- cfg->dns_timeout = 0.5;
-
- pool = rspamd_mempool_new(rspamd_mempool_suggest_size(), NULL, 0);
-
- s = rspamd_session_create(pool, session_fin, NULL, NULL, NULL);
-
- resolver = rspamd_dns_resolver_init(NULL, event_loop, cfg);
-
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_A, "google.com"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_PTR, "81.19.70.3"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_MX, "rambler.ru"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_TXT, "rambler.ru"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_TXT, "google.com"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_SPF, "rambler.ru"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_SRV,
- "_xmpp-server._tcp.jabber.org"));
- requests++;
- g_assert(rspamd_dns_resolver_request(resolver, s, pool, test_dns_cb, NULL, RDNS_REQUEST_TXT, "non-existent.arpa"));
-
- g_assert(resolver != NULL);
-
- ev_run(event_loop, 0);
- }
|