Skip to content

Commit

Permalink
🚨 Test load_vars()
Browse files Browse the repository at this point in the history
  • Loading branch information
ruaridhw committed May 6, 2020
1 parent 6414dda commit e363afe
Showing 1 changed file with 77 additions and 0 deletions.
77 changes: 77 additions & 0 deletions pyomo/solvers/tests/checks/test_CPLEXDirect.py
Original file line number Diff line number Diff line change
Expand Up @@ -520,5 +520,82 @@ def test_add_block_containing_multiple_constraints(self):
self.assertEqual(opt._solver_model.linear_constraints.get_num(), 3)


@unittest.skipIf(not unittest.mock_available, "'mock' is not available")
@unittest.skipIf(not cplexpy_available, "The 'cplex' python bindings are not available")
class TestLoadVars(unittest.TestCase):
def setUp(self):
opt = SolverFactory("cplex", solver_io="python")
model = ConcreteModel()
model.X = Var(within=NonNegativeReals, initialize=0)
model.Y = Var(within=NonNegativeReals, initialize=0)

model.C1 = Constraint(expr=2 * model.X + model.Y >= 8)
model.C2 = Constraint(expr=model.X + 3 * model.Y >= 6)

model.O = Objective(expr=model.X + model.Y)

opt.solve(model, load_solutions=False, save_results=False)

self._model = model
self._opt = opt

def test_all_vars_are_loaded(self):
self.assertTrue(self._model.X.stale)
self.assertTrue(self._model.Y.stale)
self.assertEqual(value(self._model.X), 0)
self.assertEqual(value(self._model.Y), 0)

with unittest.mock.patch.object(
self._opt._solver_model.solution,
"get_values",
wraps=self._opt._solver_model.solution.get_values,
) as wrapped_values_call:
self._opt.load_vars()

self.assertEqual(wrapped_values_call.call_count, 1)
self.assertEqual(wrapped_values_call.call_args, tuple())

self.assertFalse(self._model.X.stale)
self.assertFalse(self._model.Y.stale)
self.assertAlmostEqual(value(self._model.X), 3.6)
self.assertAlmostEqual(value(self._model.Y), 0.8)

def test_only_specified_vars_are_loaded(self):
self.assertTrue(self._model.X.stale)
self.assertTrue(self._model.Y.stale)
self.assertEqual(value(self._model.X), 0)
self.assertEqual(value(self._model.Y), 0)

with unittest.mock.patch.object(
self._opt._solver_model.solution,
"get_values",
wraps=self._opt._solver_model.solution.get_values,
) as wrapped_values_call:
self._opt.load_vars([self._model.X])

self.assertEqual(wrapped_values_call.call_count, 1)
self.assertEqual(wrapped_values_call.call_args, (([0],), {}))

self.assertFalse(self._model.X.stale)
self.assertTrue(self._model.Y.stale)
self.assertAlmostEqual(value(self._model.X), 3.6)
self.assertEqual(value(self._model.Y), 0)

with unittest.mock.patch.object(
self._opt._solver_model.solution,
"get_values",
wraps=self._opt._solver_model.solution.get_values,
) as wrapped_values_call:
self._opt.load_vars([self._model.Y])

self.assertEqual(wrapped_values_call.call_count, 1)
self.assertEqual(wrapped_values_call.call_args, (([1],), {}))

self.assertFalse(self._model.X.stale)
self.assertFalse(self._model.Y.stale)
self.assertAlmostEqual(value(self._model.X), 3.6)
self.assertAlmostEqual(value(self._model.Y), 0.8)


if __name__ == "__main__":
unittest.main()

0 comments on commit e363afe

Please sign in to comment.