Fix closing console of VBox on NIX systems

This commit is contained in:
Julien Duponchelle 2016-11-18 11:27:50 +01:00
parent 11f290482d
commit a872f0328d
No known key found for this signature in database
GPG Key ID: CE8B29639E07F5E8
3 changed files with 25 additions and 6 deletions

View File

@ -284,7 +284,7 @@ class VirtualBoxVM(BaseNode):
self._hw_virtualization = False
yield from self._stop_ubridge()
self._stop_remote_console()
yield from self._stop_remote_console()
vm_state = yield from self._get_vm_state()
if vm_state == "running" or vm_state == "paused" or vm_state == "stuck":
if self.acpi_shutdown:
@ -312,6 +312,7 @@ class VirtualBoxVM(BaseNode):
yield from self._modify_vm("--nictrace{} off".format(adapter_number + 1))
yield from self._modify_vm("--cableconnected{} off".format(adapter_number + 1))
yield from self._modify_vm("--nic{} null".format(adapter_number + 1))
yield from super().stop()
@asyncio.coroutine
def suspend(self):
@ -898,16 +899,23 @@ class VirtualBoxVM(BaseNode):
"""
Starts remote console support for this VM.
"""
pipe = yield from asyncio_open_serial(self._get_pipe_name())
server = AsyncioTelnetServer(reader=pipe, writer=pipe, binary=True, echo=True)
self._remote_pipe = yield from asyncio_open_serial(self._get_pipe_name())
server = AsyncioTelnetServer(reader=self._remote_pipe,
writer=self._remote_pipe,
binary=True,
echo=True)
self._telnet_server = yield from asyncio.start_server(server.run, '127.0.0.1', self.console)
@asyncio.coroutine
def _stop_remote_console(self):
"""
Stops remote console support for this VM.
"""
if self._telnet_server:
self._telnet_server.close()
yield from self._telnet_server.wait_closed()
self._remote_pipe.close()
self._telnet_server = None
@asyncio.coroutine
def adapter_add_nio_binding(self, adapter_number, nio):

View File

@ -460,7 +460,7 @@ class VMwareVM(BaseNode):
"""
self._hw_virtualization = False
self._stop_remote_console()
yield from self._stop_remote_console()
yield from self._stop_ubridge()
try:
@ -495,6 +495,7 @@ class VMwareVM(BaseNode):
self._vmx_pairs["ethernet{}.startconnected".format(adapter_number)] = "TRUE"
self._write_vmx_file()
yield from super().stop()
log.info("VMware VM '{name}' [{id}] stopped".format(name=self.name, id=self.id))
@asyncio.coroutine
@ -799,16 +800,23 @@ class VMwareVM(BaseNode):
"""
Starts remote console support for this VM.
"""
pipe = yield from asyncio_open_serial(self._get_pipe_name())
server = AsyncioTelnetServer(reader=pipe, writer=pipe, binary=True, echo=True)
self._remote_pipe = yield from asyncio_open_serial(self._get_pipe_name())
server = AsyncioTelnetServer(reader=self._remote_pipe,
writer=self._remote_pipe,
binary=True,
echo=True)
self._telnet_server = yield from asyncio.start_server(server.run, '127.0.0.1', self.console)
@asyncio.coroutine
def _stop_remote_console(self):
"""
Stops remote console support for this VM.
"""
if self._telnet_server:
self._telnet_server.close()
yield from self._telnet_server.wait_closed()
self._remote_pipe.close()
self._telnet_server = None
@asyncio.coroutine
def start_capture(self, adapter_number, output_file):

View File

@ -56,6 +56,9 @@ class SerialReaderWriterProtocol(asyncio.Protocol):
def data_received(self, data):
self._output.feed_data(data)
def close(self):
self._output.feed_eof()
class WindowsPipe:
"""