Carter
08/30/2023, 6:13 PMListImmutableListKonsist.scopeFromProject()
    .classes()
    // Skip serializable classes, because immutable collections aren't serializable by default
    .withoutSomeAnnotationsOf(kotlinx.serialization.Serializable::class)
    .flatMap { it.constructors }
    .flatMap { it.parameters }
    .filter {
        it.type.name.startsWith(List::class.java.simpleName)
    }
    .assert { it.representsTypeOf<ImmutableList<*>>() }igor.wojda
08/31/2023, 3:45 PMendsWithcontainsstartsWith<*>*ImmutableList<SomeType> == ImmutableList<*>assert { it.type.name.startsWith("ImmutableList") }Carter
08/31/2023, 3:46 PMdata class SomeClass(val: List<Elt>)data class SomeClass(val: ImmutableList<Elt>)Carter
08/31/2023, 3:48 PMval mutableList = mutableListOf(a, b, c)
val someClass = SomeClass(mutableList)
mutableList.clear()Carter
08/31/2023, 3:48 PMigor.wojda
08/31/2023, 3:54 PMrepresentsTypeListKonsist.scopeFromProject()
            .classes()
            // Skip serializable classes, because immutable collections aren't serializable by default
            .withoutSomeAnnotationsOf(kotlinx.serialization.Serializable::class)
            .flatMap { it.constructors }
            .flatMap { it.parameters }
            .assertNot {
                it.type.name.startsWith("List<") 
            }Carter
08/31/2023, 3:55 PMCarter
08/31/2023, 3:57 PMigor.wojda
08/31/2023, 3:59 PMigor.wojda
08/31/2023, 4:06 PM.assertNot {
    val regex = """.*List.*""".toRegex()
    it.type.hasNameMatching(regex)
}Carter
08/31/2023, 4:56 PMwhen you notice during PR review that devs are making certain mistakesAt the moment I’m protecting against myself 😂.