From 43f22fb3b44584e642d2aa0dc3e09d4a6066f515 Mon Sep 17 00:00:00 2001 From: hamistao Date: Thu, 9 Jan 2025 23:48:19 -0300 Subject: [PATCH] WIP Signed-off-by: hamistao --- integration/test_containers.py | 41 +++++++++++++++++++++++++--------- pylxd/models/instance.py | 5 +++++ 2 files changed, 35 insertions(+), 11 deletions(-) diff --git a/integration/test_containers.py b/integration/test_containers.py index ca820ef4..bb9e08a9 100644 --- a/integration/test_containers.py +++ b/integration/test_containers.py @@ -158,19 +158,38 @@ def test_execute(self): def test_execute_no_buffer(self): """A command is executed on the container without buffering the output.""" - self.container.start(wait=True) - self.addCleanup(self.container.stop, wait=True) - time.sleep( - 1 - ) # Wait a little to make sure the container is ready to exec since it has just been started. - buffer = [] + while True: + self.container.start(wait=True) + self.addCleanup(self.container.stop, wait=True) + time.sleep(1) + buffer = [] - result = self.container.execute(["echo", "test"], stdout_handler=buffer.append) + result = self.container.execute(["echo", "test"], stdout_handler=buffer.append) - self.assertEqual(0, result.exit_code) - self.assertEqual("", result.stdout) - self.assertEqual("", result.stderr) - self.assertEqual("test\n", "".join(buffer)) + self.assertEqual(0, result.exit_code) + self.assertEqual("", result.stdout) + self.assertEqual("", result.stderr) + self.assertEqual("test\n", "".join(buffer)) + + self.container.stop(wait=True) + time.sleep(1) + + def test_execute_no_buffer_original(self): + """A command is executed on the container without buffering the output.""" + while True: + self.container.start(wait=True) + self.addCleanup(self.container.stop, wait=True) + buffer = [] + + result = self.container.execute(["echo", "test"], stdout_handler=buffer.append) + + self.assertEqual(0, result.exit_code) + self.assertEqual("", result.stdout) + self.assertEqual("", result.stderr) + self.assertEqual("test\n", "".join(buffer)) + + self.container.stop(wait=True) + time.sleep(1) def test_execute_no_decode(self): """A command is executed on the container that isn't utf-8 decodable""" diff --git a/pylxd/models/instance.py b/pylxd/models/instance.py index 6ace85ea..52553b74 100644 --- a/pylxd/models/instance.py +++ b/pylxd/models/instance.py @@ -519,6 +519,11 @@ def execute( manager.stop() manager.join() + print(operation.metadata) + print(operation.err) + print(stdout.data) + print(stderr.data) + return _InstanceExecuteResult( operation.metadata["return"], stdout.data, stderr.data )