-
Notifications
You must be signed in to change notification settings - Fork 43
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Question / feature request: using truesocket recording mode for an in-process HTTP server #198
Comments
Yes, please share a snippet of code and I'll have a look at it. |
Thank you. Here is a sample that recreates the situation: # Sample code derived from: https://docs.python.org/3/library/http.server.html#http.server.SimpleHTTPRequestHandler and sphinx: https://github.com/sphinx-doc/sphinx.git
from contextlib import contextmanager
from http.server import SimpleHTTPRequestHandler, ThreadingHTTPServer
import mocket
from threading import Thread
from tempfile import mkdtemp
from urllib.request import urlopen
class RedirectHandler(SimpleHTTPRequestHandler):
protocol_version = "HTTP/1.1"
def do_GET(self):
if self.path == "/origin":
self.send_response(302, "Found")
self.send_header("Location", "http://127.0.0.1:8000/destination")
self.end_headers()
if self.path == "/destination":
self.send_response(200, "OK")
self.end_headers()
class RedirectServer(Thread):
def __init__(self):
super().__init__()
self.server = ThreadingHTTPServer(("127.0.0.1", 8000), RedirectHandler)
def run(self):
self.server.serve_forever(poll_interval=0.001)
def close(self):
self.server.shutdown()
@contextmanager
def redirect_server():
server = RedirectServer()
server.start()
try:
yield server
finally:
server.close()
with mocket.Mocketizer(truesocket_recording_dir=mkdtemp()):
with redirect_server():
urlopen("http://127.0.0.1:8000/origin") |
The first problem I see is that your are spawning your server while already inside After I fixed that, I got a:
and that's what I am trying to investigate now. |
My bad, that was a rookie mistake. What I get instead is that the client gets stuck on:
|
I've never felt like I completely understand socket-based programming (to the level of intuitively knowing how to write socket-based communication code), but what I remember is that although each socket can operate like a peer, generally a socket will self-categorize as either a 'server' or 'client' type of socket during initialization: the former will always (I also forget why My guess here is that we only want |
I don't think there is a procedural way to distinguish between a client and a server socket, apart from when it starts to use its primitives. Also, servers use both server and client sockets.
See the examples from https://docs.python.org/3/howto/sockets.html#creating-a-socket |
@mindflayer is that enough evidence to prove this feature request invalid? (I think that it's ok - maybe good - if it is) |
After attempting an implementation here (essentially: a lot of I've also added some debug If I read the code and behaviour correctly: the |
I'll try to spend a bit more time on it. No reason for closing it as invalid. |
Hi again @mindflayer - thanks for your responses in sphinx-doc/sphinx#11324.
To recap (and for future readers): the improvement requested in that issue is to allow Sphinx to use session-based (pooled) HTTP requests instead of creating one TCP connection per request when it checks documentation hyperlinks. While investigating how to add tests for an implementation of that, I discovered
mocket
.It turned out that
mocket
wasn't applicable for the implementation I attempted, because I wanted to retain both the test HTTP server and test HTTP client. In that plan, measurement of actual traffic from client to server was required, instead of whatmocket
generally provides: mocking of the server's responses (useful -- and in fact preferable -- in many other situations).With that explained, the question / feature request is:
Would it be possible for
mocket
's recording mode to support a socket server that is in the same Python process as the socket client?If helpful: I can provide example code that I've attempted this with, and the error output(s) that I've encountered. But I think I should ask the feasibility question first.
The text was updated successfully, but these errors were encountered: