Starter template for solving Advent of Code in Kotlin. Advent of Code is an Advent calendar of small programming puzzles by Eric Wastl. Based on aoc-kotlin-starter template by Hugh Davey.
- Gradle setup so you can run a specific day or all days on the command line (see Running)
- Timings for each part of each day
- Input for each day automatically exposed in String and List form
- Junit 5 and AssertJ test libraries included (see Testing)
- Starter .gitignore
Project is already setup with gradle. To run the app:
- Navigate to top-level directory on the command line
- Run
./gradlew runto run all days - Run
./gradlew run --args $DAYwhere$DAYis an integer to run a specific day - Run
./gradlew run --args "$DAY1 $DAY2 $ANOTHERDAY"to run a subset of days
Project includes JUnit and AssertJ and a stub unit test to get you going. To run all tests:
- Navigate to top-level directory on the command line
- Run
./gradlew test - Add
--info,--debugor--stacktraceflags for more output
By default, instantiations of Day classes in tests will use the input files in src/test/resources, not those
in src/main/resources. This hopefully gives you flexibility - you could either just copy the real input
into src/test/resources if you want to test the actual answers, or you could add a file of test data based on the
examples given on the Advent of Code description for the day. The stub Day1Test class shows a test of the
functionality of Day1 where the test input differs from the actual input.
- Inputs go into
src/main/resourcesand follow the naming conventioninput_day_X.txt - Solutions go into
src/main/kotlin/daysand implement thePuzzleinterface - Solutions follow the naming convention
DayX - It is assumed all solutions will have two parts
- It is assumed that the puzzle input is provided through the primary constructor
- You can use the
InputReadermethods for reading input - To get started simply replace
src/main/resources/input_day_1.txtwith the real input and the solutions inDay1with your own