diff --git a/README.md b/README.md index 0574d9651..f6cc4c228 100644 --- a/README.md +++ b/README.md @@ -100,11 +100,22 @@ See [Plugin Signing](https://plugins.jetbrains.com/docs/intellij/plugin-signing. ```bash $ gradlew test # Run tests $ gradlew test --tests X # Run tests in class X (package name optional) -$ gradlew test --kotest.tags="X" # Run tests with `NamedTag` X (also supports not (!), and (&), or (|)) +$ gradlew test -Pkotest.tags="X" # Run tests with `NamedTag` X (also supports not (!), and (&), or (|)) $ gradlew check # Run tests and static analysis $ gradlew runPluginVerifier # Check for compatibility issues ``` +#### 🏷️ Filtering tests +[Kotest tests can be tagged](https://kotest.io/docs/framework/tags.html) to allow selectively running tests. +Tag an entire test class by adding `tags(...)` to the class definition, or tag an individual test `context` by +writing `context("foo").config(tags = setOf(...)) {`. +It is not possible to tag an individual `test` due to limitations in Kotest. + +To run only one `context` in some test class `X`, prefix the `context`'s name with `f:` and run with `--tests X`. +The prefix `f:` filters out other `context`s in that test class, and `--tests X` filters out other test classes. +Alternatively, tag the desired `context` with the `Focus` tag and run with `-Pkotest.tags="Focus"` to filter by that +tag. + ### 📚 Documentation ```bash $ gradlew dokkaHtml # Generate documentation diff --git a/build.gradle.kts b/build.gradle.kts index 645a27793..13360b49c 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -105,7 +105,10 @@ tasks { if (project.hasProperty("kotest.tags")) systemProperty("kotest.tags", project.findProperty("kotest.tags")!!) useJUnitPlatform { - includeEngines("junit-vintage", "kotest") + if (!project.hasProperty("kotest.tags")) + includeEngines("junit-vintage") + + includeEngines("kotest") } testLogging { diff --git a/src/main/kotlin/com/fwdekker/randomness/Bundle.kt b/src/main/kotlin/com/fwdekker/randomness/Bundle.kt index 20f263aa2..5fac53f29 100644 --- a/src/main/kotlin/com/fwdekker/randomness/Bundle.kt +++ b/src/main/kotlin/com/fwdekker/randomness/Bundle.kt @@ -38,7 +38,7 @@ object Bundle { * @throws java.util.MissingFormatArgumentException if [args] has fewer arguments than required for [format] */ fun String.matchesFormat(format: String, vararg args: String) = - Regex("%[0-9]+\\\$[Ss]").findAll(format) + Regex("%[0-9]+\\\$[Ssd]").findAll(format) .toList() .reversed() .fold(format) { acc, match -> diff --git a/src/main/kotlin/com/fwdekker/randomness/SchemeEditor.kt b/src/main/kotlin/com/fwdekker/randomness/SchemeEditor.kt index 73af73a92..7f0f421e1 100644 --- a/src/main/kotlin/com/fwdekker/randomness/SchemeEditor.kt +++ b/src/main/kotlin/com/fwdekker/randomness/SchemeEditor.kt @@ -76,5 +76,5 @@ abstract class SchemeEditor(val scheme: S) : Disposable { /** * Disposes this editor's resources. */ - override fun dispose() = Disposer.dispose(this) + override fun dispose() = decoratorEditors.forEach { Disposer.dispose(it) } } diff --git a/src/main/kotlin/com/fwdekker/randomness/Settings.kt b/src/main/kotlin/com/fwdekker/randomness/Settings.kt index 420bfb784..74785bfc0 100644 --- a/src/main/kotlin/com/fwdekker/randomness/Settings.kt +++ b/src/main/kotlin/com/fwdekker/randomness/Settings.kt @@ -8,6 +8,7 @@ import com.intellij.openapi.components.SettingsCategory import com.intellij.openapi.components.Storage import com.intellij.openapi.components.service import com.intellij.util.xmlb.XmlSerializer +import com.intellij.util.xmlb.annotations.OptionTag import com.intellij.util.xmlb.annotations.Transient import org.jdom.Element import java.lang.module.ModuleDescriptor @@ -22,7 +23,8 @@ import com.intellij.openapi.components.State as JBState */ data class Settings( var version: String = CURRENT_VERSION, - var templateList: TemplateList = TemplateList(), + @OptionTag + val templateList: TemplateList = TemplateList(), ) : State() { /** * @see TemplateList.templates @@ -31,19 +33,25 @@ data class Settings( val templates: MutableList