Ejemplo n.º 1
0
 def test_creation_of_symmetrical_lattice_from_valid_string(self):
     lattice = Lattice.from_string("x x\n" " x \n" "x x\n")
     self.assertEqual(lattice.size, 3)
     self.assertTrue(lattice.is_live(0, 0))
     self.assertTrue(lattice.is_dead(0, 1))
     self.assertTrue(lattice.is_live(0, 2))
     self.assertTrue(lattice.is_dead(1, 0))
     self.assertTrue(lattice.is_live(1, 1))
     self.assertTrue(lattice.is_dead(1, 2))
     self.assertTrue(lattice.is_live(2, 0))
     self.assertTrue(lattice.is_dead(2, 1))
     self.assertTrue(lattice.is_live(2, 2))
Ejemplo n.º 2
0
 def test_creation_fails_on_rows_count_mismatch(self):
     with self.assertRaises(InvalidSizeError) as cm:
         Lattice.from_string("x x\n")
Ejemplo n.º 3
0
 def test_creation_fails_when_string_is_empty(self):
     with self.assertRaises(InvalidSizeError) as cm:
         Lattice.from_string("")
Ejemplo n.º 4
0
 def test_creation_fails_when_string_contains_invalid_symbol(self):
     with self.assertRaises(InvalidSymbolError) as cm:
         Lattice.from_string("q\n")
     self.assertRegex(str(cm.exception), r"^.*q.*$")
     self.assertRegex(str(cm.exception), r"^.*0.*0.*$")
Ejemplo n.º 5
0
 def test_creation_of_lattice_from_game1_succeeds(self):
     lattice1 = Lattice.from_string("     \n" "     \n" " xxx \n" "     \n" "     \n")
     self.assertEqual(lattice1.size, 5)
Ejemplo n.º 6
0
 def test_creation_of_lattice_with_trailing_new_lines_succeeds(self):
     lattice1 = Lattice.from_string("x x\n" "\n" "\n")
     lattice2 = Lattice.from_string("x x\n" "   \n" "   \n")
     self.assertEqual(lattice1, lattice2)
Ejemplo n.º 7
0
 def test_creation_of_single_cell_lattice_succeeds(self):
     lattice = Lattice.from_string("x")
     self.assertTrue(lattice.is_live(0, 0))
Ejemplo n.º 8
0
 def test_two_lattices_with_different_sizes_are_not_equal(self):
     lattice1 = Lattice.from_string("x x\n" "xxx\n" " x \n")
     lattice2 = Lattice.from_string("x \n" " x\n")
     self.assertNotEqual(lattice1, lattice2)
     self.assertFalse(lattice1 == lattice2)
Ejemplo n.º 9
0
 def test_no_neighbours(self):
     lattice = Lattice.from_string("x")
     self.assertEqual(lattice.get_num_of_live_neighbours(0, 0), 0)
Ejemplo n.º 10
0
 def test_out_of_bounds_error_is_raised_on_invalid_position(self):
     lattice = Lattice.from_string("x")
     with self.assertRaises(OutOfBoundsError):
         lattice.get_num_of_live_neighbours(1, 1)
Ejemplo n.º 11
0
 def test_all_neighbours_are_live(self):
     lattice = Lattice.from_string("xxx\n" "xxx\n" "xxx\n")
     self.assertEqual(lattice.get_num_of_live_neighbours(1, 1), 8)
Ejemplo n.º 12
0
 def test_no_live_neighbour(self):
     lattice = Lattice.from_string("   \n" " x \n" "   \n")
     self.assertEqual(lattice.get_num_of_live_neighbours(1, 1), 0)
Ejemplo n.º 13
0
 def test_repr_returns_correct_result(self):
     lattice = Lattice.from_string("x x\n" "xxx\n" " x \n")
     lattice_str = repr(lattice)
     self.assertEqual(lattice, Lattice.from_string(lattice_str))
Ejemplo n.º 14
0
 def test_creation_fails_on_columns_count_mismatch(self):
     with self.assertRaises(InvalidSizeError) as cm:
         Lattice.from_string("x_x\n" "xxx\n" "xx\n", dead_symbol="_")
Ejemplo n.º 15
0
 def test_creation_of_asymmetrical_lattice_from_string(self):
     lattice = Lattice.from_string("xx\n" "  \n")
     self.assertTrue(lattice.is_live(0, 0))
     self.assertTrue(lattice.is_live(0, 1))
     self.assertTrue(lattice.is_dead(1, 0))
     self.assertTrue(lattice.is_dead(1, 1))
Ejemplo n.º 16
0
 def from_string(str, dead_symbol=' ', live_symbol='x'):
     lattice = Lattice.from_string(str, dead_symbol, live_symbol)
     game = Game(lattice.size)
     game._lattice = lattice
     return game
Ejemplo n.º 17
0
 def test_two_lattices_with_same_data_are_equal(self):
     lattice1 = Lattice.from_string("x x\n" "xxx\n" " x \n")
     lattice2 = Lattice.from_string("x x\n" "xxx\n" " x \n")
     self.assertEqual(lattice1, lattice2)
     self.assertFalse(lattice1 != lattice2)