mirror of https://github.com/watcha-fr/synapse
Merge pull request #509 from matrix-org/erikj/dns_cache
Cache dns lookups, and use the cache if we fail to lookup servers laterpull/4/merge
commit
dfe1273d14
@ -0,0 +1,115 @@ |
|||||||
|
# -*- coding: utf-8 -*- |
||||||
|
# Copyright 2014-2016 OpenMarket Ltd |
||||||
|
# |
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
# you may not use this file except in compliance with the License. |
||||||
|
# You may obtain a copy of the License at |
||||||
|
# |
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0 |
||||||
|
# |
||||||
|
# Unless required by applicable law or agreed to in writing, software |
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
# See the License for the specific language governing permissions and |
||||||
|
# limitations under the License. |
||||||
|
|
||||||
|
from . import unittest |
||||||
|
from twisted.internet import defer |
||||||
|
from twisted.names import dns, error |
||||||
|
|
||||||
|
from mock import Mock |
||||||
|
|
||||||
|
from synapse.http.endpoint import resolve_service |
||||||
|
|
||||||
|
|
||||||
|
class DnsTestCase(unittest.TestCase): |
||||||
|
|
||||||
|
@defer.inlineCallbacks |
||||||
|
def test_resolve(self): |
||||||
|
dns_client_mock = Mock() |
||||||
|
|
||||||
|
service_name = "test_service.examle.com" |
||||||
|
host_name = "example.com" |
||||||
|
ip_address = "127.0.0.1" |
||||||
|
|
||||||
|
answer_srv = dns.RRHeader( |
||||||
|
type=dns.SRV, |
||||||
|
payload=dns.Record_SRV( |
||||||
|
target=host_name, |
||||||
|
) |
||||||
|
) |
||||||
|
|
||||||
|
answer_a = dns.RRHeader( |
||||||
|
type=dns.A, |
||||||
|
payload=dns.Record_A( |
||||||
|
address=ip_address, |
||||||
|
) |
||||||
|
) |
||||||
|
|
||||||
|
dns_client_mock.lookupService.return_value = ([answer_srv], None, None) |
||||||
|
dns_client_mock.lookupAddress.return_value = ([answer_a], None, None) |
||||||
|
|
||||||
|
cache = {} |
||||||
|
|
||||||
|
servers = yield resolve_service( |
||||||
|
service_name, dns_client=dns_client_mock, cache=cache |
||||||
|
) |
||||||
|
|
||||||
|
dns_client_mock.lookupService.assert_called_once_with(service_name) |
||||||
|
dns_client_mock.lookupAddress.assert_called_once_with(host_name) |
||||||
|
|
||||||
|
self.assertEquals(len(servers), 1) |
||||||
|
self.assertEquals(servers, cache[service_name]) |
||||||
|
self.assertEquals(servers[0].host, ip_address) |
||||||
|
|
||||||
|
@defer.inlineCallbacks |
||||||
|
def test_from_cache(self): |
||||||
|
dns_client_mock = Mock() |
||||||
|
dns_client_mock.lookupService.return_value = defer.fail(error.DNSServerError()) |
||||||
|
|
||||||
|
service_name = "test_service.examle.com" |
||||||
|
|
||||||
|
cache = { |
||||||
|
service_name: [object()] |
||||||
|
} |
||||||
|
|
||||||
|
servers = yield resolve_service( |
||||||
|
service_name, dns_client=dns_client_mock, cache=cache |
||||||
|
) |
||||||
|
|
||||||
|
dns_client_mock.lookupService.assert_called_once_with(service_name) |
||||||
|
|
||||||
|
self.assertEquals(len(servers), 1) |
||||||
|
self.assertEquals(servers, cache[service_name]) |
||||||
|
|
||||||
|
@defer.inlineCallbacks |
||||||
|
def test_empty_cache(self): |
||||||
|
dns_client_mock = Mock() |
||||||
|
|
||||||
|
dns_client_mock.lookupService.return_value = defer.fail(error.DNSServerError()) |
||||||
|
|
||||||
|
service_name = "test_service.examle.com" |
||||||
|
|
||||||
|
cache = {} |
||||||
|
|
||||||
|
with self.assertRaises(error.DNSServerError): |
||||||
|
yield resolve_service( |
||||||
|
service_name, dns_client=dns_client_mock, cache=cache |
||||||
|
) |
||||||
|
|
||||||
|
@defer.inlineCallbacks |
||||||
|
def test_name_error(self): |
||||||
|
dns_client_mock = Mock() |
||||||
|
|
||||||
|
dns_client_mock.lookupService.return_value = defer.fail(error.DNSNameError()) |
||||||
|
|
||||||
|
service_name = "test_service.examle.com" |
||||||
|
|
||||||
|
cache = {} |
||||||
|
|
||||||
|
servers = yield resolve_service( |
||||||
|
service_name, dns_client=dns_client_mock, cache=cache |
||||||
|
) |
||||||
|
|
||||||
|
self.assertEquals(len(servers), 0) |
||||||
|
self.assertEquals(len(cache), 0) |
Loading…
Reference in new issue