From 518b037d542a27e5eb1cb08b17e4d7a478535bd7 Mon Sep 17 00:00:00 2001 From: grossmj Date: Sun, 1 Mar 2015 14:25:09 -0700 Subject: [PATCH] Fixes connect call failed for Dynamips hypervisor #78. --- .../modules/dynamips/dynamips_hypervisor.py | 20 +++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/gns3server/modules/dynamips/dynamips_hypervisor.py b/gns3server/modules/dynamips/dynamips_hypervisor.py index 863e112a..20ab9764 100644 --- a/gns3server/modules/dynamips/dynamips_hypervisor.py +++ b/gns3server/modules/dynamips/dynamips_hypervisor.py @@ -73,12 +73,20 @@ class DynamipsHypervisor: else: host = self._host - try: - self._reader, self._writer = yield from asyncio.wait_for(asyncio.open_connection(host, self._port), timeout=self._timeout) - except OSError as e: - raise DynamipsError("Could not connect to hypervisor {}:{} {}".format(host, self._port, e)) - except asyncio.TimeoutError: - raise DynamipsError("Timeout error while connecting to hypervisor {}:{}".format(host, self._port)) + tries = 3 + while tries > 0: + try: + self._reader, self._writer = yield from asyncio.wait_for(asyncio.open_connection(host, self._port), timeout=self._timeout) + break + except OSError as e: + if tries: + tries -= 1 + log.warn("Could not connect to hypervisor {}:{} {}, retrying...".format(host, self._port, e)) + yield from asyncio.sleep(0.1) + continue + raise DynamipsError("Could not connect to hypervisor {}:{} {}".format(host, self._port, e)) + except asyncio.TimeoutError: + raise DynamipsError("Timeout error while connecting to hypervisor {}:{}".format(host, self._port)) try: version = yield from self.send("hypervisor version")