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


                              
                                                 


                    

                                      
                                      


                       
                                                  







                                                                             
                                           







                            









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

# Note: This is a test case for a bug.

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(Exception, "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()