summary refs log blame commit diff stats
path: root/tests/async/tasyncexceptions.nim
blob: aab08e30f9f948e0b6a98c6052d5fc891b20b037 (plain) (tree)
1
2
3
4
5
6
7
8


                              
                                                 


                    
                                      


                       
                                                  








                                                                             







                            









                                                                         
discard """
  file: "tasyncexceptions.nim"
  exitcode: 1
  outputsub: "Error: unhandled exception: foobar"
"""
import asyncdispatch

proc accept(): Future[int] {.async.} =
  await sleepAsync(100)
  result = 4

proc recvLine(fd: int): Future[string] {.async.} =
  await sleepAsync(100)
  return "get"

proc processClient(fd: int) {.async.} =
  # these finish synchronously, we need some async delay to emulate this bug.
  var line = await recvLine(fd)
  var foo = line[0]
  if foo == 'g':
    raise newException(EBase, "foobar")

proc serve() {.async.} =

  while true:
    var fut = await accept()
    await processClient(fut)

when isMainModule:
  proc main =
    var fut = serve()
    fut.callback =
      proc () =
        if fut.failed:
          # This test ensures that this exception crashes the application
          # as it is not handled.
          raise fut.error
    runForever()
  main()