wip #1271
344 passed, 0 failed and 0 skipped
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.internal.fundamentals.collections.IzCollectionsTest.xml
1 tests were completed in 2ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.internal.fundamentals.collections.IzCollectionsTest | 1✅ | 2ms |
✅ izumi.reflect.internal.fundamentals.collections.IzCollectionsTest
✅ Collection utils should allow to convert mappings to multimaps
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.internal.fundamentals.platform.IzStringTest.xml
1 tests were completed in 1ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.internal.fundamentals.platform.IzStringTest | 1✅ | 1ms |
✅ izumi.reflect.internal.fundamentals.platform.IzStringTest
✅ Extended string should support boolean parsing
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.test.BasicDottyTestMirror.xml
1 tests were completed in 228ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.BasicDottyTestMirror | 1✅ | 228ms |
✅ izumi.reflect.test.BasicDottyTestMirror
✅ super-basic test 1
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.test.LightTypeTagProgressionTest.xml
15 tests were completed in 294ms with 15 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.LightTypeTagProgressionTest | 15✅ | 294ms |
✅ izumi.reflect.test.LightTypeTagProgressionTest
✅ [progression] lightweight type tags (all versions) should progression test: can't support subtyping of type prefixes
✅ [progression] lightweight type tags (all versions) should progression test: can't support subtyping of concrete type projections
✅ [progression] lightweight type tags (all versions) should progression test: subtype check fails when child type has absorbed a covariant type parameter of the supertype
✅ [progression] lightweight type tags (all versions) should progression test: bounds-based subtype checks for lambdas do not work properly (LambdaParameter must contain bounds and NameReferences shouldn't for this to work)
✅ [progression] lightweight type tags (all versions) should progression test: a portion of `support swapped parents` fails on Dotty
✅ [progression] lightweight type tags (all versions) should progression test: indirect structural checks do not work
✅ [progression] lightweight type tags (all versions) should progression test: combined intersection lambda tags still contain some junk bases (coming from the unsound same-arity assumption in LightTypeTag#combine)
✅ [progression] lightweight type tags (all versions) should progression test: combined lambda tags still contain some junk bases (coming from the unsound same-arity assumption in LightTypeTag#combine)
✅ [progression] lightweight type tags (all versions) should progression test: `applied tags should not contain junk bases` is not supported on Dotty
✅ [progression] lightweight type tags (all versions) should progression test: `lambda tags should not contain junk bases` is not supported on Dotty
✅ [progression] lightweight type tags (all versions) should progression test: Dotty fails to `support methods with type parameters in structural refinements`
✅ [progression] lightweight type tags (all versions) should fails to treat tautological refinements as equal to the underlying type
✅ [progression] lightweight type tags (all versions) should fails to support methods in refinements with multiple parameter lists
✅ [progression] lightweight type tags (all versions) should progression test: fails to `Any/Object relation is consistent with Scala`
✅ [progression] lightweight type tags (all versions) should progression test: can't distinguish between equal-bounded type and alias inside refinements in dotty
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.test.LightTypeTagTest.xml
57 tests were completed in 1s with 57 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.LightTypeTagTest | 57✅ | 1s |
✅ izumi.reflect.test.LightTypeTagTest
✅ lightweight type tags (all versions) should support distinction between subtypes
✅ lightweight type tags (all versions) should eradicate intersection tautologies with Any/Object
✅ lightweight type tags (all versions) should do not eradicate intersections with Nothing
✅ lightweight type tags (all versions) should eradicate self-intersection (X with X)
✅ lightweight type tags (all versions) should support subtype checks
✅ lightweight type tags (all versions) should support unsound subtype checks
✅ lightweight type tags (all versions) should support swapped parents
✅ lightweight type tags (all versions) should support subtyping of parents parameterized with type lambdas
✅ lightweight type tags (all versions) should support subtyping of parents parameterized with type lambdas in combined tags
✅ lightweight type tags (all versions) should support subtyping of parents parameterized with type lambdas in combined tags with multiple parameters
✅ lightweight type tags (all versions) should support PDTs
✅ lightweight type tags (all versions) should intersections are associative
✅ lightweight type tags (all versions) should runtime-combined intersections are associative
✅ lightweight type tags (all versions) should support type alias and refinement subtype checks
✅ lightweight type tags (all versions) should support refinement higher-kinded subtype checks
✅ lightweight type tags (all versions) should support literal types
✅ lightweight type tags (all versions) should resolve comparisons of object and trait with the same name
✅ lightweight type tags (all versions) should resolve prefixes of annotated types
✅ lightweight type tags (all versions) should `withoutArgs` comparison works
✅ lightweight type tags (all versions) should `typeArgs` works
✅ lightweight type tags (all versions) should support subtyping of a simple combined type
✅ lightweight type tags (all versions) should issue #762: properly strip away annotated types / empty refinements / type aliases
✅ lightweight type tags (all versions) should calculate identical hashCode in parsed and constructed instances
✅ lightweight type tags (all versions) should support non-positional typetag combination
✅ lightweight type tags (all versions) should support additional mixin traits after first trait with a HKT parameter
✅ lightweight type tags (all versions) should support LTagK* family summoners
✅ lightweight type tags (all versions) should support higher-kinded intersection type equality
✅ lightweight type tags (all versions) should support contravariance
✅ lightweight type tags (all versions) should support typetag combination
✅ lightweight type tags (all versions) should tautological intersections with Any/Object are discarded from internal structure
✅ lightweight type tags (all versions) should wildcards are supported
✅ lightweight type tags (all versions) should wildcards with bounds are supported
✅ lightweight type tags (all versions) should generate tags for wildcards with type boundaries
✅ lightweight type tags (all versions) should https://github.com/zio/izumi-reflect/issues/315 regression test 2.1.0-M1: IntegrationCheck[F] should not be related to IntegrationCheck[Identity]
✅ lightweight type tags (all versions) should normalize stable PDTs (https://github.com/zio/zio/issues/3390)
✅ lightweight type tags (all versions) should properly dealias and assign prefixes to existential types and wildcards
✅ lightweight type tags (all versions) should no redundant $ in object names
✅ lightweight type tags (all versions) should support basic None.type subtype check
✅ lightweight type tags (all versions) should supports complex type lambdas
✅ lightweight type tags (all versions) should intersection lambda tags should not contain junk bases
✅ lightweight type tags (all versions) should No degenerate lambdas (regression test https://github.com/zio/izumi-reflect/issues/345)
✅ lightweight type tags (all versions) should check subtyping when higher-kinds are involved on Scala 3
✅ lightweight type tags (all versions) should support higher-kinded intersection type subtyping
✅ lightweight type tags (all versions) should support higher-kinded intersection type combination isn't supported on Dotty
✅ lightweight type tags (all versions) should support structural & refinement type subtype checks
✅ lightweight type tags (all versions) should support structural & refinement type equality
✅ lightweight type tags (all versions) should strong summons test
✅ lightweight type tags (all versions) should distinguishes between val and type structural refinements
✅ lightweight type tags (all versions) should does not contain intersections in plain structural refinements
✅ lightweight type tags (all versions) should support equal-bounded types as paradoxical (before 2.3.0 and since 2.3.6 NOT equal to their underlying)
✅ lightweight type tags (all versions) should support structural subtype checks
✅ lightweight type tags (all versions) should what about non-empty refinements with intersections
✅ lightweight type tags (all versions) should support contravariance in refinement method comparisons
✅ lightweight type tags (all versions) should support human-readable representation
✅ lightweight type tags (Scala 2) should support structural & refinement type equality (Scala 2 specific, generic type projection)
✅ lightweight type tags (Scala 2) should strong summons test (Scala 2 specific, generic type projection)
✅ lightweight type tags (Scala 2) should there should be no unexpected lambdas in bases db produced from nested existential types (Scala 2 specific, unreducible application of higher-kinded type to wildcard arguments) (regression test https://github.com/zio/izumi-reflect/issues/345)
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.test.TagMacroTest.xml
1 tests were completed in 19ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.TagMacroTest | 1✅ | 19ms |
✅ izumi.reflect.test.TagMacroTest
✅ Tag macro should reconstruct lambda tags
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.test.TagProgressionTest.xml
12 tests were completed in 92ms with 12 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.TagProgressionTest | 12✅ | 92ms |
✅ izumi.reflect.test.TagProgressionTest
✅ [progression] Tag (all versions) should progression test: can't substitute type parameters inside defs/vals in structural types
✅ [progression] Tag (all versions) should progression test: cannot resolve a higher-kinded type in a higher-kinded tag in a named deeply-nested type lambda on Scala 2
✅ [progression] Tag (all versions) should progression test: cannot resolve a higher-kinded type in a higher-kinded tag in an anonymous deeply-nested type lambda
✅ [progression] Tag (all versions) should progression test: projections into singletons are not handled properly (on Scala 2)
✅ [progression] Tag (all versions) should Progression test: Scala 2 fails to Handle Tags outside of a predefined set (Somehow raw Tag.auto.T works on Scala 2, but not when defined as an alias)
✅ [progression] Tag (all versions) should progression test: fails to combine higher-kinded intersection types without losing ignored type arguments
✅ [progression] Tag (all versions) should progression test: Dotty fails to regression test: resolve correct closestClass for Scala vararg AnyVal (https://github.com/zio/izumi-reflect/issues/224)
✅ [progression] Tag (all versions) should progression test: fails to preserve lower bound when combining higher-kinded type members
✅ [progression] Tag (all versions) should progression test: fails on Scala 3 don't lose tautological intersection components other than Any/AnyRef
✅ [progression] Tag (all versions) should progression test: intersection tautologies are not removed automatically when constructing combined intersection type
✅ [progression] Tag (Scala 2) should progression test: combine intersection path-dependent intersection types with inner tags doesn't work yet (Scala 2 specific, generic type projection)
✅ [progression] Tag (Scala 2) should progression test: type tags with bounds are not currently requested by the macro on Scala 2
✅ izumi-reflect/izumi-reflect/.js/target/test-reports/TEST-izumi.reflect.test.TagTest.xml
81 tests were completed in 873ms with 81 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.TagTest | 81✅ | 873ms |
✅ izumi.reflect.test.TagTest
✅ Tag (all versions) should Work for any concrete type
✅ Tag (all versions) should Support identity lambda type equality
✅ Tag (all versions) should regression test for https://github.com/zio/izumi-reflect/issues/98
✅ Tag (all versions) should Work for any abstract type with available Tag when obscured by empty refinement
✅ Tag (all versions) should handle function local type aliases
✅ Tag (all versions) should Can dealias transparent type members with class type parameters inside them when a tag is summoned _inside_ the class, because LightTypeTags are not affected by https://github.com/scala/bug/issues/11139
✅ Tag (all versions) should Tag.auto.T kind inference macro works for known cases
✅ Tag (all versions) should Shouldn't work for any abstract type without available TypeTag or Tag or TagK
✅ Tag (all versions) should handle Id type lambda
✅ Tag (all versions) should handle Id1 type lambda
✅ Tag (all versions) should handle singleton types
✅ Tag (all versions) should handle nested intersection aliases
✅ Tag (all versions) should handle nested refined intersection aliases
✅ Tag (all versions) should simple combined Tag
✅ Tag (all versions) should consider class member's this-prefix to be the defining template, not the most specific prefix from where the call is happening (deliberate omission of this for better ergonomics in cakes)
✅ Tag (all versions) should Does NOT synthesize Tags for abstract types, but recursively summons Tag[this.Abstract]
✅ Tag (all versions) should DOES synthesize Tags for abstract types (object X; X.T), does not summon Tag[X.T]
✅ Tag (all versions) should DOES synthesize Tags for abstract types (trait X; X#T), does not summon Tag[X#T]
✅ Tag (all versions) should DOES synthesize Tags for abstract types (val x; x.T), does not summon Tag[x.T]
✅ Tag (all versions) should Work for an abstract type with available TagK when obscured by empty refinement
✅ Tag (all versions) should Work for an abstract type with available TagK when TagK is requested through an explicit implicit
✅ Tag (all versions) should Work for an abstract type with available TagKK
✅ Tag (all versions) should Work for any configuration of parameters
✅ Tag (all versions) should handle Swap type lambda
✅ Tag (all versions) should Assemble from higher than TagKK tags
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/293 assemble tag for Builder[B, Collection[B]]
✅ Tag (all versions) should combine intersection types
✅ Tag (all versions) should summon HKT Tag for a Java type
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/76 derive tag for a parametric trait inside object
✅ Tag (all versions) should this.type tags should be generated, but are identical with their class / object tag
✅ Tag (all versions) should this.type should have correct prefix
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/83, convert trifunctor tag to bifunctor tag
✅ Tag (all versions) should resolve TagK from TagKK
✅ Tag (all versions) should can materialize TagK for type lambdas that close on a generic parameter with available Tag
✅ Tag (all versions) should can materialize TagK for type lambdas that close on a generic parameter with available Tag when the constructor is a type parameter
✅ Tag (all versions) should type parameter covariance works after combine
✅ Tag (all versions) should combine Const Lambda to TagK
✅ Tag (all versions) should combined TagK 3 & 2 parameter coherence
✅ Tag (all versions) should resolve TagKK from an odd higher-kinded Tag with swapped & ignored parameters
✅ Tag (all versions) should can resolve Tags of TagK's themselves correctly
✅ Tag (all versions) should regression test: ignore function-local anonymous classes (https://github.com/zio/zio/issues/4285)
✅ Tag (all versions) should equal path-dependent tags for singleton types are expected to be equal
✅ Tag (all versions) should return expected class tag
✅ Tag (all versions) should Work with term type prefixes
✅ Tag (all versions) should correctly resolve abstract types inside traits when summoned inside trait
✅ Tag (all versions) should combine higher-kinded type lambdas without losing ignored type arguments
✅ Tag (all versions) should resolve a higher-kinded type inside a named type lambda with ignored type arguments
✅ Tag (all versions) should resolve TagKK from an odd higher-kinded Tag with swapped & ignored parameters (low-level)
✅ Tag (all versions) should correctly resolve a higher-kinded nested type inside a named swap type lambda
✅ Tag (all versions) should support subtyping of parents parameterized with type lambdas in combined tags
✅ Tag (all versions) should support subtyping of parents parameterized with type lambdas in combined tags with multiple parameters
✅ Tag (all versions) should combine inside type lambdas with repeated usages of a type lambda type parameter
✅ Tag (all versions) should combine inside type lambdas with repeated usages of an outer type
✅ Tag (all versions) should combine inside type lambdas with repeated usages of an outer distinct type with the same type symbol
✅ Tag (all versions) should combine inside type lambdas where the type constructor of the type lambda result is a type lambda type parameter
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/82, convert trifunctor hkt to bifunctor when combining tags
✅ Tag (all versions) should combine higher-kinded types without losing ignored type arguments
✅ Tag (all versions) should resolve a higher-kinded type inside an anonymous type lambda with ignored & higher-kinded type arguments
✅ Tag (all versions) should correctly resolve a higher-kinded nested type inside an anonymous swap type lambda
✅ Tag (all versions) should handles abstract types instead of parameters
✅ Tag (all versions) should Generates lambda parents for lambda bases
✅ Tag (all versions) should subtyping for Invariant Java HKT
✅ Tag (all versions) should subtyping for Invariant Scala HKT
✅ Tag (all versions) should Work for structural concrete types
✅ Tag (all versions) should Work for any abstract type with available Tag while preserving additional type refinement
✅ Tag (all versions) should Work for any abstract type with available Tag while preserving additional method refinement
✅ Tag (all versions) should can resolve parameters in structural types
✅ Tag (all versions) should combine higher-kinded type members
✅ Tag (all versions) should regression test: do not be confused by a type alias of Set of an abstract type referred via this-prefix on Scala 3
✅ Tag (all versions) should support injecting runtime tags in place of type projections from type parameters / match types on type parameters
✅ Tag (all versions) should regression test for: Scala 2, https://github.com/zio/izumi-reflect/issues/189, parameterized type alias with intersection produces incorrect output
✅ Tag (all versions) should combining with wildcards is supported
✅ Tag (all versions) should other type members' bounds are not malformed when resolving parameters in structural types
✅ Tag (all versions) should form a correct type lambda for an equal-bounded abstract type
✅ Tag (all versions) should eradicate intersection tautologies with Any/Object (Tag)
✅ Tag (all versions) should tautological intersections with Any/Object are discarded from internal structure (Tag)
✅ Tag (Scala 2) should Work for an abstract type with available TagK when TagK is requested through an explicit implicit (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should Handle Tags outside of a predefined set (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should Can create custom type tags to support bounded generics, e.g. <: Dep in TagK (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should can find HKTag when obscured by type lambda (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should we no longer accidentally materialize tags for type parameters that are prefixes of type projections (Scala 2 specific, generic type projection)
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.internal.fundamentals.collections.IzCollectionsTest.xml
1 tests were completed in 28ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.internal.fundamentals.collections.IzCollectionsTest | 1✅ | 28ms |
✅ izumi.reflect.internal.fundamentals.collections.IzCollectionsTest
✅ Collection utils should allow to convert mappings to multimaps
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.internal.fundamentals.platform.IzStringTest.xml
1 tests were completed in 1ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.internal.fundamentals.platform.IzStringTest | 1✅ | 1ms |
✅ izumi.reflect.internal.fundamentals.platform.IzStringTest
✅ Extended string should support boolean parsing
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.AllPartsStrongTestScala2Jvm.xml
6 tests were completed in 976ms with 6 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.AllPartsStrongTestScala2Jvm | 6✅ | 976ms |
✅ izumi.reflect.test.AllPartsStrongTestScala2Jvm
✅ allPartsStrong for Identity typelambda
✅ allPartsStrong for eta-expansion typelambda
✅ allPartsStrong for application typelambda
✅ allPartsStrong for anonymous application typelambda
✅ allPartsStrong for x.F[x.Id] typelambda
✅ allPartsStrong for TC#DiscoveryNode type projection
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.BasicDottyTestMirror.xml
1 tests were completed in 181ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.BasicDottyTestMirror | 1✅ | 181ms |
✅ izumi.reflect.test.BasicDottyTestMirror
✅ super-basic test 1
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.LightTypeTagProgressionTest.xml
15 tests were completed in 1s with 15 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.LightTypeTagProgressionTest | 15✅ | 1s |
✅ izumi.reflect.test.LightTypeTagProgressionTest
✅ [progression] lightweight type tags (all versions) should progression test: can't support subtyping of type prefixes
✅ [progression] lightweight type tags (all versions) should progression test: can't support subtyping of concrete type projections
✅ [progression] lightweight type tags (all versions) should progression test: subtype check fails when child type has absorbed a covariant type parameter of the supertype
✅ [progression] lightweight type tags (all versions) should progression test: bounds-based subtype checks for lambdas do not work properly (LambdaParameter must contain bounds and NameReferences shouldn't for this to work)
✅ [progression] lightweight type tags (all versions) should progression test: a portion of `support swapped parents` fails on Dotty
✅ [progression] lightweight type tags (all versions) should progression test: indirect structural checks do not work
✅ [progression] lightweight type tags (all versions) should progression test: combined intersection lambda tags still contain some junk bases (coming from the unsound same-arity assumption in LightTypeTag#combine)
✅ [progression] lightweight type tags (all versions) should progression test: combined lambda tags still contain some junk bases (coming from the unsound same-arity assumption in LightTypeTag#combine)
✅ [progression] lightweight type tags (all versions) should progression test: `applied tags should not contain junk bases` is not supported on Dotty
✅ [progression] lightweight type tags (all versions) should progression test: `lambda tags should not contain junk bases` is not supported on Dotty
✅ [progression] lightweight type tags (all versions) should progression test: Dotty fails to `support methods with type parameters in structural refinements`
✅ [progression] lightweight type tags (all versions) should fails to treat tautological refinements as equal to the underlying type
✅ [progression] lightweight type tags (all versions) should fails to support methods in refinements with multiple parameter lists
✅ [progression] lightweight type tags (all versions) should progression test: fails to `Any/Object relation is consistent with Scala`
✅ [progression] lightweight type tags (all versions) should progression test: can't distinguish between equal-bounded type and alias inside refinements in dotty
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.LightTypeTagTest.xml
57 tests were completed in 295ms with 57 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.LightTypeTagTest | 57✅ | 295ms |
✅ izumi.reflect.test.LightTypeTagTest
✅ lightweight type tags (all versions) should support distinction between subtypes
✅ lightweight type tags (all versions) should eradicate intersection tautologies with Any/Object
✅ lightweight type tags (all versions) should do not eradicate intersections with Nothing
✅ lightweight type tags (all versions) should eradicate self-intersection (X with X)
✅ lightweight type tags (all versions) should support subtype checks
✅ lightweight type tags (all versions) should support unsound subtype checks
✅ lightweight type tags (all versions) should support swapped parents
✅ lightweight type tags (all versions) should support subtyping of parents parameterized with type lambdas
✅ lightweight type tags (all versions) should support subtyping of parents parameterized with type lambdas in combined tags
✅ lightweight type tags (all versions) should support subtyping of parents parameterized with type lambdas in combined tags with multiple parameters
✅ lightweight type tags (all versions) should support PDTs
✅ lightweight type tags (all versions) should intersections are associative
✅ lightweight type tags (all versions) should runtime-combined intersections are associative
✅ lightweight type tags (all versions) should support type alias and refinement subtype checks
✅ lightweight type tags (all versions) should support refinement higher-kinded subtype checks
✅ lightweight type tags (all versions) should support literal types
✅ lightweight type tags (all versions) should resolve comparisons of object and trait with the same name
✅ lightweight type tags (all versions) should resolve prefixes of annotated types
✅ lightweight type tags (all versions) should `withoutArgs` comparison works
✅ lightweight type tags (all versions) should `typeArgs` works
✅ lightweight type tags (all versions) should support subtyping of a simple combined type
✅ lightweight type tags (all versions) should issue #762: properly strip away annotated types / empty refinements / type aliases
✅ lightweight type tags (all versions) should calculate identical hashCode in parsed and constructed instances
✅ lightweight type tags (all versions) should support non-positional typetag combination
✅ lightweight type tags (all versions) should support additional mixin traits after first trait with a HKT parameter
✅ lightweight type tags (all versions) should support LTagK* family summoners
✅ lightweight type tags (all versions) should support higher-kinded intersection type equality
✅ lightweight type tags (all versions) should support contravariance
✅ lightweight type tags (all versions) should support typetag combination
✅ lightweight type tags (all versions) should tautological intersections with Any/Object are discarded from internal structure
✅ lightweight type tags (all versions) should wildcards are supported
✅ lightweight type tags (all versions) should wildcards with bounds are supported
✅ lightweight type tags (all versions) should generate tags for wildcards with type boundaries
✅ lightweight type tags (all versions) should https://github.com/zio/izumi-reflect/issues/315 regression test 2.1.0-M1: IntegrationCheck[F] should not be related to IntegrationCheck[Identity]
✅ lightweight type tags (all versions) should normalize stable PDTs (https://github.com/zio/zio/issues/3390)
✅ lightweight type tags (all versions) should properly dealias and assign prefixes to existential types and wildcards
✅ lightweight type tags (all versions) should no redundant $ in object names
✅ lightweight type tags (all versions) should support basic None.type subtype check
✅ lightweight type tags (all versions) should supports complex type lambdas
✅ lightweight type tags (all versions) should intersection lambda tags should not contain junk bases
✅ lightweight type tags (all versions) should No degenerate lambdas (regression test https://github.com/zio/izumi-reflect/issues/345)
✅ lightweight type tags (all versions) should check subtyping when higher-kinds are involved on Scala 3
✅ lightweight type tags (all versions) should support higher-kinded intersection type subtyping
✅ lightweight type tags (all versions) should support higher-kinded intersection type combination isn't supported on Dotty
✅ lightweight type tags (all versions) should support structural & refinement type subtype checks
✅ lightweight type tags (all versions) should support structural & refinement type equality
✅ lightweight type tags (all versions) should strong summons test
✅ lightweight type tags (all versions) should distinguishes between val and type structural refinements
✅ lightweight type tags (all versions) should does not contain intersections in plain structural refinements
✅ lightweight type tags (all versions) should support equal-bounded types as paradoxical (before 2.3.0 and since 2.3.6 NOT equal to their underlying)
✅ lightweight type tags (all versions) should support structural subtype checks
✅ lightweight type tags (all versions) should what about non-empty refinements with intersections
✅ lightweight type tags (all versions) should support contravariance in refinement method comparisons
✅ lightweight type tags (all versions) should support human-readable representation
✅ lightweight type tags (Scala 2) should support structural & refinement type equality (Scala 2 specific, generic type projection)
✅ lightweight type tags (Scala 2) should strong summons test (Scala 2 specific, generic type projection)
✅ lightweight type tags (Scala 2) should there should be no unexpected lambdas in bases db produced from nested existential types (Scala 2 specific, unreducible application of higher-kinded type to wildcard arguments) (regression test https://github.com/zio/izumi-reflect/issues/345)
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.TagMacroTest.xml
1 tests were completed in 84ms with 1 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.TagMacroTest | 1✅ | 84ms |
✅ izumi.reflect.test.TagMacroTest
✅ Tag macro should reconstruct lambda tags
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.TagProgressionTest.xml
12 tests were completed in 1s with 12 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.TagProgressionTest | 12✅ | 1s |
✅ izumi.reflect.test.TagProgressionTest
✅ [progression] Tag (all versions) should progression test: can't substitute type parameters inside defs/vals in structural types
✅ [progression] Tag (all versions) should progression test: cannot resolve a higher-kinded type in a higher-kinded tag in a named deeply-nested type lambda on Scala 2
✅ [progression] Tag (all versions) should progression test: cannot resolve a higher-kinded type in a higher-kinded tag in an anonymous deeply-nested type lambda
✅ [progression] Tag (all versions) should progression test: projections into singletons are not handled properly (on Scala 2)
✅ [progression] Tag (all versions) should Progression test: Scala 2 fails to Handle Tags outside of a predefined set (Somehow raw Tag.auto.T works on Scala 2, but not when defined as an alias)
✅ [progression] Tag (all versions) should progression test: fails to combine higher-kinded intersection types without losing ignored type arguments
✅ [progression] Tag (all versions) should progression test: Dotty fails to regression test: resolve correct closestClass for Scala vararg AnyVal (https://github.com/zio/izumi-reflect/issues/224)
✅ [progression] Tag (all versions) should progression test: fails to preserve lower bound when combining higher-kinded type members
✅ [progression] Tag (all versions) should progression test: fails on Scala 3 don't lose tautological intersection components other than Any/AnyRef
✅ [progression] Tag (all versions) should progression test: intersection tautologies are not removed automatically when constructing combined intersection type
✅ [progression] Tag (Scala 2) should progression test: combine intersection path-dependent intersection types with inner tags doesn't work yet (Scala 2 specific, generic type projection)
✅ [progression] Tag (Scala 2) should progression test: type tags with bounds are not currently requested by the macro on Scala 2
✅ izumi-reflect/izumi-reflect/.jvm/target/test-reports/TEST-izumi.reflect.test.TagTest.xml
81 tests were completed in 2s with 81 passed, 0 failed and 0 skipped.
Test suite | Passed | Failed | Skipped | Time |
---|---|---|---|---|
izumi.reflect.test.TagTest | 81✅ | 2s |
✅ izumi.reflect.test.TagTest
✅ Tag (all versions) should Work for any concrete type
✅ Tag (all versions) should Support identity lambda type equality
✅ Tag (all versions) should regression test for https://github.com/zio/izumi-reflect/issues/98
✅ Tag (all versions) should Work for any abstract type with available Tag when obscured by empty refinement
✅ Tag (all versions) should handle function local type aliases
✅ Tag (all versions) should Can dealias transparent type members with class type parameters inside them when a tag is summoned _inside_ the class, because LightTypeTags are not affected by https://github.com/scala/bug/issues/11139
✅ Tag (all versions) should Tag.auto.T kind inference macro works for known cases
✅ Tag (all versions) should Shouldn't work for any abstract type without available TypeTag or Tag or TagK
✅ Tag (all versions) should handle Id type lambda
✅ Tag (all versions) should handle Id1 type lambda
✅ Tag (all versions) should handle singleton types
✅ Tag (all versions) should handle nested intersection aliases
✅ Tag (all versions) should handle nested refined intersection aliases
✅ Tag (all versions) should simple combined Tag
✅ Tag (all versions) should consider class member's this-prefix to be the defining template, not the most specific prefix from where the call is happening (deliberate omission of this for better ergonomics in cakes)
✅ Tag (all versions) should Does NOT synthesize Tags for abstract types, but recursively summons Tag[this.Abstract]
✅ Tag (all versions) should DOES synthesize Tags for abstract types (object X; X.T), does not summon Tag[X.T]
✅ Tag (all versions) should DOES synthesize Tags for abstract types (trait X; X#T), does not summon Tag[X#T]
✅ Tag (all versions) should DOES synthesize Tags for abstract types (val x; x.T), does not summon Tag[x.T]
✅ Tag (all versions) should Work for an abstract type with available TagK when obscured by empty refinement
✅ Tag (all versions) should Work for an abstract type with available TagK when TagK is requested through an explicit implicit
✅ Tag (all versions) should Work for an abstract type with available TagKK
✅ Tag (all versions) should Work for any configuration of parameters
✅ Tag (all versions) should handle Swap type lambda
✅ Tag (all versions) should Assemble from higher than TagKK tags
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/293 assemble tag for Builder[B, Collection[B]]
✅ Tag (all versions) should combine intersection types
✅ Tag (all versions) should summon HKT Tag for a Java type
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/76 derive tag for a parametric trait inside object
✅ Tag (all versions) should this.type tags should be generated, but are identical with their class / object tag
✅ Tag (all versions) should this.type should have correct prefix
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/83, convert trifunctor tag to bifunctor tag
✅ Tag (all versions) should resolve TagK from TagKK
✅ Tag (all versions) should can materialize TagK for type lambdas that close on a generic parameter with available Tag
✅ Tag (all versions) should can materialize TagK for type lambdas that close on a generic parameter with available Tag when the constructor is a type parameter
✅ Tag (all versions) should type parameter covariance works after combine
✅ Tag (all versions) should combine Const Lambda to TagK
✅ Tag (all versions) should combined TagK 3 & 2 parameter coherence
✅ Tag (all versions) should resolve TagKK from an odd higher-kinded Tag with swapped & ignored parameters
✅ Tag (all versions) should can resolve Tags of TagK's themselves correctly
✅ Tag (all versions) should regression test: ignore function-local anonymous classes (https://github.com/zio/zio/issues/4285)
✅ Tag (all versions) should equal path-dependent tags for singleton types are expected to be equal
✅ Tag (all versions) should return expected class tag
✅ Tag (all versions) should Work with term type prefixes
✅ Tag (all versions) should correctly resolve abstract types inside traits when summoned inside trait
✅ Tag (all versions) should combine higher-kinded type lambdas without losing ignored type arguments
✅ Tag (all versions) should resolve a higher-kinded type inside a named type lambda with ignored type arguments
✅ Tag (all versions) should resolve TagKK from an odd higher-kinded Tag with swapped & ignored parameters (low-level)
✅ Tag (all versions) should correctly resolve a higher-kinded nested type inside a named swap type lambda
✅ Tag (all versions) should support subtyping of parents parameterized with type lambdas in combined tags
✅ Tag (all versions) should support subtyping of parents parameterized with type lambdas in combined tags with multiple parameters
✅ Tag (all versions) should combine inside type lambdas with repeated usages of a type lambda type parameter
✅ Tag (all versions) should combine inside type lambdas with repeated usages of an outer type
✅ Tag (all versions) should combine inside type lambdas with repeated usages of an outer distinct type with the same type symbol
✅ Tag (all versions) should combine inside type lambdas where the type constructor of the type lambda result is a type lambda type parameter
✅ Tag (all versions) should regression test: https://github.com/zio/izumi-reflect/issues/82, convert trifunctor hkt to bifunctor when combining tags
✅ Tag (all versions) should combine higher-kinded types without losing ignored type arguments
✅ Tag (all versions) should resolve a higher-kinded type inside an anonymous type lambda with ignored & higher-kinded type arguments
✅ Tag (all versions) should correctly resolve a higher-kinded nested type inside an anonymous swap type lambda
✅ Tag (all versions) should handles abstract types instead of parameters
✅ Tag (all versions) should Generates lambda parents for lambda bases
✅ Tag (all versions) should subtyping for Invariant Java HKT
✅ Tag (all versions) should subtyping for Invariant Scala HKT
✅ Tag (all versions) should Work for structural concrete types
✅ Tag (all versions) should Work for any abstract type with available Tag while preserving additional type refinement
✅ Tag (all versions) should Work for any abstract type with available Tag while preserving additional method refinement
✅ Tag (all versions) should can resolve parameters in structural types
✅ Tag (all versions) should combine higher-kinded type members
✅ Tag (all versions) should regression test: do not be confused by a type alias of Set of an abstract type referred via this-prefix on Scala 3
✅ Tag (all versions) should support injecting runtime tags in place of type projections from type parameters / match types on type parameters
✅ Tag (all versions) should regression test for: Scala 2, https://github.com/zio/izumi-reflect/issues/189, parameterized type alias with intersection produces incorrect output
✅ Tag (all versions) should combining with wildcards is supported
✅ Tag (all versions) should other type members' bounds are not malformed when resolving parameters in structural types
✅ Tag (all versions) should form a correct type lambda for an equal-bounded abstract type
✅ Tag (all versions) should eradicate intersection tautologies with Any/Object (Tag)
✅ Tag (all versions) should tautological intersections with Any/Object are discarded from internal structure (Tag)
✅ Tag (Scala 2) should Work for an abstract type with available TagK when TagK is requested through an explicit implicit (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should Handle Tags outside of a predefined set (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should Can create custom type tags to support bounded generics, e.g. <: Dep in TagK (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should can find HKTag when obscured by type lambda (Scala 2 HKTag Syntax)
✅ Tag (Scala 2) should we no longer accidentally materialize tags for type parameters that are prefixes of type projections (Scala 2 specific, generic type projection)