mirror of
https://github.com/sprockets/sprockets.mixins.metrics.git
synced 2024-11-22 03:00:25 +00:00
Add tcp & udp tests for data sent
This commit is contained in:
parent
b24a3699a5
commit
924735c24e
1 changed files with 70 additions and 5 deletions
75
tests.py
75
tests.py
|
@ -4,9 +4,10 @@ import os
|
||||||
import socket
|
import socket
|
||||||
import time
|
import time
|
||||||
import unittest
|
import unittest
|
||||||
|
from unittest.mock import patch
|
||||||
import uuid
|
import uuid
|
||||||
|
|
||||||
from tornado import gen, testing, web
|
from tornado import gen, iostream, testing, web
|
||||||
import mock
|
import mock
|
||||||
|
|
||||||
from sprockets.mixins.metrics import influxdb, statsd
|
from sprockets.mixins.metrics import influxdb, statsd
|
||||||
|
@ -54,15 +55,43 @@ class TCPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.application = None
|
self.application = None
|
||||||
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(TCPStatsdMetricCollectionTests, self).setUp()
|
super(TCPStatsdMetricCollectionTests, self).setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': 'testing',
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
'host': self.statsd.sockaddr[0],
|
'host': self.statsd.sockaddr[0],
|
||||||
'port': self.statsd.sockaddr[1],
|
'port': self.statsd.sockaddr[1],
|
||||||
'protocol': 'tcp',
|
'protocol': 'tcp',
|
||||||
'prepend_metric_type': True})
|
'prepend_metric_type': True})
|
||||||
|
|
||||||
|
@patch.object(iostream.IOStream, 'write')
|
||||||
|
def test_expected_counters_data_written(self, mock_sock):
|
||||||
|
path = ('foo', 'bar')
|
||||||
|
value = 500
|
||||||
|
metric_type = 'c'
|
||||||
|
expected = "{}:{}|{}\n".format(
|
||||||
|
'.'.join((self.namespace, 'counters', *path)),
|
||||||
|
value,
|
||||||
|
metric_type)
|
||||||
|
|
||||||
|
self.application.statsd.send(path, value, metric_type)
|
||||||
|
mock_sock.assert_called_once_with(expected.encode())
|
||||||
|
|
||||||
|
@patch.object(iostream.IOStream, 'write')
|
||||||
|
def test_expected_timers_data_written(self, mock_sock):
|
||||||
|
path = ('foo', 'bar')
|
||||||
|
value = 500
|
||||||
|
metric_type = 'ms'
|
||||||
|
expected = "{}:{}|{}\n".format(
|
||||||
|
'.'.join((self.namespace, 'timers', *path)),
|
||||||
|
value,
|
||||||
|
metric_type)
|
||||||
|
|
||||||
|
self.application.statsd.send(path, value, metric_type)
|
||||||
|
mock_sock.assert_called_once_with(expected.encode())
|
||||||
|
|
||||||
def test_tcp_message_format(self):
|
def test_tcp_message_format(self):
|
||||||
expected = '{path}:{value}|{metric_type}\n'
|
expected = '{path}:{value}|{metric_type}\n'
|
||||||
self.assertEqual(self.application.statsd._msg_format, expected)
|
self.assertEqual(self.application.statsd._msg_format, expected)
|
||||||
|
@ -124,10 +153,12 @@ class TCPStatsdConfigurationTests(testing.AsyncHTTPTestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.application = None
|
self.application = None
|
||||||
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(TCPStatsdConfigurationTests, self).setUp()
|
super(TCPStatsdConfigurationTests, self).setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': 'testing',
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
'host': self.statsd.sockaddr[0],
|
'host': self.statsd.sockaddr[0],
|
||||||
'port': self.statsd.sockaddr[1],
|
'port': self.statsd.sockaddr[1],
|
||||||
'protocol': 'tcp',
|
'protocol': 'tcp',
|
||||||
|
@ -162,10 +193,12 @@ class UDPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.application = None
|
self.application = None
|
||||||
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(UDPStatsdMetricCollectionTests, self).setUp()
|
super(UDPStatsdMetricCollectionTests, self).setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': 'testing',
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
'host': self.statsd.sockaddr[0],
|
'host': self.statsd.sockaddr[0],
|
||||||
'port': self.statsd.sockaddr[1],
|
'port': self.statsd.sockaddr[1],
|
||||||
'protocol': 'udp',
|
'protocol': 'udp',
|
||||||
|
@ -175,6 +208,36 @@ class UDPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
self.statsd.close()
|
self.statsd.close()
|
||||||
super(UDPStatsdMetricCollectionTests, self).tearDown()
|
super(UDPStatsdMetricCollectionTests, self).tearDown()
|
||||||
|
|
||||||
|
@patch.object(socket.socket, 'sendto')
|
||||||
|
def test_expected_counters_data_written(self, mock_sock):
|
||||||
|
path = ('foo', 'bar')
|
||||||
|
value = 500
|
||||||
|
metric_type = 'c'
|
||||||
|
expected = "{}:{}|{}".format(
|
||||||
|
'.'.join((self.namespace, 'counters', *path)),
|
||||||
|
value,
|
||||||
|
metric_type)
|
||||||
|
|
||||||
|
self.application.statsd.send(path, value, metric_type)
|
||||||
|
mock_sock.assert_called_once_with(
|
||||||
|
expected.encode(),
|
||||||
|
(self.statsd.sockaddr[0], self.statsd.sockaddr[1]))
|
||||||
|
|
||||||
|
@patch.object(socket.socket, 'sendto')
|
||||||
|
def test_expected_timers_data_written(self, mock_sock):
|
||||||
|
path = ('foo', 'bar')
|
||||||
|
value = 500
|
||||||
|
metric_type = 'ms'
|
||||||
|
expected = "{}:{}|{}".format(
|
||||||
|
'.'.join((self.namespace, 'timers', *path)),
|
||||||
|
value,
|
||||||
|
metric_type)
|
||||||
|
|
||||||
|
self.application.statsd.send(path, value, metric_type)
|
||||||
|
mock_sock.assert_called_once_with(
|
||||||
|
expected.encode(),
|
||||||
|
(self.statsd.sockaddr[0], self.statsd.sockaddr[1]))
|
||||||
|
|
||||||
def test_udp_message_format(self):
|
def test_udp_message_format(self):
|
||||||
expected = '{path}:{value}|{metric_type}'
|
expected = '{path}:{value}|{metric_type}'
|
||||||
self.assertEqual(self.application.statsd._msg_format, expected)
|
self.assertEqual(self.application.statsd._msg_format, expected)
|
||||||
|
@ -236,10 +299,12 @@ class UDPStatsdConfigurationTests(testing.AsyncHTTPTestCase):
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.application = None
|
self.application = None
|
||||||
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(UDPStatsdConfigurationTests, self).setUp()
|
super(UDPStatsdConfigurationTests, self).setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': 'testing',
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
'host': self.statsd.sockaddr[0],
|
'host': self.statsd.sockaddr[0],
|
||||||
'port': self.statsd.sockaddr[1],
|
'port': self.statsd.sockaddr[1],
|
||||||
'protocol': 'udp',
|
'protocol': 'udp',
|
||||||
|
|
Loading…
Reference in a new issue