Chamando corotinas em asyncio.Protocol.data_received

Estou tendo um problema ao fazer coisas assíncronas noasyncio.Protocol.data_received retorno de chamada do novo Pythonassíncio módulo.

Considere o seguinte servidor:

class MathServer(asyncio.Protocol):

   @asyncio.coroutine
   def slow_sqrt(self, x):
      yield from asyncio.sleep(1)
      return math.sqrt(x)

   def fast_sqrt(self, x):
      return math.sqrt(x)

   def connection_made(self, transport):
      self.transport = transport

   #@asyncio.coroutine
   def data_received(self, data):
      print('data received: {}'.format(data.decode()))
      x = json.loads(data.decode())
      #res = self.fast_sqrt(x)
      res = yield from self.slow_sqrt(x)
      self.transport.write(json.dumps(res).encode('utf8'))
      self.transport.close()

usado com o seguinte cliente:

class MathClient(asyncio.Protocol):

   def connection_made(self, transport):
      transport.write(json.dumps(2.).encode('utf8'))

   def data_received(self, data):
      print('data received: {}'.format(data.decode()))

   def connection_lost(self, exc):
      asyncio.get_event_loop().stop()

Comself.fast_sqrt sendo chamado, tudo funciona como esperado.

Comself.slow_sqrt, não funciona.

Também não funciona comself.fast_sqrt e a@asyncio.coroutine decorador emdata_received.

Sinto que estou perdendo algo fundamental aqui.

O código completo está aqui:

ServidorCliente

Testado com:

Python 3.4.0b1 (Windows)Python 3.3.3 + asyncio-0.2.1 (FreeBSD)

O problema é o mesmo em ambos: comslow_sqrt, o cliente / servidor ficará travado sem fazer nada.

questionAnswers(1)

yourAnswerToTheQuestion