aoc/2024/09/solution.test.nix

131 lines
3.8 KiB
Nix
Raw Normal View History

{describe, it, ...}:
let
pkgs = import <nixpkgs> {};
lib = pkgs.lib;
solution = import ./solution.nix pkgs;
sample1 = "2333133121414131402";
/*
0099811188827773336446555566
*/
sample1defraged = [
{ id = 0; size = 2; start = 0; }
{ id = 9; size = 2; start = 2; }
{ id = 8; size = 1; start = 4; }
{ id = 1; size = 3; start = 5; }
{ id = 8; size = 3; start = 8; }
{ id = 2; size = 1; start = 11; }
{ id = 7; size = 3; start = 12; }
{ id = 3; size = 3; start = 15; }
{ id = 6; size = 1; start = 18; }
{ id = 4; size = 2; start = 19; }
{ id = 6; size = 1; start = 21; }
{ id = 5; size = 4; start = 22; }
{ id = 6; size = 1; start = 26; }
{ id = 6; size = 1; start = 27; }
];
sample2 = "12345";
sample2disk = [
{id = 0; size = 1; start = 0;}
{id = null; size = 2; start = 1;}
{id = 1; size = 3; start = 3;}
{id = null; size = 4; start = 6;}
{id = 2; size = 5; start = 10;}
];
in [
(describe "part 1" [
(it "gets list of disk chunks" {
actual = (solution sample2).disk;
expected = sample2disk;
})
(it "gets list of disk chunks with bigger sample" {
actual = (solution sample1).disk;
expected = [
{ id = 0; size = 2; start = 0; }
{ id = null; size = 3; start = 2; }
{ id = 1; size = 3; start = 5; }
{ id = null; size = 3; start = 8; }
{ id = 2; size = 1; start = 11; }
{ id = null; size = 3; start = 12; }
{ id = 3; size = 3; start = 15; }
{ id = null; size = 1; start = 18; }
{ id = 4; size = 2; start = 19; }
{ id = null; size = 1; start = 21; }
{ id = 5; size = 4; start = 22; }
{ id = null; size = 1; start = 26; }
{ id = 6; size = 4; start = 27; }
{ id = null; size = 1; start = 31; }
{ id = 7; size = 3; start = 32; }
{ id = null; size = 1; start = 35; }
{ id = 8; size = 4; start = 36; }
{ id = null; size = 0; start = 40; }
{ id = 9; size = 2; start = 40; }
];
})
(it "defrags files" {
actual = (solution sample1).defragged.files
|> builtins.filter ({size,...}: size > 0)
|> lib.sort (a: b: a.start < b.start);
expected = sample1defraged;
})
# (it "defrags a file" {
# actual = (solution sample1).defrag
# [
# {id = null; size = 1; start = 10;}
# {id = null; size = 5; start = 15;}
# {id = null; size = 10; start = 50;}
# {id = 1; size = 100; start = 100;}
# ]
# {id = 1; size = 100; start = 100;};
# expected = {
# file = [
# { id = 1; size = 1; start = 10; }
# { id = 1; size = 5; start = 15; }
# { id = 1; size = 10; start = 50;}
# { id = 1; size = 100 - 10 - 5 - 1; start = 100;}
# ];
# free = [
# {id = null; start = 100 + 100 - 10 - 5 - 1; size = 1 + 5 + 10;}
# ];
# };
# })
#
# (it "doesn't defrag a file to the left of free space" {
# actual = (solution sample1).defrag
# [
# {id = 1; size = 100; start = 0;}
# {id = null; size = 1; start = 101;}
# ]
# {id = 1; size = 100; start = 0;};
# expected = {
# file = [
# { id = 1; size = 100; start = 0;}
# ];
# free = [
# { id = null; size = 1; start = 101;}
# ];
# };
# })
#
(it "gets checksum" {
actual = (solution sample1).checksum {files = sample1defraged;};
expected = 1928;
})
(it "gets the correct result" {
actual = (solution sample1).part1result;
expected = 1928;
})
(it "makes the disk" {
actual = (solution sample1).fullDisk;
expected = 5;
})
])
]