Skip to content

39services/ansible_advent_of_code_2022

Repository files navigation

Advent of Code 2022, in Ansible!

This repository contains my solutions to the Advent of Code 2022 challenges!

To challenge myself a lot, I decided to write these in my golden hammer, Ansible. I will regret this! :​D

For context, Ansible is a configuration management tool that is used to configure servers. It is not meant to be used as a programming language and it is not very good at it. It does however come with a strong (in-line) Jinja2 templating engine and it exposes some of the Python objects it uses internally, so it is possible to do some programming with it. The Python methods don't end up being very useful since they're hard to chain together and they don't return anything useful aside from slightly manipulating the data, something Ansible and Jinja2 filters are much better at.

I want this to actually be solving Advent of Code in Ansible, not using Ansible to call Python modules, shell scripts or other external programs. For this reason I will try to use the Ansible Collections ansible.builtin, ansible.utils and community.general for modules and filters as much as possible.

This means the bulk of the operations will be done with ansible.builtin.set_fact combined with many loops, whens, untils and other Ansible magic! This repository will likely end up containing a lot of Jinja2 statements that I hope will end up being useful to know outside of this challenge.

I started this back in December of 2022 but did not get around to finishing it. My goal is to finish it before the 2023 edition starts. Maybe I'll do something even worse for that one! Terraform, maybe? :​D

I'm not even gonna bother with Ansible Lint for this one, I'm sure it will be very unhappy with me! :​D

Side note, GitHub Copilot is the one adding these ":​D" at the end of my sentences, I'm not that happy about doing this! :​D

Day Name Stars Reaction Time to run
1 Calorie Counting ⭐ ⭐ 🤪 6s
2 Rock Paper Scissors ⭐ ⭐ 😝 1m 34s
3 Rucksack Reorganization ⭐ ⭐ 😏 22s
4 Camp Cleanup ⭐ ⭐ 😨 7m 9s
5 Supply Stacks ⭐ ⭐ 😱 6m 24s
6 Tuning Trouble ⭐ ⭐ 😌 1m 31s
7 No Space Left On Device 🤯
8 Treetop Tree House ⭐ ⭐ 😵 3h 45m 47s
9 Rope Bridge
10 Cathode-Ray Tube
11 Monkey in the Middle
12 Hill Climbing Algorithm
13 Distress Signal
14 Regolith Reservoir
15 Beacon Exclusion Zone
16 Proboscidea Volcanium
17 Pyroclastic Flow
18 Boiling Boulders
19 Not Enough Minerals
20 Grove Positioning System
21 Monkey Math
22 Monkey Map
23 Unstable Diffusion
24 Blizzard Basin
25 Full of Hot Air

Times are for the real inputs, on a Ryzen 9 7950X with 64GB of CL30 RAM.
I had previously run some of these on a Ryzen 5 5600X, it seems the 7950X is about 33% faster.

The "Reaction" column is how I felt about the puzzle and how hellish it was to solve in Ansible.

The Ansible code will run completely in memory on the local machine, so no need to configure hosts.

To run the code, you will need to have Ansible installed. You can install it with pip install ansible.

Then, you can run the code with ansible-playbook playbooks/all.yml.

This will only use the example inputs given by advent of code, these are quite small and shouldn't take too long to run.
To use the real inputs I was given, run the command again and add -i inputs. The inputs are located in files in inputs/group_vars/all/day*.yml.

❗ Real inputs are very large and may take several hours to process

Then, you can run the code with ansible-playbook playbooks/all.yml -i inputs.

To limit it to specific days you can use tags. Some days can take a while, Ansible was never meant to be used like this! :​)

For example, to run only day 1, you can run ansible-playbook playbook.yml --tags day1.

You can find more on Ansible filters here: Ansible Filters documentation.
This is not a comprehensive list, and Ansible Collections can include more filters. Check #goals for which filters I will use.

The following Jinja2 Filters are also available: List of Jinja2 filters.

While the filters and Jinja2 templating engine is primarily made to write configuration files, it is available in-line in Ansible tasks. Ansible's flow control statements interpret the input as a Jinja2 template, which is what allows for most of the flexibility you see here. Any text put inside Jinja2 delimiters will be interpreted as Jinja2 for any text, this allows for data manipulation and finer flow control.

The code is licensed under the MIT license, feel free to take inspiration and learn from my awful Jinja2 statements! I regularly use this repository as a cheat sheet for Jinja2 and Ansible filters so I hope it can be useful to others as well.