mirror of
https://github.com/GNS3/gns3-server
synced 2025-01-11 16:41:04 +00:00
parent
f4f9e6eba6
commit
f35c742b07
@ -299,6 +299,11 @@ class DockerVM(BaseVM):
|
|||||||
"""Stops this Docker container."""
|
"""Stops this Docker container."""
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
if self._telnet_server:
|
||||||
|
self._telnet_server.close()
|
||||||
|
yield from self._telnet_server.wait_closed()
|
||||||
|
self._telnet_server = None
|
||||||
|
|
||||||
if self._ubridge_hypervisor and self._ubridge_hypervisor.is_running():
|
if self._ubridge_hypervisor and self._ubridge_hypervisor.is_running():
|
||||||
yield from self._ubridge_hypervisor.stop()
|
yield from self._ubridge_hypervisor.stop()
|
||||||
|
|
||||||
@ -306,10 +311,6 @@ class DockerVM(BaseVM):
|
|||||||
if state == "paused":
|
if state == "paused":
|
||||||
yield from self.unpause()
|
yield from self.unpause()
|
||||||
|
|
||||||
if self._telnet_server:
|
|
||||||
self._telnet_server.close()
|
|
||||||
self._telnet_server = None
|
|
||||||
|
|
||||||
# t=5 number of seconds to wait before killing the container
|
# t=5 number of seconds to wait before killing the container
|
||||||
try:
|
try:
|
||||||
yield from self.manager.query("POST", "containers/{}/stop".format(self._cid), params={"t": 5})
|
yield from self.manager.query("POST", "containers/{}/stop".format(self._cid), params={"t": 5})
|
||||||
|
@ -125,13 +125,14 @@ class AsyncioTelnetServer:
|
|||||||
return_when=asyncio.FIRST_COMPLETED)
|
return_when=asyncio.FIRST_COMPLETED)
|
||||||
for coro in done:
|
for coro in done:
|
||||||
data = coro.result()
|
data = coro.result()
|
||||||
|
|
||||||
|
# Console is closed
|
||||||
|
if len(data) == 0:
|
||||||
|
raise ConnectionResetError()
|
||||||
|
|
||||||
if coro == network_read:
|
if coro == network_read:
|
||||||
network_read = asyncio.async(network_reader.read(READ_SIZE))
|
network_read = asyncio.async(network_reader.read(READ_SIZE))
|
||||||
|
|
||||||
# Remote console is closed
|
|
||||||
if len(data) == 0:
|
|
||||||
raise ConnectionResetError()
|
|
||||||
|
|
||||||
if IAC in data:
|
if IAC in data:
|
||||||
data = yield from self._IAC_parser(data, network_reader, network_writer)
|
data = yield from self._IAC_parser(data, network_reader, network_writer)
|
||||||
if self._writer:
|
if self._writer:
|
||||||
|
@ -68,7 +68,6 @@ def test_start_command(vm):
|
|||||||
assert vm.start_command is None
|
assert vm.start_command is None
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def test_create(loop, project, manager):
|
def test_create(loop, project, manager):
|
||||||
|
|
||||||
response = {
|
response = {
|
||||||
|
Loading…
Reference in New Issue
Block a user