From 5459398f6ca3f0a34eb14343147068a704338a81 Mon Sep 17 00:00:00 2001 From: Oscar Dowson Date: Wed, 19 Jun 2024 14:01:48 +1200 Subject: [PATCH] Add more tests to improve code coverage (#215) --- src/MOI_wrapper.jl | 6 +++--- test/MOI_wrapper.jl | 38 ++++++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 3 deletions(-) diff --git a/src/MOI_wrapper.jl b/src/MOI_wrapper.jl index bb7703d..242dac3 100644 --- a/src/MOI_wrapper.jl +++ b/src/MOI_wrapper.jl @@ -304,9 +304,9 @@ mutable struct Optimizer <: MOI.AbstractOptimizer _Solution(), ) MOI.empty!(model) - @static if Sys.iswindows() - # Set number of threads by default on Windows. This fixes a - # hang in some versions of Highs_jll. For discussion, see + if Sys.iswindows() + # Set number of threads by default on Windows. This fixes a hang in + # some versions of Highs_jll. For discussion, see # https://github.com/ERGO-Code/HiGHS/issues/1257 n_threads = max(1, div(length(Sys.cpu_info()), 2)) MOI.set(model, MOI.NumberOfThreads(), n_threads) diff --git a/test/MOI_wrapper.jl b/test/MOI_wrapper.jl index a985249..b7f3934 100644 --- a/test/MOI_wrapper.jl +++ b/test/MOI_wrapper.jl @@ -848,6 +848,44 @@ function test_copy_to_unsupported_constraint() return end +function test_delete_constraint_twice() + model = HiGHS.Optimizer() + x = MOI.add_variable(model) + ci = MOI.add_constraint(model, 1.0 * x, MOI.EqualTo(1.0)) + @test_throws( + ErrorException( + "Encountered an error in HiGHS (Status -1). Check the log " * + "for details.", + ), + MOI.delete(model, [ci, ci]), + ) + return +end + +function test_RawStatusStringOptimizeNotCalled() + model = HiGHS.Optimizer() + @test MOI.get(model, MOI.RawStatusString()) == "OPTIMIZE_NOT_CALLED" + @test MOI.get(model, MOI.ResultCount()) == 0 + return +end + +function test_nonbasic_equality_constraint() + model = HiGHS.Optimizer() + x = MOI.add_variable(model) + ci = MOI.add_constraint(model, 1.0 * x, MOI.EqualTo(1.0)) + MOI.optimize!(model) + @test MOI.get(model, MOI.ConstraintBasisStatus(), ci) == MOI.NONBASIC + return +end + +function test_variable_basis_status_zero() + model = HiGHS.Optimizer() + x = MOI.add_variable(model) + MOI.optimize!(model) + @test MOI.get(model, MOI.VariableBasisStatus(), x) == MOI.NONBASIC + return +end + end # module TestMOIHighs.runtests()