summary refs log tree commit diff stats
path: root/tests/async/t22210.nim
blob: fcf939472599bfaa4d5a2d08fc9409390547ffe9 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
discard """
output: '''
stage 1
stage 2
stage 3
(status: 200, data: "SOMEDATA")
'''
"""

import std/asyncdispatch


# bug #22210
type
  ClientResponse = object
    status*: int
    data*: string

proc subFoo1(): Future[int] {.async.} =
  await sleepAsync(100)
  return 200

proc subFoo2(): Future[string] {.async.} =
  await sleepAsync(100)
  return "SOMEDATA"

proc testFoo(): Future[ClientResponse] {.async.} =
  try:
    let status = await subFoo1()
    doAssert(status == 200)
    let data = await subFoo2()
    return ClientResponse(status: status, data: data)
  finally:
    echo "stage 1"
    await sleepAsync(100)
    echo "stage 2"
    await sleepAsync(200)
    echo "stage 3"

when isMainModule:
  echo waitFor testFoo()