Commit f90e0e91 authored by Paul McCarthy's avatar Paul McCarthy 🚵
Browse files

TEST: py2 compat

parent be4791fa
......@@ -7,6 +7,7 @@ import os
import os.path as op
import contextlib
import threading
import multiprocessing as mp
import functools as ft
import sys
import re
......@@ -23,8 +24,8 @@ try:
except ImportError:
from StringIO import StringIO
import SimpleHTTPServer as http
import SocketServer as socksrv
http.HTTPServer = socksrv.TCPServer
http.HTTPServer = http.BaseHTTPServer.HTTPServer
http.SimpleHTTPRequestHandler.protocol_version = 'HTTP/1.0'
import mock
......@@ -50,27 +51,31 @@ def indir(dir):
class HTTPServer(threading.Thread):
class HTTPServer(mp.Process):
"""Simple HTTP server which serves files from a specified directory.
Intended to be used via the :func:`server` context manager function.
def __init__(self, rootdir):
self.daemon = True
self.rootdir = rootdir
handler = ft.partial(http.SimpleHTTPRequestHandler, directory=rootdir)
handler = http.SimpleHTTPRequestHandler
self.server = http.HTTPServer(('', 0), handler)
self.shutdown = mp.Event()
def stop(self):
def port(self):
return self.server.server_address[1]
def run(self):
with indir(self.rootdir):
while not self.shutdown.is_set():
......@@ -147,7 +152,7 @@ def mock_input(*responses):
n = next(resp)
return n
if sys.version[0] == '2': target = 'builtins.raw_input'
if sys.version[0] == '2': target = '__builtin__.raw_input'
else: target = 'builtins.input'
with mock.patch(target, _input):
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment