aboutsummaryrefslogtreecommitdiff
path: root/aoc2023/test/day8/day8_test.gleam
diff options
context:
space:
mode:
authorHunky Jimpjorps <thechairman@thechairman.info>2023-12-08 09:42:13 -0500
committerHunky Jimpjorps <thechairman@thechairman.info>2023-12-08 09:42:13 -0500
commitdf2f2fd140f188dfb5df68b44e397a8855e79f02 (patch)
tree9bb603eba8a3c46848bc59a6c5ba1c73ed34759c /aoc2023/test/day8/day8_test.gleam
parent82c3ecec3de5111b460910bafe141b3aed478676 (diff)
parentb51dd4b3768bce0209733ef2562cb96e5330d3c6 (diff)
downloadgleam_aoc-df2f2fd140f188dfb5df68b44e397a8855e79f02.tar.gz
gleam_aoc-df2f2fd140f188dfb5df68b44e397a8855e79f02.zip
Merge branch 'main' of https://github.com/hunkyjimpjorps/AdventOfCode
Diffstat (limited to 'aoc2023/test/day8/day8_test.gleam')
-rw-r--r--aoc2023/test/day8/day8_test.gleam61
1 files changed, 61 insertions, 0 deletions
diff --git a/aoc2023/test/day8/day8_test.gleam b/aoc2023/test/day8/day8_test.gleam
new file mode 100644
index 0000000..2cd499a
--- /dev/null
+++ b/aoc2023/test/day8/day8_test.gleam
@@ -0,0 +1,61 @@
+import gleam/list
+import showtime/tests/should
+import adglent.{type Example, Example}
+import day8/solve
+
+type Problem1AnswerType =
+ Int
+
+type Problem2AnswerType =
+ Int
+
+/// Add examples for part 1 here:
+/// ```gleam
+///const part1_examples: List(Example(Problem1AnswerType)) = [Example("some input", "")]
+/// ```
+const part1_examples: List(Example(Problem1AnswerType)) = [
+ Example(
+ "LLR
+
+AAA = (BBB, BBB)
+BBB = (AAA, ZZZ)
+ZZZ = (ZZZ, ZZZ)",
+ 6,
+ ),
+]
+
+/// Add examples for part 2 here:
+/// ```gleam
+///const part2_examples: List(Example(Problem2AnswerType)) = [Example("some input", "")]
+/// ```
+const part2_examples: List(Example(Problem2AnswerType)) = [
+ Example(
+ "LR
+
+11A = (11B, XXX)
+11B = (XXX, 11Z)
+11Z = (11B, XXX)
+22A = (22B, XXX)
+22B = (22C, 22C)
+22C = (22Z, 22Z)
+22Z = (22B, 22B)
+XXX = (XXX, XXX)",
+ 6,
+ ),
+]
+
+pub fn part1_test() {
+ part1_examples
+ |> should.not_equal([])
+ use example <- list.map(part1_examples)
+ solve.part1(example.input)
+ |> should.equal(example.answer)
+}
+
+pub fn part2_test() {
+ part2_examples
+ |> should.not_equal([])
+ use example <- list.map(part2_examples)
+ solve.part2(example.input)
+ |> should.equal(example.answer)
+}