/************************************************************************* ** CMapTest.cpp ** ** ** ** This file is part of dvisvgm -- the DVI to SVG converter ** ** Copyright (C) 2005-2013 Martin Gieseking ** ** ** ** This program is free software; you can redistribute it and/or ** ** modify it under the terms of the GNU 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 General Public License for more details. ** ** ** ** You should have received a copy of the GNU General Public License ** ** along with this program; if not, see . ** *************************************************************************/ #include #include "CMap.h" using namespace std; static void check_range (const SegmentedCMap &cmap, int min, int max, int cid_min) { for (int i=min; i <= max; i++) ASSERT_EQ(cmap.cid(i), cid_min+(i-min)); } static void check_zero (const SegmentedCMap &cmap, int min, int max) { for (int i=min; i <= max; i++) ASSERT_EQ(cmap.cid(i), 0); } TEST(SegmentedCMapTest, disjoint_ranges) { SegmentedCMap cmap("test"); cmap.addCIDRange(5, 8, 1); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 5, 8, 1); check_zero(cmap, 0, 4); check_zero(cmap, 9, 20); cmap.addCIDRange(10, 15, 5); ASSERT_EQ(cmap.numCIDRanges(), 2); check_range(cmap, 5, 8, 1); check_range(cmap, 10, 15, 5); check_zero(cmap, 0, 4); check_zero(cmap, 9, 9); check_zero(cmap, 16, 20); cmap.addCIDRange(0, 3, 50); ASSERT_EQ(cmap.numCIDRanges(), 3); check_range(cmap, 0, 3, 50); check_range(cmap, 5, 8, 1); check_range(cmap, 10, 15, 5); check_zero(cmap, 4, 4); check_zero(cmap, 9, 9); check_zero(cmap, 16, 20); cmap.addCIDRange(16, 20, 1); ASSERT_EQ(cmap.numCIDRanges(), 4); check_range(cmap, 5, 8, 1); check_range(cmap, 10, 15, 5); check_range(cmap, 0, 3, 50); check_range(cmap, 16, 20, 1); } TEST(SegmentedCMapTest, touching_ranges) { SegmentedCMap cmap("test"); cmap.addCIDRange(5, 8, 10); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 5, 8, 10); cmap.addCIDRange(9, 15, 14); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 5, 15, 10); cmap.addCIDRange(1, 4, 5); ASSERT_EQ(cmap.numCIDRanges(), 2); check_range(cmap, 1, 4, 5); check_range(cmap, 5, 15, 10); cmap.addCIDRange(1, 4, 6); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 1, 15, 6); } TEST(SegmentedCMapTest, overlapping_ranges) { SegmentedCMap cmap("test"); cmap.addCIDRange(5, 8, 10); cmap.addCIDRange(7, 15, 12); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 5, 15, 10); cmap.addCIDRange(10, 20, 1); ASSERT_EQ(cmap.numCIDRanges(), 2); check_range(cmap, 5, 9, 10); check_range(cmap, 10, 20, 1); cmap.addCIDRange(2, 7, 7); ASSERT_EQ(cmap.numCIDRanges(), 2); check_range(cmap, 2, 9, 7); check_range(cmap, 10, 20, 1); cmap.addCIDRange(1, 12, 100); ASSERT_EQ(cmap.numCIDRanges(), 2); check_range(cmap, 1, 12, 100); check_range(cmap, 13, 20, 4); cmap.addCIDRange(0, 30, 1); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 0, 30, 1); } TEST(SegmentedCMapTest, inner_ranges) { SegmentedCMap cmap("test"); cmap.addCIDRange(5, 20, 1); cmap.addCIDRange(10, 15, 6); ASSERT_EQ(cmap.numCIDRanges(), 1); check_range(cmap, 5, 20, 1); cmap.addCIDRange(10, 15, 100); ASSERT_EQ(cmap.numCIDRanges(), 3); check_range(cmap, 5, 9, 1); check_range(cmap, 10, 15, 100); check_range(cmap, 16, 20, 12); cmap.addCIDRange(15, 15, 50); ASSERT_EQ(cmap.numCIDRanges(), 4); check_range(cmap, 5, 9, 1); check_range(cmap, 10, 14, 100); check_range(cmap, 15, 15, 50); check_range(cmap, 16, 20, 12); cmap.addCIDRange(6, 19, 1); ASSERT_EQ(cmap.numCIDRanges(), 3); check_range(cmap, 5, 5, 1); check_range(cmap, 6, 19, 1); check_range(cmap, 20, 20, 16); }