Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(168)

Unified Diff: tools/telemetry/telemetry/core/backends/chrome/websocket_unittest.py

Issue 258623002: Telemetry fixit: use a minimal ws server for testSockOpts. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: 0 for port Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools/telemetry/telemetry/core/backends/chrome/websocket_unittest.py
diff --git a/tools/telemetry/telemetry/core/backends/chrome/websocket_unittest.py b/tools/telemetry/telemetry/core/backends/chrome/websocket_unittest.py
index 66f79b3458c5f5f294c7ecb30f2bcd53a177380f..a49f4a5ae2d19c6d70852ecac266e6af98cc0c65 100644
--- a/tools/telemetry/telemetry/core/backends/chrome/websocket_unittest.py
+++ b/tools/telemetry/telemetry/core/backends/chrome/websocket_unittest.py
@@ -1,11 +1,36 @@
# Copyright 2013 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
+
+import base64
+import BaseHTTPServer
+import hashlib
import socket
+import threading
import unittest
+
from telemetry.core.backends.chrome import websocket
+
+# Minimal handler for a local websocket server.
+class _FakeWebSocketHandler(BaseHTTPServer.BaseHTTPRequestHandler):
+ def do_GET(self):
+ key = self.headers.getheader('Sec-WebSocket-Key')
+
+ value = key + '258EAFA5-E914-47DA-95CA-C5AB0DC85B11'
+ hashed = base64.encodestring(hashlib.sha1(value).digest()).strip().lower()
+
+ self.send_response(101)
+
+ self.send_header('Sec-Websocket-Accept', hashed)
+ self.send_header('upgrade', 'websocket')
+ self.send_header('connection', 'upgrade')
+ self.end_headers()
+
+ self.wfile.flush()
+
+
class TestWebSocket(unittest.TestCase):
def testExports(self):
self.assertNotEqual(websocket.create_connection, None)
@@ -13,11 +38,16 @@ class TestWebSocket(unittest.TestCase):
self.assertNotEqual(websocket.WebSocketTimeoutException, None)
def testSockOpts(self):
- ws = websocket.create_connection('ws://echo.websocket.org')
+ httpd = BaseHTTPServer.HTTPServer(('', 0), _FakeWebSocketHandler)
+ threading.Thread(target=httpd.handle_request).start()
+ ws_url = 'ws://127.0.0.1:%d' % httpd.server_port
+ ws = websocket.create_connection(ws_url)
self.assertNotEquals(
ws.sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR), 0)
+
+ threading.Thread(target=httpd.handle_request).start()
ws = websocket.create_connection(
- 'ws://echo.websocket.org',
+ ws_url,
sockopt=[(socket.IPPROTO_TCP, socket.TCP_NODELAY, 1)])
self.assertNotEquals(
ws.sock.getsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR), 0)
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698