import gleam/list import showtime/tests/should import adglent.{type Example, Example} import day2/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( "Game 1: 3 blue, 4 red; 1 red, 2 green, 6 blue; 2 green Game 2: 1 blue, 2 green; 3 green, 4 blue, 1 red; 1 green, 1 blue Game 3: 8 green, 6 blue, 20 red; 5 blue, 4 red, 13 green; 5 green, 1 red Game 4: 1 green, 3 red, 6 blue; 3 green, 6 red; 3 green, 15 blue, 14 red Game 5: 6 red, 1 blue, 3 green; 2 blue, 1 red, 2 green", 8, ), ] /// Add examples for part 2 here: /// ```gleam ///const part2_examples: List(Example(Problem2AnswerType)) = [Example("some input", "")] /// ``` const part2_examples: List(Example(Problem2AnswerType)) = [ Example( "Game 1: 3 blue, 4 red; 1 red, 2 green, 6 blue; 2 green Game 2: 1 blue, 2 green; 3 green, 4 blue, 1 red; 1 green, 1 blue Game 3: 8 green, 6 blue, 20 red; 5 blue, 4 red, 13 green; 5 green, 1 red Game 4: 1 green, 3 red, 6 blue; 3 green, 6 red; 3 green, 15 blue, 14 red Game 5: 6 red, 1 blue, 3 green; 2 blue, 1 red, 2 green", 2286, ), Example( "Game 1: 3 blue, 4 red; 1 red, 2 green, 6 blue; 2 green", 48, ), ] 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) }