diff --git a/.github/CONTRIBUTING.md b/.github/CONTRIBUTING.md index 25c4c4424c..f2b8177b1c 100644 --- a/.github/CONTRIBUTING.md +++ b/.github/CONTRIBUTING.md @@ -12,7 +12,7 @@ Following a few guidelines so that others can quickly benefit from your contribu ## Code of Conduct This project and everyone participating in it is governed by Atrium's -[Code of Conduct](https://github.com/robstoll/atrium/tree/main/.github/CODE_OF_CONDUCT.md). +[Code of Conduct](https://github.com/robstoll/atrium/tree/v1.2.0/.github/CODE_OF_CONDUCT.md). By participating, you are expected to uphold this code. Please report unacceptable behaviour to info@tutteli.ch ## How to Contribute diff --git a/README.md b/README.md index 6753adca3e..202c154def 100644 --- a/README.md +++ b/README.md @@ -1,20 +1,20 @@ - -[![Download](https://img.shields.io/badge/Download-1.1.0-%23007ec6)](https://search.maven.org/artifact/ch.tutteli.atrium/atrium-fluent/1.1.0/jar) + - + # Atrium Atrium is an open-source multiplatform expectation/assertion library for Kotlin with support for JVM, JS and Android. @@ -28,11 +28,11 @@ or even replace core components with your own implementation easily. See [Examples](#examples) below to get a feel for how you could benefit from Atrium. ---- + **Table of Content** - [Installation](#installation) @@ -102,7 +102,7 @@ repositories { mavenCentral() } dependencies { - testImplementation("ch.tutteli.atrium:atrium-fluent:1.1.0") + testImplementation("ch.tutteli.atrium:atrium-fluent:1.2.0") } ``` @@ -114,7 +114,7 @@ repositories { kotlin { sourceSets { val commonTest by getting { - implementation("ch.tutteli.atrium:atrium-fluent:1.1.0") + implementation("ch.tutteli.atrium:atrium-fluent:1.2.0") } // no need to add it to specific targets such as jvmTest, is done automatically starting with Kotlin 1.5 } @@ -139,11 +139,11 @@ In case you use a version prior to Kotlin 1.5, then use the following depending
-I use JS IR but Atrium 1.1.0 was built with LEGACY +I use JS IR but Atrium 1.2.0 was built with LEGACY Atrium will support JS IR with v1.2.0 where we drop Kotlin 1.3 support entirely. -In the meantime you can use the special version: 1.1.0-IR-alpha. See https://github.com/robstoll/atrium/releases/tag/v1.1.0-IR-alpha +In the meantime you can use the special version: 1.2.0-IR-alpha. See https://github.com/robstoll/atrium/releases/tag/v1.2.0-IR-alpha for further information
@@ -158,25 +158,25 @@ Following extensions are maintained outside of this repository. ## Sample Projects -Have a look into the [samples](https://github.com/robstoll/atrium/tree/main/samples) +Have a look into the [samples](https://github.com/robstoll/atrium/tree/v1.2.0/samples) folder, it currently contains sample projects for -- [js - kotlin-test](https://github.com/robstoll/atrium/tree/main/samples/js/kotlin-test) -- [jvm -- junit5](https://github.com/robstoll/atrium/tree/main/samples/jvm/junit5) -- [jvm -- spek](https://github.com/robstoll/atrium/tree/main/samples/jvm/spel) -- [jvm -- maven](https://github.com/robstoll/atrium/tree/main/samples/jvm/maven/) -- [jvm -- kotest](https://github.com/robstoll/atrium/tree/main/samples/jvm/kotest) -- [jvm -- TestNG](https://github.com/robstoll/atrium/tree/main/samples/jvm/testng) -- [multiplatform project](https://github.com/robstoll/atrium/tree/main/samples/multiplatform/) +- [js - kotlin-test](https://github.com/robstoll/atrium/tree/v1.2.0/samples/js/kotlin-test) +- [jvm -- junit5](https://github.com/robstoll/atrium/tree/v1.2.0/samples/jvm/junit5) +- [jvm -- spek](https://github.com/robstoll/atrium/tree/v1.2.0/samples/jvm/spel) +- [jvm -- maven](https://github.com/robstoll/atrium/tree/v1.2.0/samples/jvm/maven/) +- [jvm -- kotest](https://github.com/robstoll/atrium/tree/v1.2.0/samples/jvm/kotest) +- [jvm -- TestNG](https://github.com/robstoll/atrium/tree/v1.2.0/samples/jvm/testng) +- [multiplatform project](https://github.com/robstoll/atrium/tree/v1.2.0/samples/multiplatform/) Are you using a different runner? A PR would be appreciated 😊. # Examples We are using the API provided by the bundle module -[atrium-fluent](https://github.com/robstoll/atrium/tree/main/bundles/fluent/atrium-fluent/build.gradle.kts) +[atrium-fluent](https://github.com/robstoll/atrium/tree/v1.2.0/bundles/fluent/atrium-fluent/build.gradle.kts) in the following examples. It provides a pure fluent API for the JVM platform. Have a look at -[apis/differences.md](https://github.com/robstoll/atrium/tree/main/apis/differences.md) +[apis/differences.md](https://github.com/robstoll/atrium/tree/v1.2.0/apis/differences.md) to see how the infix API looks like, how they differ respectively. ## Your First Expectation @@ -193,7 +193,7 @@ import ch.tutteli.atrium.logic._logic val x = 10 expect(x).toEqual(9) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FirstExampleSpec.kt#L31) ↓ [Output](#ex-first) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FirstExampleSpec.kt#L31) ↓ [Output](#ex-first) ```text I expected subject: 10 (kotlin.Int <1234789>) @@ -208,7 +208,7 @@ where on the first line the actual subject (`10` in the above example) is shown In this sense the report can be read as `I expected the subject of the expectation, which was 10, to equal 9` -- and needlessly to say, this expectation was not met and thus the thrown error. -We are using the bundle [atrium-fluent](https://github.com/robstoll/atrium/tree/main/bundles/fluent/atrium-fluent/build.gradle) +We are using the bundle [atrium-fluent](https://github.com/robstoll/atrium/tree/v1.2.0/bundles/fluent/atrium-fluent/build.gradle) and the predefined expectation verb `expect` in the examples. Thus, the corresponding `import`s at the beginning of the file in the above example. We will omit the `import` statements in the remaining examples for brevity. @@ -225,7 +225,7 @@ The next section shows how you can define multiple expectations for the same sub // two single expectations, only first evaluated expect(4 + 6).toBeLessThan(5).toBeGreaterThan(10) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L24) ↓ [Output](#ex-single) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L24) ↓ [Output](#ex-single) ```text I expected subject: 10 (kotlin.Int <1234789>) @@ -263,7 +263,7 @@ expect(4 + 6) { toBeGreaterThan(10) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L40) ↓ [Output](#ex-group) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L40) ↓ [Output](#ex-group) ```text I expected subject: 10 (kotlin.Int <1234789>) @@ -360,7 +360,7 @@ expect { throw IllegalArgumentException("name is empty") }.toThrow() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L64) ↓ [Output](#ex-toThrow1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L64) ↓ [Output](#ex-toThrow1) ```text I expected subject: () -> kotlin.Nothing (readme.examples.MostExamplesSpec$1$5$1 <1234789>) @@ -399,7 +399,7 @@ expect { message { toStartWith("firstName") } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L71) ↓ [Output](#ex-toThrow2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L71) ↓ [Output](#ex-toThrow2) ```text I expected subject: () -> kotlin.Nothing (readme.examples.MostExamplesSpec$1$6$1 <1234789>) @@ -420,7 +420,7 @@ expect { throw IllegalArgumentException() }.toThrow().message.toStartWith("firstName") ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L79) ↓ [Output](#ex-toThrow3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L79) ↓ [Output](#ex-toThrow3) ```text I expected subject: () -> kotlin.Nothing (readme.examples.MostExamplesSpec$1$7$1 <1234789>) @@ -443,7 +443,7 @@ expect { throw IllegalArgumentException("name is empty", RuntimeException("a cause")) }.notToThrow() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L85) ↓ [Output](#ex-notToThrow) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L85) ↓ [Output](#ex-notToThrow) ```text I expected subject: () -> kotlin.Nothing (readme.examples.MostExamplesSpec$1$8$1 <1234789>) @@ -464,7 +464,7 @@ I expected subject: () -> kotlin.Nothing (readme.examples.MostExamplesSpe Notice that stacks are filtered so that you only see what is of interest. You can [use your own](#use-own-components) -[AtriumErrorAdjuster](https://docs.atriumlib.org/latest#/kdoc/atrium-core/ch.tutteli.atrium.reporting/-atrium-error-adjuster) +[AtriumErrorAdjuster](https://docs.atriumlib.org/1.2.0/kdoc/atrium-core/ch.tutteli.atrium.reporting/-atrium-error-adjuster) to adjust the filtering. Stack frames of Atrium and of test runners (Spek, Kotest, TestNG, and JUnit for JVM, mocha and jasmine for JS) are excluded per default. [Create a Feature Request](https://github.com/robstoll/atrium/issues/new?template=feature_request.md&title=[Feature]) @@ -511,7 +511,7 @@ expect(myPerson) .its { fullName() } // not evaluated anymore, subject String afterwards .toStartWith("rob") // not evaluated anymore ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L41) ↓ [Output](#ex-its-single) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L41) ↓ [Output](#ex-its-single) ```text I expected subject: Person(firstName=Robert, lastName=Stoll, isStudent=false) (readme.examples.FeatureExtractorSpec$1$Person <1234789>) @@ -556,7 +556,7 @@ Feature extractors follow the common pattern of having two overloads: its { lastName }.toEqual("Dummy") } ``` - ↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L49) ↓ [Output](#ex-its-group) + ↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L49) ↓ [Output](#ex-its-group) ```text I expected subject: Person(firstName=Robert, lastName=Stoll, isStudent=false) (readme.examples.FeatureExtractorSpec$1$Person <1234789>) @@ -584,7 +584,7 @@ expect(myPerson) .feature { f(it::fullName) } // not evaluated anymore, subject String afterwards .toStartWith("rob") // not evaluated anymore ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L63) ↓ [Output](#ex-property-methods-single) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L63) ↓ [Output](#ex-property-methods-single) ```text I expected subject: Person(firstName=Robert, lastName=Stoll, isStudent=false) (readme.examples.FeatureExtractorSpec$1$Person <1234789>) @@ -627,7 +627,7 @@ expect(myPerson) { // forms an expectation-group feature { f(it::lastName) }.toEqual("Dummy") } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L71) ↓ [Output](#ex-property-methods-group) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L71) ↓ [Output](#ex-property-methods-group) ```text I expected subject: Person(firstName=Robert, lastName=Stoll, isStudent=false) (readme.examples.FeatureExtractorSpec$1$Person <1234789>) @@ -676,7 +676,7 @@ expect(myPerson) .toEqual("Robert aka. Stoll") // fails .toStartWith("llotS") // not evaluated anymore ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L85) ↓ [Output](#ex-methods-args) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L85) ↓ [Output](#ex-methods-args) ```text I expected subject: Person(firstName=Robert, lastName=Stoll, isStudent=false) (readme.examples.FeatureExtractorSpec$1$Person <1234789>) @@ -696,7 +696,7 @@ in case you miss a shortcut. πŸ’¬ Write own feature extractors with additional checks. Atrium provides a feature extractor which allows to extract in a safe way in case the extraction is only valid for certain subjects. -It is inter alia used for [`List.get`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultListAssertions.kt#L13) +It is inter alia used for [`List.get`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultListAssertions.kt#L13) @@ -718,7 +718,7 @@ expect(myFamily) .feature("the first member's name") { members.first().name } // subject narrowed to String .toEqual("Peter") ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L102) ↓ [Output](#ex-arbitrary-features) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L102) ↓ [Output](#ex-arbitrary-features) ```text I expected subject: Family(members=[FamilyMember(name=Robert)]) (readme.examples.FeatureExtractorSpec$1$Family <1234789>) @@ -766,7 +766,7 @@ expect(listOf(1 to "a", 2 to "b")).get(10) { firstToBe(1) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L118) ↓ [Output](#ex-within-expectation-functions) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/FeatureExtractorSpec.kt#L118) ↓ [Output](#ex-within-expectation-functions) ```text I expected subject: [(1, a), (2, b)] (java.util.Arrays.ArrayList <1234789>) @@ -886,7 +886,7 @@ expect(x).toBeAnInstanceOf { feature { f(it::flag) }.toEqual(false) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L92) ↓ [Output](#ex-type-expectations-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L92) ↓ [Output](#ex-type-expectations-1) ```text I expected subject: SubType2(word=hello, flag=true) (readme.examples.SubType2 <1234789>) @@ -910,7 +910,7 @@ expect(x).toBeAnInstanceOf() .feature { f(it::number) } .toEqual(2) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L99) ↓ [Output](#ex-type-expectations-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L99) ↓ [Output](#ex-type-expectations-2) ```text I expected subject: SubType2(word=hello, flag=true) (readme.examples.SubType2 <1234789>) @@ -940,7 +940,7 @@ Let us look at the case where the subject of the expectation has a [nullable typ val slogan1: String? = "postulating expectations made easy" expect(slogan1).toEqual(null) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L106) ↓ [Output](#ex-nullable-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L106) ↓ [Output](#ex-nullable-1) ```text I expected subject: "postulating expectations made easy" <1234789> @@ -954,7 +954,7 @@ I expected subject: "postulating expectations made easy" <1234789> val slogan2: String? = null expect(slogan2).toEqual("postulating expectations made easy") ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L110) ↓ [Output](#ex-nullable-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L110) ↓ [Output](#ex-nullable-2) ```text I expected subject: null @@ -975,7 +975,7 @@ expect(slogan2) // subject has type String? .notToEqualNull() // subject is narrowed to String .toStartWith("atrium") ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L115) ↓ [Output](#ex-nullable-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L115) ↓ [Output](#ex-nullable-3) ```text I expected subject: null @@ -992,7 +992,7 @@ one without (example above) and one with `assertionCreator`-lambda (example belo ```kotlin expect(slogan2).notToEqualNull { toStartWith("atrium") } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L120) ↓ [Output](#ex-nullable-4) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L120) ↓ [Output](#ex-nullable-4) ```text I expected subject: null @@ -1034,7 +1034,7 @@ for further examples. ```kotlin expect(listOf(1, 2, 2, 4)).toContain(2, 3) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L124) ↓ [Output](#ex-collection-short-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L124) ↓ [Output](#ex-collection-short-1) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1072,7 +1072,7 @@ expect(listOf(1, 2, 2, 4)).toContain( { toBeGreaterThan(2).toBeLessThan(4) } ) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L128) ↓ [Output](#ex-collection-short-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L128) ↓ [Output](#ex-collection-short-2) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1114,7 +1114,7 @@ expect(listOf(1, 2, 3, 4)).toHaveElementsAndAny { toBeLessThan(0) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L135) ↓ [Output](#ex-collection-any) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L135) ↓ [Output](#ex-collection-any) ```text I expected subject: [1, 2, 3, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1132,7 +1132,7 @@ expect(listOf(1, 2, 3, 4)).toHaveElementsAndNone { toBeGreaterThan(2) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L140) ↓ [Output](#ex-collection-none) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L140) ↓ [Output](#ex-collection-none) ```text I expected subject: [1, 2, 3, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1152,7 +1152,7 @@ expect(listOf(1, 2, 3, 4)).toHaveElementsAndAll { toBeGreaterThan(2) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L145) ↓ [Output](#ex-collection-all) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L145) ↓ [Output](#ex-collection-all) ```text I expected subject: [1, 2, 3, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1182,7 +1182,7 @@ Following on the last section we will start with an `inOrder` example: ```kotlin expect(listOf(1, 2, 2, 4)).toContain.inOrder.only.entries({ toBeLessThan(3) }, { toBeLessThan(2) }) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L151) ↓ [Output](#ex-collection-builder-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L151) ↓ [Output](#ex-collection-builder-1) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1228,7 +1228,7 @@ expect(listOf(1, 2, 2, 4)).toContainExactly( report = { showOnlyFailingIfMoreExpectedElementsThan(2) } ) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L154) ↓ [Output](#ex-collection-reportOptions-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L154) ↓ [Output](#ex-collection-reportOptions-1) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1259,7 +1259,7 @@ and we happily answer your question there. ```kotlin expect(listOf(1, 2, 2, 4)).toContain.inOrder.only.values(1, 2, 2, 3, 4) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L162) ↓ [Output](#ex-collection-builder-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L162) ↓ [Output](#ex-collection-builder-2) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1284,7 +1284,7 @@ I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) ```kotlin expect(listOf(1, 2, 2, 4)).toContain.inAnyOrder.atLeast(1).butAtMost(2).entries({ toBeLessThan(3) }) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L165) ↓ [Output](#ex-collection-builder-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L165) ↓ [Output](#ex-collection-builder-3) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1301,7 +1301,7 @@ I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) ```kotlin expect(listOf(1, 2, 2, 4)).toContain.inAnyOrder.only.values(1, 2, 3, 4) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L168) ↓ [Output](#ex-collection-builder-4) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L168) ↓ [Output](#ex-collection-builder-4) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1320,7 +1320,7 @@ I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) ```kotlin expect(listOf(1, 2, 2, 4)).toContain.inAnyOrder.only.values(4, 3, 2, 2, 1) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L171) ↓ [Output](#ex-collection-builder-5) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L171) ↓ [Output](#ex-collection-builder-5) ```text I expected subject: [1, 2, 2, 4] (java.util.Arrays.ArrayList <1234789>) @@ -1354,7 +1354,7 @@ for further examples. ```kotlin expect(mapOf("a" to 1, "b" to 2)).toContain("c" to 2, "a" to 1, "b" to 1) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L175) ↓ [Output](#ex-map-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L175) ↓ [Output](#ex-map-1) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1378,7 +1378,7 @@ expect(mapOf("a" to 1, "b" to 2)).toContain( KeyValue("b") { toBeLessThan(2) } ) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L178) ↓ [Output](#ex-map-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L178) ↓ [Output](#ex-map-2) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1400,7 +1400,7 @@ Again both overloads are provided, one for key-value `Pair`s: ```kotlin expect(mapOf("a" to 1, "b" to 2)).toContainOnly("b" to 2) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L186) ↓ [Output](#ex-map-only-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L186) ↓ [Output](#ex-map-only-1) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1425,7 +1425,7 @@ expect(mapOf("a" to 1, "b" to 2)).toContainOnly( KeyValue("b") { toBeLessThan(2) } ) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L189) ↓ [Output](#ex-map-only-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L189) ↓ [Output](#ex-map-only-2) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1453,7 +1453,7 @@ again provide two overloads, one expecting key-value `Pair`s: ```kotlin expect(mapOf("a" to 1, "b" to 2)).toContain.inOrder.only.entries("b" to 2, "a" to 1) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L197) ↓ [Output](#ex-map-builder-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L197) ↓ [Output](#ex-map-builder-1) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1480,7 +1480,7 @@ expect(mapOf("a" to 1, "b" to 2)).toContain.inOrder.only.entries( KeyValue("a") { toBeLessThan(2) }, KeyValue("b") { toBeLessThan(2) }) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L200) ↓ [Output](#ex-map-builder-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L200) ↓ [Output](#ex-map-builder-2) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1517,7 +1517,7 @@ expect(mapOf("bernstein" to bernstein)) feature { f(it::firstName) }.toEqual("Albert") } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L210) ↓ [Output](#ex-map-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L210) ↓ [Output](#ex-map-3) ```text I expected subject: {bernstein=Person(firstName=Leonard, lastName=Bernstein, age=50)} (java.util.Collections.SingletonMap <1234789>) @@ -1537,7 +1537,7 @@ expect(mapOf("a" to 1, "b" to 2)) { values { toHaveElementsAndNone { toBeGreaterThan(1) } } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L222) ↓ [Output](#ex-map-4) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L222) ↓ [Output](#ex-map-4) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1573,7 +1573,7 @@ expect(linkedMapOf("a" to 1, "b" to 2)).asEntries().toContain.inOrder.only.entri } ) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L228) ↓ [Output](#ex-map-5) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L228) ↓ [Output](#ex-map-5) ```text I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) @@ -1594,7 +1594,7 @@ I expected subject: {a=1, b=2} (java.util.LinkedHashMap <1234789>) `toEqualKeyValue` as well as `key` and `value` are expectation functions defined for `Map.Entry`. There are more expectation functions, a full list can be found in -[KDoc of atrium-api-fluent](https://docs.atriumlib.org/latest#/kdoc/atrium-api-fluent). +[KDoc of atrium-api-fluent](https://docs.atriumlib.org/1.2.0/kdoc/atrium-api-fluent). ## Path Expectations See also @@ -1611,7 +1611,7 @@ For example, `toExist` will explain which entry was the first one missing: ```kotlin expect(Paths.get("/usr/bin/noprogram")).toExist() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/PathSpec.kt#L37) ↓ [Output](#ex-path-exists) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/PathSpec.kt#L37) ↓ [Output](#ex-path-exists) ```text I expected subject: /usr/bin/noprogram (sun.nio.fs.UnixPath <1234789>) @@ -1627,7 +1627,7 @@ Atrium will give details about why something cannot be accessed, for example whe ```kotlin expect(Paths.get("/root/.ssh/config")).toBeWritable() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/PathSpec.kt#L41) ↓ [Output](#ex-path-writable) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/PathSpec.kt#L41) ↓ [Output](#ex-path-writable) ```text I expected subject: /root/.ssh/config (sun.nio.fs.UnixPath <1234789>) @@ -1650,7 +1650,7 @@ val filePointer = Files.createSymbolicLink(directory.resolve("directory"), file) expect(filePointer.resolve("subfolder/file")).toBeARegularFile() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/PathSpec.kt#L46) ↓ [Output](#ex-path-symlink-and-parent-not-folder) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/PathSpec.kt#L46) ↓ [Output](#ex-path-symlink-and-parent-not-folder) ```text I expected subject: /tmp/atrium-path/directory/subfolder/file (sun.nio.fs.UnixPath <1234789>) @@ -1674,7 +1674,7 @@ expect("filename?") notToContain("?") } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L238) ↓ [Output](#ex-because-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L238) ↓ [Output](#ex-because-1) ```text I expected subject: "filename?" <1234789> @@ -1735,7 +1735,7 @@ expect(listOf(1, 2, 3, -1)).toHaveElementsAndAll { } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L33) ↓ [Output](#ex-third-party-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L33) ↓ [Output](#ex-third-party-1) ```text I expected subject: [1, 2, 3, -1] (java.util.Arrays.ArrayList <1234789>) @@ -1768,7 +1768,7 @@ fun Expect.notToBeNegative() = expect(-10).notToBeNegative() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L42) ↓ [Output](#ex-third-party-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L42) ↓ [Output](#ex-third-party-2) ```text I expected subject: -10 (kotlin.Int <1234789>) @@ -1813,7 +1813,7 @@ fun Expect.notToBeNegative() = expect(-10).notToBeNegative() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L59) ↓ [Output](#ex-third-party-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L59) ↓ [Output](#ex-third-party-3) ```text I expected subject: -10 (kotlin.Int <1234789>) @@ -1853,7 +1853,7 @@ expectGrouped { } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L29) ↓ [Output](#ex-data-driven-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L29) ↓ [Output](#ex-data-driven-1) ```text my expectations: @@ -1896,7 +1896,7 @@ expectGrouped { } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L45) ↓ [Output](#ex-data-driven-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L45) ↓ [Output](#ex-data-driven-2) ```text my expectations: @@ -1941,7 +1941,7 @@ expectGrouped { } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L82) ↓ [Output](#ex-data-driven-nesting) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L82) ↓ [Output](#ex-data-driven-nesting) ```text my expectations: @@ -1988,7 +1988,7 @@ expectGrouped { } } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L63) ↓ [Output](#ex-data-driven-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/DataDrivenSpec.kt#L63) ↓ [Output](#ex-data-driven-3) ```text my expectations: @@ -2010,11 +2010,11 @@ as well as expectation functions which have not been shown in the examples above Take a look at the sample files which are used i.a. in the KDOC of the corresponding expectation functions: -- [Samples api-fluent common](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) -- [Samples api-fluent jvm](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) +- [Samples api-fluent common](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) +- [Samples api-fluent jvm](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) -+ [Samples api-infix common](https://github.com/robstoll/atrium/tree/main/apis/infix/atrium-api-infix/src/commonTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) -+ [Samples api-infix jvm](https://github.com/robstoll/atrium/tree/main/apis/infix/atrium-api-infix/src/jvmTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) ++ [Samples api-infix common](https://github.com/robstoll/atrium/tree/v1.2.0/apis/infix/atrium-api-infix/src/commonTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) ++ [Samples api-infix jvm](https://github.com/robstoll/atrium/tree/v1.2.0/apis/infix/atrium-api-infix/src/jvmTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) # How is Atrium different from other Expectation/Assertion Libraries @@ -2107,7 +2107,7 @@ expect { } }.toThrow { messageToContain("no no no") } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L251) ↓ [Output](#ex-add-info-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L251) ↓ [Output](#ex-add-info-3) ```text I expected subject: () -> kotlin.Nothing (readme.examples.MostExamplesSpec$1$38$1 <1234789>) @@ -2149,7 +2149,7 @@ then Atrium reminds us of the possible pitfall. For instance: ```kotlin expect(BigDecimal.TEN).toEqualIncludingScale(BigDecimal("10.0")) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L261) ↓ [Output](#ex-pitfall-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L261) ↓ [Output](#ex-pitfall-1) ```text I expected subject: 10 (java.math.BigDecimal <1234789>) @@ -2167,7 +2167,7 @@ For instance: ```kotlin expect(listOf(1)).get(0) {} ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L264) ↓ [Output](#ex-pitfall-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/MostExamplesSpec.kt#L264) ↓ [Output](#ex-pitfall-2) ```text I expected subject: [1] (java.util.Collections.SingletonList <1234789>) @@ -2195,7 +2195,7 @@ You could even mix up different API-styles if needed (but not without losing con ## Migration of Deprecated Functionality Atrium follows [Semantic Versioning](https://semver.org/) and tries to be binary backward compatible within a major version (since 0.6.0). -Until 1.1.0 this is only true for the API level, we reserve the right to break things on the logic and core level until then. +Until 1.2.0 this is only true for the API level, we reserve the right to break things on the logic and core level until then. Moreover, we follow the principle that a user of Atrium has enough time to migrate its code to new functionality before a next major version. We provide this in form of `@Deprecated` annotations with a corresponding `ReplaceWith` as well as migration guides in the [Release Notes](https://github.com/robstoll/atrium/releases). @@ -2230,7 +2230,7 @@ and its usage: ```kotlin expect(12).toBeAMultipleOf(5) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L44) ↓ [Output](#ex-own-boolean-1) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L44) ↓ [Output](#ex-own-boolean-1) ```text I expected subject: 12 (kotlin.Int <1234789>) @@ -2246,7 +2246,7 @@ Let us see how we actually defined `toBeAMultipleOf`. the expectation to itself (creating alone is not enough, it needs to be appended in order that it is evaluated). The method `createAndAppend` returns an `Expect` for the current subject, making it easy for you to provide a fluent API as well. - The method [createAndAppend](https://docs.atriumlib.org/latest#/kdoc/atrium-core/ch.tutteli.atrium.creating/-assertion-container/create-and-append.html) + The method [createAndAppend](https://docs.atriumlib.org/1.2.0/kdoc/atrium-core/ch.tutteli.atrium.creating/-assertion-container/create-and-append.html) expects: - a `String` as description of your expectation. - the representation of the expected value. @@ -2269,7 +2269,7 @@ fun Expect.toBeEven() = ``` -We are using a [Text](https://docs.atriumlib.org/latest#/kdoc/atrium-core/ch.tutteli.atrium.reporting/-text/index.html) as +We are using a [Text](https://docs.atriumlib.org/1.2.0/kdoc/atrium-core/ch.tutteli.atrium.reporting/-text/index.html) as representation so that `"an even number"` is not treated as a `String` in reporting. Its usage looks then as follows: @@ -2278,7 +2278,7 @@ Its usage looks then as follows: ```kotlin expect(13).toBeEven() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L57) ↓ [Output](#ex-own-boolean-2) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L57) ↓ [Output](#ex-own-boolean-2) ```text I expected subject: 13 (kotlin.Int <1234789>) @@ -2307,10 +2307,10 @@ fun Expect.toComplyValidation() = expect(MyDomainModel(alpha1 = 1204)).toComplyValidation() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L85) ↓ [Output](#ex-third-party-10) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/ThirdPartySpec.kt#L85) ↓ [Output](#ex-third-party-10) ```text -I expected subject: MyDomainModel(alpha1=1204) (readme.examples.ThirdPartySpec$1$MyDomainModel <1234789>) +I expected subject: MyDomainModel(alpha1.2.04) (readme.examples.ThirdPartySpec$1$MyDomainModel <1234789>) ◆ to comply: validation β„Ή Properties of the unexpected IllegalStateException Β» message: "threshold value for alpha1 exceeded, expected <= 1000, was 1204" <1234789> @@ -2412,7 +2412,7 @@ Its usage is then as follows: expect(Person("Susanne", "Whitley", 43, listOf())) .toHaveNumberOfChildren(2) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L74) ↓ [Output](#ex-own-compose-3) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L74) ↓ [Output](#ex-own-compose-3) ```text I expected subject: Person(firstName=Susanne, lastName=Whitley, age=43, children=[]) (readme.examples.Person <1234789>) @@ -2448,7 +2448,7 @@ I.e. it fails for a `Person` with 0 children, because such a person does not hav expect(Person("Susanne", "Whitley", 43, listOf())) .toHaveAdultChildren() ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L91) ↓ [Output](#ex-own-compose-4) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L91) ↓ [Output](#ex-own-compose-4) ```text I expected subject: Person(firstName=Susanne, lastName=Whitley, age=43, children=[]) (readme.examples.Person <1234789>) @@ -2494,7 +2494,7 @@ expect(Person("Susanne", "Whitley", 43, listOf(Person("Petra", "Whitley", 12, li feature { f(it::age) }.toBeGreaterThan(18) } ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L101) ↓ [Output](#ex-own-compose-5) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationFunctionsSpec.kt#L101) ↓ [Output](#ex-own-compose-5) ```text I expected subject: Person(firstName=Susanne, lastName=Whitley, age=43, children=[Person(firstName=Petra, lastName=Whitley, age=12, children=[])]) (readme.examples.Person <1234789>) @@ -2556,7 +2556,7 @@ fun >> Expect.sameInitialsAs( There are a few additional methods which you can call after `mapArguments`. -See [KDoc of ArgumentMapperBuilder](https://docs.atriumlib.org/latest#/kdoc/atrium-logic/ch.tutteli.atrium.logic.utils/-argument-mapper-builder/index.html). +See [KDoc of ArgumentMapperBuilder](https://docs.atriumlib.org/1.2.0/kdoc/atrium-logic/ch.tutteli.atrium.logic.utils/-argument-mapper-builder/index.html). In case you want to provide your own implementation, it suffices to create an extension function for `ArgumentMapperBuilder`. @@ -2566,23 +2566,23 @@ it suffices to create an extension function for `ArgumentMapperBuilder`. Yet, sometimes we would like to create functions which have a better error reporting than the one we get when we compose expectation functions. -[`_logic`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/logic.kt#L23) +[`_logic`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/logic.kt#L23) is the entry point to `AssertionContainer` which is the equivalent of `Expect` but on a lower level. Following a quick overview what extension methods could be useful: - all expectation functions on the logic level (what you have seen in [Compose expectation functions](#compose-expectation-functions) was the API level) so that you can reuse and compose them in other ways. - `changeSubject` which allows to change the subject either: - - `unreported`; meaning it does not show up in reporting (e.g. `Expect>.asList()` uses it, see [arrayAssertions](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/main/kotlin/ch/tutteli/atrium/api/fluent/en_GB/arraySubjectChangers.kt#L20)) - - reported, using `reportBuilder`; meaning a subject transformation which is shown in reporting as it incorporates a transformation (e.g. `toBeAnInstanceOf` uses it, see [AnyAssertions](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultAnyAssertions.kt#L70)) -- `collect` which allows to collect expectations - especially helpful in composing expectations (see [mapEntryAssertions -> isKeyValue](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultMapEntryAssertions.kt#L11)) -- `extractFeature` for feature extraction where it is not always save to extract (see [`List.get`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultListAssertions.kt#L13)) + - `unreported`; meaning it does not show up in reporting (e.g. `Expect>.asList()` uses it, see [arrayAssertions](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/main/kotlin/ch/tutteli/atrium/api/fluent/en_GB/arraySubjectChangers.kt#L20)) + - reported, using `reportBuilder`; meaning a subject transformation which is shown in reporting as it incorporates a transformation (e.g. `toBeAnInstanceOf` uses it, see [AnyAssertions](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultAnyAssertions.kt#L70)) +- `collect` which allows to collect expectations - especially helpful in composing expectations (see [mapEntryAssertions -> isKeyValue](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultMapEntryAssertions.kt#L11)) +- `extractFeature` for feature extraction where it is not always save to extract (see [`List.get`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/impl/DefaultListAssertions.kt#L13)) Besides, the `assertionBuilder` allows to create different kinds of Assertions -(see [AssertionBuilder](https://docs.atriumlib.org/latest#/kdoc/atrium-core/ch.tutteli.atrium.assertions.builders/-assertion-builder/index.html) for more information) +(see [AssertionBuilder](https://docs.atriumlib.org/1.2.0/kdoc/atrium-core/ch.tutteli.atrium.assertions.builders/-assertion-builder/index.html) for more information) which can be used to create very specific expectation functions. -You can find an example in [floatingPointAssertions](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic-common/src/main/kotlin/ch/tutteli/atrium/logic/impl/DefaultFloatingPointAssertions.kt#L72) +You can find an example in [floatingPointAssertions](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic-common/src/main/kotlin/ch/tutteli/atrium/logic/impl/DefaultFloatingPointAssertions.kt#L72) which makes use of explanatory assertions as well as providing a failure hint. Unfortunately we do not have the time to cover all cases, so let us know if you want to know more @@ -2605,14 +2605,14 @@ Atrium offers the expectation verbs `expect` and `expectGrouped` out of the box. You can also define your own expectation verb if the pre-defined verbs do not suite you or in case you want to change some default implementation. In order to create an own expectation verb it is sufficient to: - 1. Copy the file content of [atriumVerbs.kt](https://github.com/robstoll/atrium/tree/main/misc/atrium-verbs-internal/src/commonMain/kotlin/ch.tutteli.atrium.api.verbs.internal/atriumVerbs.kt) + 1. Copy the file content of [atriumVerbs.kt](https://github.com/robstoll/atrium/tree/v1.2.0/misc/atrium-verbs-internal/src/commonMain/kotlin/ch.tutteli.atrium.api.verbs.internal/atriumVerbs.kt) 2. Create your own atriumVerbs.kt and paste the previously copied content 3. Adjust package name and `import`s and rename `expect`/`expectGrouped` as desired (you can also leave it that way of course). 4. exclude `atrium-verbs` from your dependencies. Taking the setup shown in the [Installation](#installation) section for the JVM platform, you would replace the `dependencies` block as follows: ```kotlin dependencies { - testImplementation("ch.tutteli.atrium:atrium-fluent:1.1.0") { + testImplementation("ch.tutteli.atrium:atrium-fluent:1.2.0") { exclude(group="ch.tutteli.atrium", module="atrium-verbs") } } @@ -2642,7 +2642,7 @@ What are the drawbacks: ## Use own Components Replacing existing components with your own (or third-party) components can be done when specifying an own expectation verb -via `withOptions`. See for instance [atriumVerbs.kt](https://github.com/robstoll/atrium/tree/main/misc/atrium-verbs-internal/src/commonMain/kotlin/ch.tutteli.atrium.api.verbs.internal/atriumVerbs.kt#L29) +via `withOptions`. See for instance [atriumVerbs.kt](https://github.com/robstoll/atrium/tree/v1.2.0/misc/atrium-verbs-internal/src/commonMain/kotlin/ch.tutteli.atrium.api.verbs.internal/atriumVerbs.kt#L29) which is used internally of Atrium in tests and uses a different `AtriumErrorAdjuster`. Another example, say you prefer multi-line reporting over single-line reporting, @@ -2675,7 +2675,7 @@ Following an example using the expectation verb ```kotlin expect(10).toEqual(9) ``` -↑ [Example](https://github.com/robstoll/atrium/tree/main/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationVerbSpec.kt#L51) ↓ [Output](#ex-own-expectation-verb) +↑ [Example](https://github.com/robstoll/atrium/tree/v1.2.0/misc/tools/readme-examples/src/main/kotlin/readme/examples/OwnExpectationVerbSpec.kt#L51) ↓ [Output](#ex-own-expectation-verb) ```text expected the subject: @@ -2695,7 +2695,7 @@ You prefer another reporting style but Atrium does not yet support it? Please let us know it by [writing a feature request](https://github.com/robstoll/atrium/issues/new?template=feature_request.md&title=[Feature]). There are more options to choose from. Take a look at the -[DefaultComponentFactoryContainer](https://github.com/robstoll/atrium/tree/main/atrium-core/src/commonMain/kotlin/ch/tutteli/atrium/creating/impl/ComponentFactoryContainerImpl.kt#L118) +[DefaultComponentFactoryContainer](https://github.com/robstoll/atrium/tree/v1.2.0/atrium-core/src/commonMain/kotlin/ch/tutteli/atrium/creating/impl/ComponentFactoryContainerImpl.kt#L118) to see the default configuration. @@ -2707,17 +2707,17 @@ Both have their design focus on interoperability with code completion functional -- so that you can let your IDE do some of the work. Atrium is -[built up by different modules](https://docs.atriumlib.org/latest#/kdoc/) +[built up by different modules](https://docs.atriumlib.org/1.2.0/kdoc/) and it is your choice which implementation you want to use. However, this is more intended for advanced user with special requirements. Atrium provides bundle modules which bundle API, logic, core, translation as well as predefined expectation verbs, so that you just have to have a dependency on one of those bundles: -- [atrium-fluent](https://github.com/robstoll/atrium/tree/main/bundles/fluent/atrium-fluent/build.gradle.kts) -- [atrium-infix](https://github.com/robstoll/atrium/tree/main/bundles/infix/atrium-infix/build.gradle.kts) +- [atrium-fluent](https://github.com/robstoll/atrium/tree/v1.2.0/bundles/fluent/atrium-fluent/build.gradle.kts) +- [atrium-infix](https://github.com/robstoll/atrium/tree/v1.2.0/bundles/infix/atrium-infix/build.gradle.kts) Have a look at -[apis/differences.md](https://github.com/robstoll/atrium/tree/main/apis/differences.md) +[apis/differences.md](https://github.com/robstoll/atrium/tree/v1.2.0/apis/differences.md) for more information and to see how the API styles differ. # Java Interoperability @@ -2731,15 +2731,15 @@ Therefore, you want to turn the platform type into the nullable version. You need to use a cast to do this. But depending on your return type this might be cumbersome especially if you deal with type parameters. Thus, Atrium provides the following functions to ease dealing with Java Code at least for some standard cases: -- [`nullable`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L189) +- [`nullable`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L189) turns a type into a nullable type and a return type of a KFunction into a nullable type. -- [`nullableContainer`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L30) +- [`nullableContainer`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L30) turns an `Iterable` into an iterable with nullable element type, likewise it does the same for `Array`. -- [`nullableKeyMap`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L56) +- [`nullableKeyMap`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L56) turns a `Map` into a map with a nullable key type. -- [`nullableValueMap`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L69) +- [`nullableValueMap`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L69) turns a `Map` into a map with a nullable value type. -- [`nullableKeyValueMap`](https://github.com/robstoll/atrium/tree/main/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L82) +- [`nullableKeyValueMap`](https://github.com/robstoll/atrium/tree/v1.2.0/logic/atrium-logic/src/commonMain/kotlin/ch/tutteli/atrium/logic/utils/nullable.kt#L82) turns a `Map` into a map with a nullable key and nullable value type. @@ -2800,8 +2800,8 @@ expect(sequenceOf(1, 2, 3)).asIterable().toContain(2) Likewise, you can turn an `Expect>`, `Expect` etc. into an `Expect>` with `asList`. -See [ArraySubjectChangerSamples](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/ArraySubjectChangerSamples.kt) -and [SequenceSubjectChangerSamples](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/SequenceSubjectChangerSamples.kt). +See [ArraySubjectChangerSamples](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/ArraySubjectChangerSamples.kt) +and [SequenceSubjectChangerSamples](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/SequenceSubjectChangerSamples.kt). Feel free vote for [first class support for Array and Sequence in api-fluent](https://github.com/robstoll/atrium/issues/459). @@ -2828,7 +2828,7 @@ Atrium does not provide extension functions applicable to `Expect` directl because they would basically duplicate the functions available for `Expect`. However, Atrium provides the subject changer `asPath` so that you can turn an `Expect` into an `Expect`. -See [FileSubjectChangerSamples](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/FileSubjectChangerSamples.kt). +See [FileSubjectChangerSamples](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/FileSubjectChangerSamples.kt). ## Where are the expectation functions for java.util.Date? @@ -2837,20 +2837,20 @@ because they would basically duplicate the functions available for `Expect` either into an `Expect` or `Expect`. -See [DateSubjectChangerSamples](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/DateSubjectChangerSamples.kt). +See [DateSubjectChangerSamples](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/DateSubjectChangerSamples.kt). ## Where do I find a list of all available functions? Atrium provides KDoc for all APIs - have a look at their KDoc: -- [atrium-api-fluent](https://docs.atriumlib.org/latest#/kdoc/atrium-api-fluent) -- [atrium-api-infix](https://docs.atriumlib.org/latest#/kdoc/atrium-api-infix) +- [atrium-api-fluent](https://docs.atriumlib.org/1.2.0/kdoc/atrium-api-fluent) +- [atrium-api-infix](https://docs.atriumlib.org/1.2.0/kdoc/atrium-api-infix) A good alternative is to have a look at the sample files: -- [Samples api-fluent common](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) -- [Samples api-fluent jvm](https://github.com/robstoll/atrium/tree/main/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) +- [Samples api-fluent common](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/commonTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) +- [Samples api-fluent jvm](https://github.com/robstoll/atrium/tree/v1.2.0/apis/fluent/atrium-api-fluent/src/jvmTest/kotlin/ch/tutteli/atrium/api/fluent/en_GB/samples/) -+ [Samples api-infix common](https://github.com/robstoll/atrium/tree/main/apis/infix/atrium-api-infix/src/commonTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) -+ [Samples api-infix jvm](https://github.com/robstoll/atrium/tree/main/apis/infix/atrium-api-infix/src/jvmTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) ++ [Samples api-infix common](https://github.com/robstoll/atrium/tree/v1.2.0/apis/infix/atrium-api-infix/src/commonTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) ++ [Samples api-infix jvm](https://github.com/robstoll/atrium/tree/v1.2.0/apis/infix/atrium-api-infix/src/jvmTest/kotlin/ch/tutteli/atrium/api/infix/en_GB/samples/) # Roadmap @@ -2882,7 +2882,7 @@ You are more than welcome to contribute as well: if you would like to code (ping us on [Slack](https://kotlinlang.slack.com/messages/C887ZKGCQ) if there are not any). Please have a look at -[CONTRIBUTING.md](https://github.com/robstoll/atrium/tree/main/.github/CONTRIBUTING.md) +[CONTRIBUTING.md](https://github.com/robstoll/atrium/tree/v1.2.0/.github/CONTRIBUTING.md) for further suggestions and guidelines. # Sponsors diff --git a/apis/differences.md b/apis/differences.md index 78bdd03e4f..032ee36bb6 100644 --- a/apis/differences.md +++ b/apis/differences.md @@ -13,13 +13,13 @@ These modules bundle: Following a list of the available bundle-modules. The links point to the KDoc of their included API where you find an overview of all available expectation functions of the API. -- [atrium-api-fluent](https://docs.atriumlib.org/latest#/kdoc/atrium-api-fluent) -- [atrium-api-infix](https://docs.atriumlib.org/latest#/kdoc/atrium-api-infix) +- [atrium-api-fluent](https://docs.atriumlib.org/1.2.0/kdoc/atrium-api-fluent) +- [atrium-api-infix](https://docs.atriumlib.org/1.2.0/kdoc/atrium-api-infix) ---- Following an excerpt of a build.gradle file which uses both APIs (see -[README#Installation](https://github.com/robstoll/atrium/tree/main/README.md#installation) +[README#Installation](https://github.com/robstoll/atrium/tree/v1.2.0/README.md#installation) for the rest): ```kotlin dependencies { diff --git a/build.gradle.kts b/build.gradle.kts index 1d555934fd..d3da59956f 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -1,7 +1,7 @@ buildscript { // needs to be defined in here so that the tutteli publish plugin can set up conventions based on the group // (if defined in regular scope of build.gradle.kts then the tutteli plugin would not see it when applied) - rootProject.version = "1.2.0-SNAPSHOT" + rootProject.version = "1.2.0" rootProject.group = "ch.tutteli.atrium" } @@ -63,7 +63,7 @@ Release & deploy a commit Either use the following commands or the manual steps below -export ATRIUM_PREVIOUS_VERSION=1.1.0 +export ATRIUM_PREVIOUS_VERSION=1.2.0 export ATRIUM_VERSION=1.2.0 find ./ -name "*.md" | xargs perl -0777 -i \ -pe "s@$ATRIUM_PREVIOUS_VERSION@$ATRIUM_VERSION@g;" \ @@ -183,7 +183,7 @@ Prepare next dev cycle Either use the following commands or the manual steps below -export ATRIUM_VERSION=1.1.0 +export ATRIUM_VERSION=1.2.0 export ATRIUM_NEXT_VERSION=1.2.0 find ./ -name "*.md" | xargs perl -0777 -i \ -pe "s@tree/v$ATRIUM_VERSION@tree/main@g;" \