def test_shortest(self): "Test the shortest path" self.assertEqual(doors.Doors(["ihgpwlah"]).shortest(), "DDRRRD") self.assertEqual(doors.Doors(["kglvqrro"]).shortest(), "DDUDRLRRUDRD") self.assertEqual( doors.Doors(["ulqzkmiv"]).shortest(), "DRURDRUDDLLDLUURRDULRLDUUDDDRR")
def test_part_two(self): "Test part two example of Doors object" # 1. Create Doors object from text myobj = doors.Doors(part2=True, text=aoc_17.from_text(PART_TWO_TEXT)) # 2. Check the part two result self.assertEqual(myobj.part_two(verbose=False), PART_TWO_RESULT)
def test_part_one(self): "Test part one example of Doors object" # 1. Create Doors object from text myobj = doors.Doors(text=aoc_17.from_text(PART_ONE_TEXT)) # 2. Check the part one result self.assertEqual(myobj.part_one(verbose=False), PART_ONE_RESULT)
def test_empty_init(self): "Test the default Doors creation" # 1. Create default Doors object myobj = doors.Doors() # 2. Make sure it has the default values self.assertEqual(myobj.part2, False) self.assertEqual(myobj.text, None) self.assertEqual(myobj.seed, None)
def test_text_init(self): "Test the Doors object creation from text" # 1. Create Doors object from text myobj = doors.Doors(text=aoc_17.from_text(EXAMPLE_TEXT)) # 2. Make sure it has the expected values self.assertEqual(myobj.part2, False) self.assertEqual(len(myobj.text), 1) self.assertEqual(myobj.seed, "ihgpwlah") # 3. Check methods self.assertEqual(myobj.shortest(), "DDRRRD") self.assertEqual(myobj.longest(), 370)
def part_two(args, input_lines): "Process part two of the puzzle" # 1. Create the puzzle solver solver = doors.Doors(part2=True, text=input_lines) # 2. Determine the solution for part two solution = solver.part_two(verbose=args.verbose, limit=args.limit) if solution is None: print("There is no solution") else: print("The solution for part two is %s" % (solution)) # 3. Return result return solution is not None
def test_longest(self): "Test the longest path" self.assertEqual(doors.Doors(["ihgpwlah"]).longest(), 370) self.assertEqual(doors.Doors(["kglvqrro"]).longest(), 492) self.assertEqual(doors.Doors(["ulqzkmiv"]).longest(), 830)