test-fibers-waiter-queue.scm 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. ;;; Copyright (C) 2024 Igalia, S.L.
  2. ;;;
  3. ;;; Licensed under the Apache License, Version 2.0 (the "License");
  4. ;;; you may not use this file except in compliance with the License.
  5. ;;; You may obtain a copy of the License at
  6. ;;;
  7. ;;; http://www.apache.org/licenses/LICENSE-2.0
  8. ;;;
  9. ;;; Unless required by applicable law or agreed to in writing, software
  10. ;;; distributed under the License is distributed on an "AS IS" BASIS,
  11. ;;; WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. ;;; See the License for the specific language governing permissions and
  13. ;;; limitations under the License.
  14. (use-modules (srfi srfi-64)
  15. (test utils))
  16. (test-begin "test-fibers-waiter-queue")
  17. (with-additional-imports
  18. ((fibers waiter-queue)
  19. (fibers operations)
  20. (hoot boxes))
  21. (test-call "(#f #t 42 100 #f)"
  22. (lambda ()
  23. (define (make-op-state) (make-box #f))
  24. (define wq (make-waiter-queue))
  25. (waiter-queue-push! wq (make-op-state) 42)
  26. (define state (make-op-state))
  27. (waiter-queue-push! wq state 69)
  28. (waiter-queue-push! wq state -10)
  29. (waiter-queue-push! wq (make-op-state) 100)
  30. (let* ((a (op-state-completed? state))
  31. (b (op-state-complete! state))
  32. (x (waiter-queue-pop! wq))
  33. (y (waiter-queue-pop! wq))
  34. (z (waiter-queue-pop! wq)))
  35. (list a b x y z)))))
  36. (test-end* "test-fibers-waiter-queue")