From 147bb8758aef318315931226ac9f7727959fc0fa Mon Sep 17 00:00:00 2001 From: Julien Duponchelle Date: Tue, 23 Aug 2016 21:29:46 +0200 Subject: [PATCH] Fix log error when closing server websocket Fix #635 --- .../handlers/api/compute/notification_handler.py | 16 +++++++++++++--- .../handlers/api/controller/project_handler.py | 15 +++++++++++++-- 2 files changed, 26 insertions(+), 5 deletions(-) diff --git a/gns3server/handlers/api/compute/notification_handler.py b/gns3server/handlers/api/compute/notification_handler.py index 539d0d86..f14c75ea 100644 --- a/gns3server/handlers/api/compute/notification_handler.py +++ b/gns3server/handlers/api/compute/notification_handler.py @@ -16,14 +16,25 @@ # along with this program. If not, see . import asyncio +import aiohttp.errors from aiohttp.web import WebSocketResponse from gns3server.web.route import Route from gns3server.compute.notification_manager import NotificationManager -class NotificationHandler: +@asyncio.coroutine +def process_websocket(ws): + """ + Process ping / pong and close message + """ + try: + yield from ws.receive() + except aiohttp.errors.WSServerHandshakeError: + pass + +class NotificationHandler: @Route.get( r"/notifications/ws", description="Send notifications using Websockets") @@ -32,8 +43,7 @@ class NotificationHandler: ws = WebSocketResponse() yield from ws.prepare(request) - # Process ping / pong and close message - asyncio.async(ws.receive()) + asyncio.async(process_websocket(ws)) with notifications.queue() as queue: while True: diff --git a/gns3server/handlers/api/controller/project_handler.py b/gns3server/handlers/api/controller/project_handler.py index 914cebac..31c5e3c2 100644 --- a/gns3server/handlers/api/controller/project_handler.py +++ b/gns3server/handlers/api/controller/project_handler.py @@ -17,6 +17,7 @@ import os import aiohttp +import aiohttp.errors import asyncio import tempfile @@ -39,6 +40,17 @@ import logging log = logging.getLogger() +@asyncio.coroutine +def process_websocket(ws): + """ + Process ping / pong and close message + """ + try: + yield from ws.receive() + except aiohttp.errors.WSServerHandshakeError: + pass + + class ProjectHandler: @Route.post( @@ -238,8 +250,7 @@ class ProjectHandler: ws = aiohttp.web.WebSocketResponse() yield from ws.prepare(request) - # Process ping / pong and close message - asyncio.async(ws.receive()) + asyncio.async(process_websocket(ws)) with controller.notification.queue(project) as queue: while True: