From 94cdb8269b4e5e60fb6a2f47d3d4d57e3b863c29 Mon Sep 17 00:00:00 2001 From: 1C4nfaN Date: Thu, 12 Oct 2023 22:46:22 +0800 Subject: [PATCH] chore: add unittest for oneway req --- tests/oneway.thrift | 4 ++++ tests/test_oneway.py | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 tests/oneway.thrift create mode 100644 tests/test_oneway.py diff --git a/tests/oneway.thrift b/tests/oneway.thrift new file mode 100644 index 0000000..9559431 --- /dev/null +++ b/tests/oneway.thrift @@ -0,0 +1,4 @@ +service echo +{ + oneway void Test(1: string req) +} diff --git a/tests/test_oneway.py b/tests/test_oneway.py new file mode 100644 index 0000000..bcee32e --- /dev/null +++ b/tests/test_oneway.py @@ -0,0 +1,32 @@ +import multiprocessing +import thriftpy2 +import time +from thriftpy2.rpc import make_client, make_server + + +class Dispatcher(object): + def Test(self, req): + print("Get req msg: %s" % req) + + assert req == "Hello!" + + +oneway_thrift = thriftpy2.load("oneway.thrift", module_name="oneway_thrift") +multiprocessing.set_start_method("fork") + + +class TestOneway(object): + def setup_class(self): + server = make_server(oneway_thrift.echo, Dispatcher(), '127.0.0.1', 6000) + self.p = multiprocessing.Process(target=server.serve) + self.p.start() + time.sleep(1) # Wait a second for server to start. + + def teardown_class(self): + self.p.terminate() + + def test_echo(self): + req = "Hello!" + client = make_client(oneway_thrift.echo, '127.0.0.1', 6000) + + assert client.Test(req) == None