diff --git a/src/scimlfunctions.jl b/src/scimlfunctions.jl index 391859e20..b3949a96a 100644 --- a/src/scimlfunctions.jl +++ b/src/scimlfunctions.jl @@ -4067,8 +4067,8 @@ function BVPFunction{iip, specialize, twopoint}(f, bc; end if twopoint - if iip && (bcresid_prototype === nothing || length(bcresid_prototype) != 2) - error("bcresid_prototype must be a tuple / indexable collection of length 2 for a inplace TwoPointBVPFunction") + if iip && bcresid_prototype !== nothing + @assert length(bcresid_prototype) == 2 error("bcresid_prototype must be a tuple / indexable collection of length 2 for an inplace TwoPointBVPFunction") end if bcresid_prototype !== nothing && length(bcresid_prototype) == 2 bcresid_prototype = ArrayPartition(first(bcresid_prototype), diff --git a/test/function_building_error_messages.jl b/test/function_building_error_messages.jl index 924c342e5..5c6e189a7 100644 --- a/test/function_building_error_messages.jl +++ b/test/function_building_error_messages.jl @@ -618,6 +618,14 @@ BVPFunction(bfiip, bciip, vjp = bvjp) @test_throws SciMLBase.NonconformingFunctionsError BVPFunction(bfoop, bciip, vjp = bvjp) +# TwoPointBVPFunction + +tpbvpf(du, u, p, t) = du .= u +tpbvpbca(resa, ua, p) = resa .= ua +tpbvpbcb(resb, ub, p) = resb .= ub +SciMLBase.TwoPointBVPFunction(tpbvpf, (tpbvpbca, tpbvpbcb)) +@test_throws ErrorException SciMLBase.TwoPointBVPFunction(tpbvpf, (tpbvpbca, tpbvpbcb), bcresid_prototype = (1, 1, 1)) + # IntegralFunction ioop(u, p) = p * u