require(throws:_:sourceLocation:performing:)
Check that an expression always throws an error of a given type, and throw an error if it does not.
Declaration
@discardableResult @freestanding(expression) macro require<E, R>(throws errorType: E.Type, _ comment: @autoclosure () -> Comment? = nil, sourceLocation: SourceLocation = #_sourceLocation, performing expression: () async throws -> R) -> E where E : ErrorParameters
- errorType:
The type of error that is expected to be thrown. If
expressioncould throw any error, or the specific type of thrown error is unimportant, pass(any Error).self. - comment:
A comment describing the expectation.
- sourceLocation:
The source location to which recorded expectations and issues should be attributed.
- expression:
The expression to be evaluated.
Mentioned in
Return Value
The instance of errorType that was thrown by expression.
Overview
Use this overload of #require() when the expression expression should throw an error of a given type:
try #require(throws: EngineFailureError.self) {
FoodTruck.shared.engine.batteryLevel = 0
try FoodTruck.shared.engine.start()
}If expression does not throw an error, or if it throws an error that is not an instance of errorType, an Issue is recorded for the test that is running in the current task and an instance of ExpectationFailedError is thrown. Any value returned by expression is discarded.
If the thrown error need only equal another instance of Error, use require(throws:_:sourceLocation:performing:) instead.
If expression should never throw, simply invoke the code without using this macro. The test will then fail if an error is thrown.