From 1d9bd0b6f5dad2f4580f318ac6dd3a7ac04d19a2 Mon Sep 17 00:00:00 2001 From: Max Horn Date: Wed, 2 Feb 2022 22:44:22 +0100 Subject: [PATCH] conformance: types can't imply finiteness Finitely presented groups can be both finite and infinite, so it is not practical to require that the type of a group must already imply whether instances of the type are finite or infinite. Yet the conformance tests were doing exactly that. --- test/conformance_test.jl | 46 +++++++++++++++++++++++++++------------- 1 file changed, 31 insertions(+), 15 deletions(-) diff --git a/test/conformance_test.jl b/test/conformance_test.jl index 071e613..005e962 100644 --- a/test/conformance_test.jl +++ b/test/conformance_test.jl @@ -5,22 +5,38 @@ function test_Group_interface(G::Group) @testset "Group interface" begin @testset "Iteration protocol" begin IS = Base.IteratorSize(typeof(G)) - if IS isa Base.HasLength || IS isa Base.HasShape - @test isfinite(G) == true - @test length(G) isa Int - @test length(G) > 0 - - @test eltype(G) <: GroupElement - @test one(G) isa eltype(G) - - if GroupsCore.hasgens(G) - @test first(iterate(G)) isa eltype(G) - _, s = iterate(G) - @test first(iterate(G, s)) isa eltype(G) - @test isone(first(G)) - end - else + if IS isa Base.IsInfinite @test isfinite(G) == false + else + isfiniteG = false + if IS isa Base.HasLength || IS isa Base.HasShape + @test isfinite(G) == true + isfiniteG = true + else + @test IS isa Base.SizeUnknown + try + @test isfinite(G) isa Bool + isfiniteG = isfinite(G) + catch e + @test e isa GroupsCore.InfiniteOrder + isfiniteG = false + end + end + + if isfiniteG + @test length(G) isa Int + @test length(G) > 0 + + @test eltype(G) <: GroupElement + @test one(G) isa eltype(G) + + if GroupsCore.hasgens(G) + @test first(iterate(G)) isa eltype(G) + _, s = iterate(G) + @test first(iterate(G, s)) isa eltype(G) + @test isone(first(G)) + end + end end end