diff options
Diffstat (limited to 'cryptominisat5/cryptominisat-5.6.3/python/tests/test_pycryptosat.py')
-rw-r--r-- | cryptominisat5/cryptominisat-5.6.3/python/tests/test_pycryptosat.py | 256 |
1 files changed, 0 insertions, 256 deletions
diff --git a/cryptominisat5/cryptominisat-5.6.3/python/tests/test_pycryptosat.py b/cryptominisat5/cryptominisat-5.6.3/python/tests/test_pycryptosat.py deleted file mode 100644 index 703d46ec6..000000000 --- a/cryptominisat5/cryptominisat-5.6.3/python/tests/test_pycryptosat.py +++ /dev/null @@ -1,256 +0,0 @@ -# -*- coding: utf-8 -*- -# -# CryptoMiniSat -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to deal -# in the Software without restriction, including without limitation the rights -# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -# THE SOFTWARE. - -from __future__ import unicode_literals -from __future__ import print_function -import sys -import unittest - - -import pycryptosat -from pycryptosat import Solver - - -def check_clause(clause, solution): - for lit in clause: - var = abs(lit) - if lit < 0: - inverted = True - else: - inverted = False - - if solution[var] != inverted: - return True - - -def check_solution(clauses, solution): - for clause in clauses: - if check_clause(clause, solution) is False: - return False - - return True - -# -------------------------- test clauses -------------------------------- - -# p cnf 5 3 -# 1 -5 4 0 -# -1 5 3 4 0 -# -3 -4 0 -clauses1 = [[1, -5, 4], [-1, 5, 3, 4], [-3, -4]] - -# p cnf 2 2 -# -1 0 -# 1 0 -clauses2 = [[-1], [1]] - -# p cnf 2 3 -# -1 2 0 -# -1 -2 0 -# 1 -2 0 -clauses3 = [[-1, 2], [-1, -2], [1, -2]] - -# -------------------------- actual unit tests --------------------------- - - -class TestXor(unittest.TestCase): - - def setUp(self): - self.solver = Solver(threads=2) - - def test_wrong_args(self): - self.assertRaises(TypeError, self.solver.add_xor_clause, [1, 2]) - self.assertRaises(ValueError, self.solver.add_xor_clause, [1, 0], True) - self.assertRaises( - ValueError, self.solver.add_xor_clause, [-1, 2], True) - - def test_binary(self): - self.solver.add_xor_clause([1, 2], False) - res, solution = self.solver.solve([1]) - self.assertEqual(res, True) - self.assertEqual(solution, (None, True, True)) - - def test_unit(self): - self.solver.add_xor_clause([1], False) - res, solution = self.solver.solve() - self.assertEqual(res, True) - self.assertEqual(solution, (None, False)) - - def test_unit2(self): - self.solver.add_xor_clause([1], True) - res, solution = self.solver.solve() - self.assertEqual(res, True) - self.assertEqual(solution, (None, True)) - - def test_3_long(self): - self.solver.add_xor_clause([1, 2, 3], False) - res, solution = self.solver.solve([1, 2]) - self.assertEqual(res, True) - # self.assertEqual(solution, (None, True, True, False)) - - def test_3_long2(self): - self.solver.add_xor_clause([1, 2, 3], True) - res, solution = self.solver.solve([1, -2]) - self.assertEqual(res, True) - self.assertEqual(solution, (None, True, False, False)) - - def test_long(self): - for l in range(10, 30): - self.setUp() - toadd = [] - toassume = [] - solution_expected = [None] - for i in range(1, l): - toadd.append(i) - solution_expected.append(False) - if i != l - 1: - toassume.append(i * -1) - - self.solver.add_xor_clause(toadd, False) - res, solution = self.solver.solve(toassume) - self.assertEqual(res, True) - self.assertEqual(solution, tuple(solution_expected)) - - -class InitTester(unittest.TestCase): - - def test_wrong_args_to_solver(self): - self.assertRaises(ValueError, Solver, threads=-1) - self.assertRaises(ValueError, Solver, threads=0) - self.assertRaises(ValueError, Solver, verbose=-1) - self.assertRaises(ValueError, Solver, time_limit=-1) - self.assertRaises(ValueError, Solver, confl_limit=-1) - self.assertRaises(TypeError, Solver, threads="fail") - self.assertRaises(TypeError, Solver, verbose="fail") - self.assertRaises(TypeError, Solver, time_limit="fail") - self.assertRaises(TypeError, Solver, confl_limit="fail") - - -class TestDump(unittest.TestCase): - - def setUp(self): - self.solver = Solver() - - def test_one_dump(self): - with open("tests/test.cnf", "r") as x: - for line in x: - line = line.strip() - if "p" in line or "c" in line: - continue - - out = [int(x) for x in line.split()[:-1]] - self.solver.add_clause(out) - - res, _ = self.solver.solve() - self.assertEqual(res, True) - - self.solver.start_getting_small_clauses(4) - x = self.solver.get_next_small_clause() - self.assertNotEquals(x, None) - self.solver.end_getting_small_clauses() - - -class TestSolve(unittest.TestCase): - - def setUp(self): - self.solver = Solver(threads=2) - - def test_wrong_args(self): - self.assertRaises(TypeError, self.solver.add_clause, 'A') - self.assertRaises(TypeError, self.solver.add_clause, 1) - self.assertRaises(TypeError, self.solver.add_clause, 1.0) - self.assertRaises(TypeError, self.solver.add_clause, object()) - self.assertRaises(TypeError, self.solver.add_clause, ['a']) - self.assertRaises( - TypeError, self.solver.add_clause, [[1, 2], [3, None]]) - self.assertRaises(ValueError, self.solver.add_clause, [1, 0]) - - def test_no_clauses(self): - for _ in range(7): - self.assertEqual(self.solver.solve([]), (True, (None,))) - - def test_cnf1(self): - for cl in clauses1: - self.solver.add_clause(cl) - res, solution = self.solver.solve() - self.assertEqual(res, True) - self.assertTrue(check_solution(clauses1, solution)) - - def test_bad_iter(self): - class Liar: - - def __iter__(self): - return None - self.assertRaises(TypeError, self.solver.add_clause, Liar()) - - def test_cnf2(self): - for cl in clauses2: - self.solver.add_clause(cl) - self.assertEqual(self.solver.solve(), (False, None)) - - def test_cnf3(self): - for cl in clauses3: - self.solver.add_clause(cl) - res, solution = self.solver.solve() - self.assertEqual(res, True) - self.assertTrue(check_solution(clauses3, solution)) - - def test_cnf1_confl_limit(self): - for _ in range(1, 20): - self.setUp() - for cl in clauses1: - self.solver.add_clause(cl) - - res, solution = self.solver.solve() - self.assertTrue(res is None or check_solution(clauses1, solution)) - - def test_by_re_curse(self): - self.solver.add_clause([-1, -2, 3]) - res, _ = self.solver.solve() - self.assertEqual(res, True) - - self.solver.add_clause([-5, 1]) - self.solver.add_clause([4, -3]) - self.solver.add_clause([2, 3, 5]) - res, _ = self.solver.solve() - self.assertEqual(res, True) - -# ------------------------------------------------------------------------ - - -def run(): - print("sys.prefix: %s" % sys.prefix) - print("sys.version: %s" % sys.version) - try: - print("pycryptosat version: %r" % pycryptosat.__version__) - except AttributeError: - pass - suite = unittest.TestSuite() - suite.addTest(unittest.makeSuite(TestXor)) - suite.addTest(unittest.makeSuite(InitTester)) - suite.addTest(unittest.makeSuite(TestSolve)) - suite.addTest(unittest.makeSuite(TestDump)) - - runner = unittest.TextTestRunner(verbosity=2) - return runner.run(suite) - -if __name__ == '__main__': - run() |