summary refs log blame commit diff stats
path: root/tests/coroutines/titerators.nim
blob: d12a5debec90782c1d299e8f2b3a4a0589281ed3 (plain) (tree)
1
2
3
4
5
6
7

             
              

   

                                                  




                              
                                







                                                  
                  




                                      
 
                                      

                                                                                                        
discard """
  target: "c"
disabled: true
"""

# Timers are always flakey on the testing servers.

import coro
include system/timers

var
  stackCheckValue = 1100220033
  numbers = newSeqOfCap[int](10)

iterator theIterator(id: int, sleep: float): int =
  for i in 0..<5:
    yield 10 * id + i
    suspend(sleep)

proc theCoroutine(id: int, sleep: float32) =
  for n in theIterator(id, sleep):
    numbers.add(n)

var start = getTicks()
start(proc() = theCoroutine(1, 0.01))
start(proc() = theCoroutine(2, 0.011))
run()

var executionTime = getTicks() - start
doAssert(stackCheckValue == 1100220033, "Thread stack got corrupted")
doAssert(numbers == @[10, 20, 11, 21, 12, 22, 13, 23, 14, 24], "Coroutines executed in incorrect order")