diff options
author | Konstantin Käfer <mail@kkaefer.com> | 2017-01-13 12:28:59 +0100 |
---|---|---|
committer | Konstantin Käfer <mail@kkaefer.com> | 2017-01-17 19:23:20 +0100 |
commit | 66582681150d478140857d5def2c9cafa2748397 (patch) | |
tree | ea99ed8aacd5e36c2bb5ddb70738d6d837611d1b /test/text | |
parent | b6c11191723d6eb884de5ee17d658298f5dd4127 (diff) | |
download | qtlocation-mapboxgl-66582681150d478140857d5def2c9cafa2748397.tar.gz |
[core] abort early when placing a glyph in GlyphAtlas if the bitmap is invalid
Diffstat (limited to 'test/text')
-rw-r--r-- | test/text/glyph_atlas.test.cpp | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/test/text/glyph_atlas.test.cpp b/test/text/glyph_atlas.test.cpp index 020a7140cb..e229cd117b 100644 --- a/test/text/glyph_atlas.test.cpp +++ b/test/text/glyph_atlas.test.cpp @@ -142,3 +142,43 @@ TEST(GlyphAtlas, LoadingCancel) { {{"Test Stack"}}, {{0, 255}}); } + +TEST(GlyphAtlas, InvalidSDFGlyph) { + GlyphSet glyphSet; + glyphSet.insert(65, SDFGlyph{ 65 /* ASCII 'A' */, + "x" /* bitmap is too short */, + { 1 /* width */, 1 /* height */, 0 /* left */, 0 /* top */, + 0 /* advance */ } }); + glyphSet.insert(66, SDFGlyph{ 66 /* ASCII 'B' */, + std::string(7 * 7, 'x'), /* correct */ + { 1 /* width */, 1 /* height */, 0 /* left */, 0 /* top */, + 0 /* advance */ } }); + glyphSet.insert(67, SDFGlyph{ 67 /* ASCII 'C' */, + std::string(518 * 8, 'x'), /* correct */ + { 512 /* width */, 2 /* height */, 0 /* left */, 0 /* top */, + 0 /* advance */ } }); + + + const FontStack fontStack{ "Mock Font" }; + + GlyphAtlasTest test; + GlyphPositions positions; + test.glyphAtlas.addGlyphs(1, std::u16string{u"ABC"}, fontStack, glyphSet, positions); + + ASSERT_EQ(3u, positions.size()); + + // 'A' was not placed because the bitmap size is invalid. + ASSERT_NE(positions.end(), positions.find(65)); + ASSERT_EQ((Rect<uint16_t>{ 0, 0, 0, 0 }), positions[65].rect); + + // 'B' was placed at the top left. + ASSERT_NE(positions.end(), positions.find(66)); + // Width is 12 because actual dimensions are 1+6 pixels, with 1px border added, rounded up to + // the next multiple of 4. + ASSERT_EQ((Rect<uint16_t>{ 0, 0, 12, 12 }), positions[66].rect); + + // 'C' was not placed because the width is too big. + ASSERT_NE(positions.end(), positions.find(67)); + ASSERT_EQ((Rect<uint16_t>{ 0, 0, 0, 0 }), positions[67].rect); + +} |