mirror of
https://github.com/sprockets/sprockets.mixins.metrics.git
synced 2024-11-24 11:19:54 +00:00
Reorganize and update reqs
This commit is contained in:
parent
694c5276d0
commit
8cc566acfd
6 changed files with 23 additions and 22 deletions
|
@ -1,3 +1,3 @@
|
||||||
|
-e .
|
||||||
|
-r docs.txt
|
||||||
-r testing.txt
|
-r testing.txt
|
||||||
coverage>=4.5,<5
|
|
||||||
Sphinx
|
|
||||||
|
|
1
requires/docs.txt
Normal file
1
requires/docs.txt
Normal file
|
@ -0,0 +1 @@
|
||||||
|
sphinx==1.8.2
|
|
@ -1 +1,2 @@
|
||||||
nose>=1.3,<2
|
coverage==4.5.2
|
||||||
|
nose==1.3.7
|
||||||
|
|
|
@ -12,11 +12,11 @@ SETTINGS_KEY = 'sprockets.mixins.metrics.statsd'
|
||||||
"""``self.settings`` key that configures this mix-in."""
|
"""``self.settings`` key that configures this mix-in."""
|
||||||
|
|
||||||
|
|
||||||
class StatsdMixin(object):
|
class StatsdMixin:
|
||||||
"""Mix this class in to record metrics to a Statsd server."""
|
"""Mix this class in to record metrics to a Statsd server."""
|
||||||
|
|
||||||
def initialize(self):
|
def initialize(self):
|
||||||
super(StatsdMixin, self).initialize()
|
super().initialize()
|
||||||
|
|
||||||
def record_timing(self, duration, *path):
|
def record_timing(self, duration, *path):
|
||||||
"""Record a timing.
|
"""Record a timing.
|
||||||
|
@ -79,13 +79,13 @@ class StatsdMixin(object):
|
||||||
to send the metric, so the configured namespace is used as well.
|
to send the metric, so the configured namespace is used as well.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
super(StatsdMixin, self).on_finish()
|
super().on_finish()
|
||||||
self.record_timing(self.request.request_time(),
|
self.record_timing(self.request.request_time(),
|
||||||
self.__class__.__name__, self.request.method,
|
self.__class__.__name__, self.request.method,
|
||||||
self.get_status())
|
self.get_status())
|
||||||
|
|
||||||
|
|
||||||
class StatsDCollector(object):
|
class StatsDCollector:
|
||||||
"""Collects and submits stats to StatsD.
|
"""Collects and submits stats to StatsD.
|
||||||
|
|
||||||
This class should be constructed using the
|
This class should be constructed using the
|
||||||
|
|
|
@ -44,7 +44,7 @@ class FakeStatsdServer(tcpserver.TCPServer):
|
||||||
|
|
||||||
def tcp_server(self):
|
def tcp_server(self):
|
||||||
self.event = locks.Event()
|
self.event = locks.Event()
|
||||||
super(FakeStatsdServer, self).__init__()
|
super().__init__()
|
||||||
|
|
||||||
sock, port = testing.bind_unused_port()
|
sock, port = testing.bind_unused_port()
|
||||||
self.add_socket(sock)
|
self.add_socket(sock)
|
||||||
|
|
27
tests.py
27
tests.py
|
@ -1,10 +1,9 @@
|
||||||
import itertools
|
import itertools
|
||||||
import socket
|
import socket
|
||||||
import unittest
|
import unittest
|
||||||
|
from unittest import mock
|
||||||
|
|
||||||
from tornado import gen, iostream, testing, web
|
from tornado import gen, iostream, testing, web
|
||||||
import mock
|
|
||||||
from mock import patch
|
|
||||||
|
|
||||||
from sprockets.mixins.metrics import statsd
|
from sprockets.mixins.metrics import statsd
|
||||||
from sprockets.mixins.metrics.testing import FakeStatsdServer
|
from sprockets.mixins.metrics.testing import FakeStatsdServer
|
||||||
|
@ -67,7 +66,7 @@ class TCPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
self.application = None
|
self.application = None
|
||||||
self.namespace = 'testing'
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(TCPStatsdMetricCollectionTests, self).setUp()
|
super().setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': self.namespace,
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
|
@ -80,7 +79,7 @@ class TCPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
path_sleep = 'tornado.gen.sleep'
|
path_sleep = 'tornado.gen.sleep'
|
||||||
path_statsd = self.application.statsd
|
path_statsd = self.application.statsd
|
||||||
with mock.patch(path_sleep) as gen_sleep, \
|
with mock.patch(path_sleep) as gen_sleep, \
|
||||||
patch.object(path_statsd, '_tcp_socket') as mock_tcp_socket:
|
mock.patch.object(path_statsd, '_tcp_socket') as mock_tcp_socket:
|
||||||
f = web.Future()
|
f = web.Future()
|
||||||
f.set_result(None)
|
f.set_result(None)
|
||||||
gen_sleep.return_value = f
|
gen_sleep.return_value = f
|
||||||
|
@ -88,13 +87,13 @@ class TCPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
self.application.statsd._tcp_on_closed()
|
self.application.statsd._tcp_on_closed()
|
||||||
mock_tcp_socket.assert_called_once_with()
|
mock_tcp_socket.assert_called_once_with()
|
||||||
|
|
||||||
@patch.object(iostream.IOStream, 'write')
|
@mock.patch.object(iostream.IOStream, 'write')
|
||||||
def test_write_not_executed_when_connection_is_closed(self, mock_write):
|
def test_write_not_executed_when_connection_is_closed(self, mock_write):
|
||||||
self.application.statsd._sock.close()
|
self.application.statsd._sock.close()
|
||||||
self.application.statsd.send('foo', 500, 'c')
|
self.application.statsd.send('foo', 500, 'c')
|
||||||
mock_write.assert_not_called()
|
mock_write.assert_not_called()
|
||||||
|
|
||||||
@patch.object(iostream.IOStream, 'write')
|
@mock.patch.object(iostream.IOStream, 'write')
|
||||||
def test_expected_counters_data_written(self, mock_sock):
|
def test_expected_counters_data_written(self, mock_sock):
|
||||||
path = ('foo', 'bar')
|
path = ('foo', 'bar')
|
||||||
value = 500
|
value = 500
|
||||||
|
@ -107,7 +106,7 @@ class TCPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
self.application.statsd.send(path, value, metric_type)
|
self.application.statsd.send(path, value, metric_type)
|
||||||
mock_sock.assert_called_once_with(expected.encode())
|
mock_sock.assert_called_once_with(expected.encode())
|
||||||
|
|
||||||
@patch.object(iostream.IOStream, 'write')
|
@mock.patch.object(iostream.IOStream, 'write')
|
||||||
def test_expected_timers_data_written(self, mock_sock):
|
def test_expected_timers_data_written(self, mock_sock):
|
||||||
path = ('foo', 'bar')
|
path = ('foo', 'bar')
|
||||||
value = 500
|
value = 500
|
||||||
|
@ -183,7 +182,7 @@ class TCPStatsdConfigurationTests(testing.AsyncHTTPTestCase):
|
||||||
self.application = None
|
self.application = None
|
||||||
self.namespace = 'testing'
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(TCPStatsdConfigurationTests, self).setUp()
|
super().setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='tcp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': self.namespace,
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
|
@ -223,7 +222,7 @@ class UDPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
self.application = None
|
self.application = None
|
||||||
self.namespace = 'testing'
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(UDPStatsdMetricCollectionTests, self).setUp()
|
super().setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': self.namespace,
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
|
@ -234,9 +233,9 @@ class UDPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
self.statsd.close()
|
self.statsd.close()
|
||||||
super(UDPStatsdMetricCollectionTests, self).tearDown()
|
super().tearDown()
|
||||||
|
|
||||||
@patch.object(socket.socket, 'sendto')
|
@mock.patch.object(socket.socket, 'sendto')
|
||||||
def test_expected_counters_data_written(self, mock_sock):
|
def test_expected_counters_data_written(self, mock_sock):
|
||||||
path = ('foo', 'bar')
|
path = ('foo', 'bar')
|
||||||
value = 500
|
value = 500
|
||||||
|
@ -251,7 +250,7 @@ class UDPStatsdMetricCollectionTests(testing.AsyncHTTPTestCase):
|
||||||
expected.encode(),
|
expected.encode(),
|
||||||
(self.statsd.sockaddr[0], self.statsd.sockaddr[1]))
|
(self.statsd.sockaddr[0], self.statsd.sockaddr[1]))
|
||||||
|
|
||||||
@patch.object(socket.socket, 'sendto')
|
@mock.patch.object(socket.socket, 'sendto')
|
||||||
def test_expected_timers_data_written(self, mock_sock):
|
def test_expected_timers_data_written(self, mock_sock):
|
||||||
path = ('foo', 'bar')
|
path = ('foo', 'bar')
|
||||||
value = 500
|
value = 500
|
||||||
|
@ -329,7 +328,7 @@ class UDPStatsdConfigurationTests(testing.AsyncHTTPTestCase):
|
||||||
self.application = None
|
self.application = None
|
||||||
self.namespace = 'testing'
|
self.namespace = 'testing'
|
||||||
|
|
||||||
super(UDPStatsdConfigurationTests, self).setUp()
|
super().setUp()
|
||||||
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
self.statsd = FakeStatsdServer(self.io_loop, protocol='udp')
|
||||||
|
|
||||||
statsd.install(self.application, **{'namespace': self.namespace,
|
statsd.install(self.application, **{'namespace': self.namespace,
|
||||||
|
@ -340,7 +339,7 @@ class UDPStatsdConfigurationTests(testing.AsyncHTTPTestCase):
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
self.statsd.close()
|
self.statsd.close()
|
||||||
super(UDPStatsdConfigurationTests, self).tearDown()
|
super().tearDown()
|
||||||
|
|
||||||
def test_that_http_method_call_is_recorded(self):
|
def test_that_http_method_call_is_recorded(self):
|
||||||
response = self.fetch('/')
|
response = self.fetch('/')
|
||||||
|
|
Loading…
Reference in a new issue