Server IP : 85.214.239.14 / Your IP : 3.15.214.244 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Tue Jan 9 19:45:01 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /proc/3/task/3/cwd/srv/modoboa/env/lib64/python3.5/site-packages/modoboa/admin/tests/ |
Upload File : |
"""DNSBL related tests.""" from unittest import mock import dns.resolver from testfixtures import LogCapture from django.core import mail, management from django.test import override_settings from django.urls import reverse from django.utils.translation import ugettext as _ from modoboa.core import factories as core_factories from modoboa.lib.tests import ModoTestCase from . import utils from .. import factories, models from ..lib import get_domain_mx_list class MXTestCase(ModoTestCase): """TestCase for DNSBL related features.""" @classmethod def setUpTestData(cls): # NOQA:N802 """Create some data.""" super(MXTestCase, cls).setUpTestData() cls.domain = factories.DomainFactory(name="modoboa.org") # should not exist cls.bad_domain = factories.DomainFactory( name="does-not-exist.example.com") # Add domain admin with mailbox mb = factories.MailboxFactory( address="admin", domain=cls.bad_domain, user__username="admin@does-not-exist.example.com", user__groups=("DomainAdmins", ) ) cls.bad_domain.add_admin(mb.user) # Add domain admin with no mailbox admin = core_factories.UserFactory( username="admin2@does-not-exist.example.com", groups=("DomainAdmins", )) cls.bad_domain.add_admin(admin) cls.localconfig.parameters.set_value( "valid_mxs", "192.0.2.1 2001:db8::1") cls.localconfig.save() models.MXRecord.objects.all().delete() @mock.patch("gevent.socket.gethostbyname") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_management_command( self, mock_query, mock_getaddrinfo, mock_g_gethostbyname): """Check that command works fine.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result mock_g_gethostbyname.return_value = "1.2.3.4" self.assertEqual(models.MXRecord.objects.count(), 0) management.call_command("modo", "check_mx", "--no-dnsbl", "--ttl=0") self.assertTrue( models.MXRecord.objects.filter(domain=self.domain).exists()) # we passed a ttl to 0. this will reset the cache this time qs = models.MXRecord.objects.filter(domain=self.domain) id_ = qs[0].id management.call_command("modo", "check_mx", "--no-dnsbl", "--ttl=7200") qs = models.MXRecord.objects.filter(domain=self.domain) self.assertNotEqual(id_, qs[0].id) id_ = qs[0].id # assume that mxrecords ids are the same. means that we taking care of # ttl management.call_command("modo", "check_mx", "--no-dnsbl") qs = models.MXRecord.objects.filter(domain=self.domain) self.assertEqual(id_, qs[0].id) @mock.patch("gevent.socket.gethostbyname") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_single_domain_update( self, mock_query, mock_getaddrinfo, mock_g_gethostbyname): """Update only one domain.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result mock_g_gethostbyname.return_value = "1.2.3.4" management.call_command( "modo", "check_mx", "--domain", self.domain.name) self.assertTrue( models.MXRecord.objects.filter(domain=self.domain).exists()) self.assertFalse( models.MXRecord.objects.filter(domain=self.bad_domain).exists()) management.call_command( "modo", "check_mx", "--domain", str(self.bad_domain.pk)) self.assertFalse( models.MXRecord.objects.filter(domain=self.bad_domain).exists()) self.assertEqual(len(mail.outbox), 1) management.call_command( "modo", "check_mx", "--domain", "toto.com") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_get_mx_list_dns_server(self, mock_query, mock_getaddrinfo): """Test to get mx list from specific DNS server.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result self.set_global_parameter("custom_dns_server", "123.45.67.89") get_domain_mx_list("does-not-exist.example.com") @mock.patch("ipaddress.ip_address") @mock.patch.object(dns.resolver.Resolver, "query") def test_get_domain_mx_list_logging(self, mock_query, mock_ip_address): """Test to get error loggins from specific DNS server.""" mock_query.side_effect = utils.mock_dns_query_result mock_ip_address.side_effect = utils.mock_ip_address_result with LogCapture("modoboa.admin") as log: get_domain_mx_list("does-not-exist.example.com") get_domain_mx_list("no-mx.example.com") get_domain_mx_list("no-ns-servers.example.com") get_domain_mx_list("timeout.example.com") get_domain_mx_list("no-lookup.example.com") get_domain_mx_list("no-answer.example.Com") get_domain_mx_list("bad-response.example.com") log.check( ("modoboa.admin", "ERROR", _("No DNS record found for %s") % "does-not-exist.example.com"), ("modoboa.admin", "ERROR", _("No MX record for %s") % "no-mx.example.com"), ("modoboa.admin", "ERROR", _("No working name servers found")), ("modoboa.admin", "WARNING", _("DNS resolution timeout, unable to query %s at the moment") % "timeout.example.com"), ("modoboa.admin", "ERROR", _("No DNS record found for %s") % "does-not-exist.example.com"), ("modoboa.admin", "ERROR", _("No DNS record found for %s") % "does-not-exist.example.com"), ("modoboa.admin", "WARNING", _("Invalid IP address format for %(domain)s; %(addr)s") % {"domain": "bad-response.example.com", "addr": "000.0.0.0"}), ("modoboa.admin", "WARNING", _("Invalid IP address format for %(domain)s; %(addr)s") % {"domain": "bad-response.example.com", "addr": "000.0.0.0"}), ) @override_settings(DNSBL_PROVIDERS=["zen.spamhaus.org"]) class DNSBLTestCase(ModoTestCase): """TestCase for DNSBL related features.""" @classmethod def setUpTestData(cls): # NOQA:N802 """Create some data.""" super(DNSBLTestCase, cls).setUpTestData() cls.domain = factories.DomainFactory(name="modoboa.org") factories.DomainFactory(name="does-not-exist.example.com") cls.domain2 = factories.DomainFactory( name="test.localhost") # Should not be checked cls.domain3 = factories.DomainFactory( name="modoboa.com", enable_dns_checks=False) models.DNSBLResult.objects.all().delete() @mock.patch("gevent.socket.gethostbyname") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_management_command( self, mock_query, mock_getaddrinfo, mock_g_gethostbyname): """Check that command works fine.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result mock_g_gethostbyname.return_value = "1.2.3.4" self.assertEqual(models.DNSBLResult.objects.count(), 0) management.call_command("modo", "check_mx") self.assertTrue( models.DNSBLResult.objects.filter(domain=self.domain).exists()) self.assertFalse( models.DNSBLResult.objects.filter(domain=self.domain3).exists()) response = self.client.get( reverse("admin:dnsbl_domain_detail", args=[self.domain.pk])) self.assertEqual(response.status_code, 200) self.assertFalse(self.domain.uses_a_reserved_tld) self.assertTrue(self.domain2.uses_a_reserved_tld) @mock.patch("gevent.socket.gethostbyname") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_notifications( self, mock_query, mock_getaddrinfo, mock_g_gethostbyname): """Check notifications.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result mock_g_gethostbyname.return_value = "1.2.3.4" management.call_command( "modo", "check_mx", "--email", "user@example.test") if len(mail.outbox) != 2: for message in mail.outbox: print(message.subject) self.assertEqual(len(mail.outbox), 2) @mock.patch("gevent.socket.gethostbyname") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_management_command_no_dnsbl( self, mock_query, mock_getaddrinfo, mock_g_gethostbyname): """Check that command works fine without dnsbl.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result mock_g_gethostbyname.return_value = "1.2.3.4" self.assertEqual(models.DNSBLResult.objects.count(), 0) management.call_command("modo", "check_mx", "--no-dnsbl") self.assertFalse( models.DNSBLResult.objects.filter(domain=self.domain).exists()) response = self.client.get( reverse("admin:dnsbl_domain_detail", args=[self.domain.pk])) self.assertEqual(response.status_code, 200) class DNSChecksTestCase(ModoTestCase): """A test case for DNS checks.""" @classmethod def setUpTestData(cls): # NOQA:N802 """Create some data.""" super(DNSChecksTestCase, cls).setUpTestData() cls.domain = factories.DomainFactory(name="dns-checks.com") @mock.patch("gevent.socket.gethostbyname") @mock.patch("socket.getaddrinfo") @mock.patch.object(dns.resolver.Resolver, "query") def test_management_command( self, mock_query, mock_getaddrinfo, mock_g_gethostbyname): """Check that command works fine.""" mock_query.side_effect = utils.mock_dns_query_result mock_getaddrinfo.side_effect = utils.mock_ip_query_result mock_g_gethostbyname.return_value = "1.2.3.4" self.domain.enable_dkim = True self.domain.dkim_public_key = "XXXXX" self.domain.save(update_fields=["enable_dkim", "dkim_public_key"]) management.call_command("modo", "check_mx", "--no-dnsbl", "--ttl=0") self.assertIsNot(self.domain.spf_record, None) self.assertIsNot(self.domain.dkim_record, None) self.assertIsNot(self.domain.dmarc_record, None) self.assertIsNot(self.domain.autoconfig_record, None) self.assertIsNot(self.domain.autodiscover_record, None)