All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.io.kotest.assertions.throwables.AnyThrowableHandling.kt Maven / Gradle / Ivy

package io.kotest.assertions.throwables

import io.kotest.assertions.AssertionCounter
import io.kotest.assertions.failure

/**
 * Verifies that a block of code throws any [Throwable]
 *
 * Use function to wrap a block of code that you want to verify that throws any kind of [Throwable], where using
 * [shouldThrowAny] can't be used for any reason, such as an assignment of a variable (assignments are statements,
 * therefore has no return value).
 *
 * If you want to verify a specific [Throwable], use [shouldThrowExactlyUnit].
 *
 * If you want to verify a [Throwable] and any subclass, use [shouldThrowUnit].
 *
 * @see [shouldThrowAny]
 */
inline fun shouldThrowAnyUnit(block: () -> Unit) = shouldThrowAny(block)

/**
 * Verifies that a block of code does NOT throw any [Throwable]
 *
 * Use function to wrap a block of code that you want to make sure doesn't throw any [Throwable],
 * where using [shouldNotThrowAny] can't be used for any reason, such as an assignment of a variable (assignments are
 * statements, therefore has no return value).
 *
 * Note that executing this code is no different to executing [block] itself, as any uncaught exception will
 * be propagated up anyways.
 *
 * @see [shouldNotThrowAny]
 * @see [shouldNotThrowExactlyUnit]
 * @see [shouldNotThrowUnit]
 *
 */
inline fun shouldNotThrowAnyUnit(block: () -> Unit) = shouldNotThrowAny(block)

/**
 * Verifies that a block of code throws any [Throwable]
 *
 * Use function to wrap a block of code that you want to verify that throws any kind of [Throwable].
 *
 * If you want to verify a specific [Throwable], use [shouldThrowExactly].
 *
 * If you want to verify a [Throwable] and any subclasses, use [shouldThrow]
 *
 *
 * **Attention to assignment operations:**
 *
 * When doing an assignment to a variable, the code won't compile, because an assignment is not of type [Any], as required
 * by [block]. If you need to test that an assignment throws a [Throwable], use [shouldThrowAnyUnit] or it's variations.
 *
 * ```
 *     val thrownThrowable: Throwable = shouldThrowAny {
 *         throw FooException() // This is a random Throwable, could be anything
 *     }
 * ```
 *
 * @see [shouldThrowAnyUnit]
 */
inline fun shouldThrowAny(block: () -> Any?): Throwable {
   AssertionCounter.inc()
   val thrownException = try {
      block()
      null
   } catch (e: Throwable) {
      e
   }

   return thrownException ?: throw failure("Expected a throwable, but nothing was thrown.")
}


/**
 * Verifies that a block of code does NOT throw any [Throwable]
 *
 * Use function to wrap a block of code that you want to make sure doesn't throw any [Throwable].
 *
 * Note that executing this code is no different to executing [block] itself, as any uncaught exception will
 * be propagated up anyways.
 *
 * **Attention to assignment operations:**
 *
 * When doing an assignment to a variable, the code won't compile, because an assignment is not of type [Any], as required
 * by [block]. If you need to test that an assignment doesn't throw a [Throwable], use [shouldNotThrowAnyUnit] or it's
 * variations.
 *
 * @see [shouldNotThrowAnyUnit]
 * @see [shouldNotThrowExactly]
 * @see [shouldNotThrow]
 *
 */
inline fun  shouldNotThrowAny(block: () -> T): T {
   AssertionCounter.inc()

   val thrownException = try {
      return block()
   } catch (e: Throwable) {
      e
   }

   throw failure(
      "No exception expected, but a ${thrownException::class.simpleName} was thrown.",
      thrownException
   )
}


/**
 * Verifies that a block of code throws any [Throwable] with given [message].
 *
 * @see [shouldNotThrowMessage]
 * */
inline fun  shouldThrowMessage(message: String, block: () -> T) {
   AssertionCounter.inc()

   val thrownException = try {
      block()
      null
   } catch (e: Throwable) {
      e
   }

   thrownException ?: throw failure(
      """Expected a throwable with message: $message,
                                                |but nothing was thrown""".trimMargin()
   )

   if (thrownException.message != message) {
      throw failure(
         """Expected a throwable with message: $message,
                                |but got a throwable with message: ${thrownException.message}""".trimMargin(),
         thrownException
      )
   }
}

/**
 * Verifies that a block of code does not throws any [Throwable] with given [message].
* */
inline fun  shouldNotThrowMessage(message: String, block: () -> T) {
   AssertionCounter.inc()

   val thrownException = try {
      block()
      null
   } catch (e: Throwable) {
      e
   }

   if (thrownException != null && thrownException.message == message)
      throw failure(
         """Expected no exception with message: "$message"
                          |but a ${thrownException::class.simpleName} was thrown with given message""".trimMargin(),
         thrownException
      )

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy