Pretend to be a UDP socket
| 20 | |
| 21 | |
| 22 | class MockSocket: |
| 23 | "Pretend to be a UDP socket" |
| 24 | def __init__(self, failp): |
| 25 | self.failp = failp |
| 26 | self.msgs = [] # accumulate messages for later inspection |
| 27 | |
| 28 | def send(self, msg): |
| 29 | if self.failp: |
| 30 | raise StatsdTestException("Should not interrupt the logger") |
| 31 | |
| 32 | sock_dir = tempfile.mkdtemp() |
| 33 | sock_file = os.path.join(sock_dir, "test.sock") |
| 34 | |
| 35 | server = socket.socket(socket.AF_UNIX, socket.SOCK_DGRAM) |
| 36 | client = socket.socket(socket.AF_UNIX, socket.SOCK_DGRAM) |
| 37 | |
| 38 | try: |
| 39 | server.bind(sock_file) |
| 40 | client.connect(sock_file) |
| 41 | |
| 42 | client.send(msg) |
| 43 | self.msgs.append(server.recv(1024)) |
| 44 | |
| 45 | finally: |
| 46 | client.close() |
| 47 | server.close() |
| 48 | shutil.rmtree(sock_dir) |
| 49 | |
| 50 | def reset(self): |
| 51 | self.msgs = [] |
| 52 | |
| 53 | |
| 54 | def test_statsd_fail(): |
no outgoing calls