File: Runner.RuntimeStateTests.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (45 lines) | stat: -rw-r--r-- 1,841 bytes parent folder | download
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
42
43
44
45
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2023 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for Swift project authors
//

@testable @_spi(ForToolsIntegrationOnly) import Testing

@Suite("Runner.RuntimeState Tests")
struct Runner_RuntimeStateTests {
  // This confirms that the `eventHandler` of a nested runner's configuration
  // has the runtime state of the "outer" runner, so that task local data is
  // handled appropriately.
  @Test func runnerStateScopedEventHandler() async {
    var configuration = Configuration()
    configuration.eventHandler = { _, _ in
      // Inside this event handler, the current Test should be the outer `@Test`
      // function, not the temporary `Test` created below.
      #expect(Test.current?.name == "runnerStateScopedEventHandler()")
    }

    await Test(name: "foo") {}.run(configuration: configuration)
  }

  // This confirms that an event posted within the closure of `withTaskGroup`
  // (and similar APIs) in regular tests (those which are not testing the
  // testing library itself) are handled appropriately and do not crash.
  @Test func eventPostingInTaskGroup() async {
    // Enable delivery of "expectation checked" events, merely as a way to allow
    // an event to be posted during the test below without causing any real
    // issues to be recorded or otherwise confuse the testing harness.
    var configuration = Configuration.current ?? .init()
    configuration.deliverExpectationCheckedEvents = true

    await Configuration.withCurrent(configuration) {
      await withTaskGroup(of: Void.self) { group in
        #expect(Bool(true))
      }
    }
  }
}