From 925f8d7176c3d54d435896ec0d2eabda634bbcc8 Mon Sep 17 00:00:00 2001 From: pacien Date: Mon, 3 Dec 2018 18:42:23 +0100 Subject: merge tests --- tests/huffman/thuffmanencoder.nim | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 tests/huffman/thuffmanencoder.nim (limited to 'tests/huffman/thuffmanencoder.nim') diff --git a/tests/huffman/thuffmanencoder.nim b/tests/huffman/thuffmanencoder.nim new file mode 100644 index 0000000..d08db03 --- /dev/null +++ b/tests/huffman/thuffmanencoder.nim @@ -0,0 +1,38 @@ +# gzip-like LZSS compressor +# Copyright (C) 2018 Pacien TRAN-GIRARD +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as +# published by the Free Software Foundation, either version 3 of the +# License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. +# +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see . + +import unittest, tables +import huffman/huffmantree, huffman/huffmanencoder + +suite "huffmanencoder": + let tree = huffmanBranch( + huffmanLeaf(1'u), + huffmanBranch( + huffmanLeaf(2'u), + huffmanLeaf(3'u))) + + test "buildCodebook": + let codebook = buildCodebook(tree, uint) + check codebook.len == 3 + check codebook[1'u] == (1, 0b0'u) + check codebook[2'u] == (2, 0b01'u) + check codebook[3'u] == (2, 0b11'u) + + test "encode": + let encoder = tree.encoder(uint) + check encoder.encode(1'u) == (1, 0b0'u) + check encoder.encode(2'u) == (2, 0b01'u) + check encoder.encode(3'u) == (2, 0b11'u) -- cgit v1.2.3