/* * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include <gtest/gtest.h> #include <minikin/FontCollection.h> #include "FontTestUtils.h" #include "MinikinFontForTest.h" #include "MinikinInternal.h" namespace android { // The test font has following glyphs. // U+82A6 // U+82A6 U+FE00 (VS1) // U+82A6 U+E0100 (VS17) // U+82A6 U+E0101 (VS18) // U+82A6 U+E0102 (VS19) // U+845B // U+845B U+FE01 (VS2) // U+845B U+E0101 (VS18) // U+845B U+E0102 (VS19) // U+845B U+E0103 (VS20) // U+537F // U+717D U+FE02 (VS3) // U+717D U+E0102 (VS19) // U+717D U+E0103 (VS20) const char kVsTestFont[] = kTestFontDir "/VarioationSelectorTest-Regular.ttf"; void expectVSGlyphs(const FontCollection& fc, uint32_t codepoint, const std::set<uint32_t>& vsSet) { for (uint32_t vs = 0xFE00; vs <= 0xE01EF; ++vs) { // Move to variation selectors supplements after variation selectors. if (vs == 0xFF00) { vs = 0xE0100; } if (vsSet.find(vs) == vsSet.end()) { EXPECT_FALSE(fc.hasVariationSelector(codepoint, vs)) << "Glyph for U+" << std::hex << codepoint << " U+" << vs; } else { EXPECT_TRUE(fc.hasVariationSelector(codepoint, vs)) << "Glyph for U+" << std::hex << codepoint << " U+" << vs; } } } TEST(FontCollectionTest, hasVariationSelectorTest) { FontFamily* family = new FontFamily(); family->addFont(new MinikinFontForTest(kVsTestFont)); std::vector<FontFamily*> families({family}); FontCollection fc(families); family->Unref(); EXPECT_FALSE(fc.hasVariationSelector(0x82A6, 0)); expectVSGlyphs(fc, 0x82A6, std::set<uint32_t>({0xFE00, 0xE0100, 0xE0101, 0xE0102})); EXPECT_FALSE(fc.hasVariationSelector(0x845B, 0)); expectVSGlyphs(fc, 0x845B, std::set<uint32_t>({0xFE01, 0xE0101, 0xE0102, 0xE0103})); EXPECT_FALSE(fc.hasVariationSelector(0x537F, 0)); expectVSGlyphs(fc, 0x537F, std::set<uint32_t>({})); EXPECT_FALSE(fc.hasVariationSelector(0x717D, 0)); expectVSGlyphs(fc, 0x717D, std::set<uint32_t>({0xFE02, 0xE0102, 0xE0103})); } const char kEmojiXmlFile[] = kTestFontDir "emoji.xml"; TEST(FontCollectionTest, hasVariationSelectorTest_emoji) { MinikinAutoUnref<FontCollection> collection(getFontCollection(kTestFontDir, kEmojiXmlFile)); // Both text/color font have cmap format 14 subtable entry for VS15/VS16 respectively. EXPECT_TRUE(collection->hasVariationSelector(0x2623, 0xFE0E)); EXPECT_TRUE(collection->hasVariationSelector(0x2623, 0xFE0F)); // The text font has cmap format 14 subtable entry for VS15 but the color font doesn't have for // VS16 EXPECT_TRUE(collection->hasVariationSelector(0x2626, 0xFE0E)); EXPECT_FALSE(collection->hasVariationSelector(0x2626, 0xFE0F)); // The color font has cmap format 14 subtable entry for VS16 but the text font doesn't have for // VS15. EXPECT_TRUE(collection->hasVariationSelector(0x262A, 0xFE0E)); EXPECT_TRUE(collection->hasVariationSelector(0x262A, 0xFE0F)); // Neither text/color font have cmap format 14 subtable entry for VS15/VS16. EXPECT_TRUE(collection->hasVariationSelector(0x262E, 0xFE0E)); EXPECT_FALSE(collection->hasVariationSelector(0x262E, 0xFE0F)); // Text font doesn't have U+262F U+FE0E or even its base code point U+262F. EXPECT_FALSE(collection->hasVariationSelector(0x262F, 0xFE0E)); // VS15/VS16 is only for emoji, should return false for not an emoji code point. EXPECT_FALSE(collection->hasVariationSelector(0x2229, 0xFE0E)); EXPECT_FALSE(collection->hasVariationSelector(0x2229, 0xFE0F)); } TEST(FontCollectionTest, newEmojiTest) { MinikinAutoUnref<FontCollection> collection(getFontCollection(kTestFontDir, kEmojiXmlFile)); // U+2695, U+2640, U+2642 are not in emoji catrgory in Unicode 9 but they are now in emoji // category. Should return true even if U+FE0E was appended. // These three emojis are only avalilable in TextEmoji.ttf but U+2695 is excluded here since it // is used in other tests. EXPECT_TRUE(collection->hasVariationSelector(0x2640, 0xFE0E)); EXPECT_FALSE(collection->hasVariationSelector(0x2640, 0xFE0F)); EXPECT_TRUE(collection->hasVariationSelector(0x2642, 0xFE0E)); EXPECT_FALSE(collection->hasVariationSelector(0x2642, 0xFE0F)); } } // namespace android