-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpysolve.py
67 lines (52 loc) Β· 2.12 KB
/
pysolve.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import os
import shutil
import sys
import time
from colorama import Fore, Style, init
from pyutils import download, puzzle_input
init()
year = sys.argv[1]
day = str(sys.argv[2]).zfill(2)
day_folder = os.path.join(year, day)
if not os.path.exists(day_folder):
os.makedirs(day_folder)
shutil.copy(os.path.join('template', '__init__.py'),
os.path.join(day_folder, '__init__.py'))
open(os.path.join(day_folder, 'test.txt'), 'a').close()
os.chdir(os.path.abspath(os.sep.join([year, day])))
download(*sys.argv[1:])
solution = getattr(__import__('.'.join([year, day])), day)
parse = solution.parse if hasattr(solution, 'parse') else lambda x: x
def with_duration(func):
start = time.perf_counter()
result = func()
duration = time.perf_counter() - start
return (result, duration)
def run(part):
solver_name = f'solve{part}'
if hasattr(solution, solver_name):
print()
print(f'Part {part}')
solver = getattr(solution, solver_name)
if hasattr(solver, 'expectations'):
max_testname = max(len(testname)
for testname in solver.expectations.keys())
for filename, expectation in solver.expectations.items():
result = solver(parse(puzzle_input(
f'{filename}.txt') if filename.startswith('test') else [filename]))
if result == expectation:
print(
f' {filename:<{max_testname+2}}{Fore.GREEN}PASS{Style.RESET_ALL}')
else:
print(
f' {filename:<{max_testname+2}}{Fore.RED}FAIL{Style.RESET_ALL} (expected {expectation}, got {result})')
raise AssertionError()
result, duration_sec = with_duration(
lambda: solver(parse(puzzle_input())))
print(f' solution = {result} ({int(duration_sec*1000)}ms)')
try:
print(f'AoC.{Fore.LIGHTGREEN_EX}{year}{Style.RESET_ALL}.{Fore.LIGHTYELLOW_EX}{day}{Style.RESET_ALL}')
run(1)
run(2)
except AssertionError:
pass