blob: 1e1db2f40e6faa897258ef999f4b276af8490704 [file] [log] [blame]
Dominik Röttscheseae454fe2017-11-22 11:16:571// Copyright 2017 The Chromium Authors. All rights reserved.
Dominik Röttsches8b49ef62017-11-21 20:04:232// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "ui/gfx/font_fallback_linux.h"
6
7#include "base/strings/utf_string_conversions.h"
8#include "testing/gtest/include/gtest/gtest.h"
9#include "ui/gfx/font.h"
Etienne Bergeron5a32abe2019-07-19 19:14:4010#include "ui/gfx/font_fallback.h"
Dominik Röttsches8b49ef62017-11-21 20:04:2311
12namespace gfx {
13
Etienne Bergeron5a32abe2019-07-19 19:14:4014namespace {
15const char kDefaultApplicationLocale[] = "us-en";
16} // namespace
17
Etienne Bergeronb27aab52019-09-30 16:51:4218class FontFallbackLinuxTest : public testing::Test {
19 public:
20 void SetUp() override {
21 // Clear the font fallback cache.
22 GetFallbackFontsCacheInstance()->Clear();
23 }
24};
25
Dominik Röttsches8b49ef62017-11-21 20:04:2326// If the Type 1 Symbol.pfb font is installed, it is returned as fallback font
27// for the PUA character 0xf6db. This test ensures we're not returning Type 1
28// fonts as fallback.
Etienne Bergeronb27aab52019-09-30 16:51:4229TEST_F(FontFallbackLinuxTest, NoType1InFallbackFonts) {
Dominik Röttsches8b49ef62017-11-21 20:04:2330 FallbackFontData font_fallback_data =
31 GetFallbackFontForChar(0xf6db, std::string());
32 if (font_fallback_data.filename.length() >= 3u) {
33 std::string extension = font_fallback_data.filename.substr(
34 font_fallback_data.filename.length() - 3);
35 EXPECT_NE(extension, "pfb");
36 } else {
37 EXPECT_EQ(font_fallback_data.filename.length(), 0u);
38 }
39}
40
Etienne Bergeronb27aab52019-09-30 16:51:4241TEST_F(FontFallbackLinuxTest, GetFallbackFont) {
Etienne Bergeron5a32abe2019-07-19 19:14:4042 Font base_font;
43
44 Font fallback_font_cjk;
45 EXPECT_TRUE(GetFallbackFont(base_font, kDefaultApplicationLocale,
46 base::WideToUTF16(L"⻩"), &fallback_font_cjk));
47 EXPECT_EQ(fallback_font_cjk.GetFontName(), "Noto Sans CJK JP");
48
49 Font fallback_font_khmer;
50 EXPECT_TRUE(GetFallbackFont(base_font, kDefaultApplicationLocale,
51 base::WideToUTF16(L"ឨឮឡ"), &fallback_font_khmer));
52 EXPECT_EQ(fallback_font_khmer.GetFontName(), "Noto Sans Khmer");
53}
54
Etienne Bergeronb27aab52019-09-30 16:51:4255TEST_F(FontFallbackLinuxTest, Fallbacks) {
56 EXPECT_EQ(0U, GetFallbackFontsCacheInstance()->size());
57
Etienne Bergeron4a5f5492019-07-19 17:32:3658 Font default_font("sans", 13);
59 std::vector<Font> fallbacks = GetFallbackFonts(default_font);
60 EXPECT_FALSE(fallbacks.empty());
Etienne Bergeronb27aab52019-09-30 16:51:4261 EXPECT_EQ(1U, GetFallbackFontsCacheInstance()->size());
Etienne Bergeron4a5f5492019-07-19 17:32:3662
63 // The first fallback should be 'DejaVu Sans' which is the default linux
64 // fonts. The fonts on linux are mock with test_fonts (see
65 // third_party/tests_font).
66 if (!fallbacks.empty())
67 EXPECT_EQ(fallbacks[0].GetFontName(), "DejaVu Sans");
Etienne Bergeronb27aab52019-09-30 16:51:4268
69 // Second lookup should not increase the cache size.
70 fallbacks = GetFallbackFonts(default_font);
71 EXPECT_FALSE(fallbacks.empty());
72 EXPECT_EQ(1U, GetFallbackFontsCacheInstance()->size());
Etienne Bergeron4a5f5492019-07-19 17:32:3673}
74
Dominik Röttsches8b49ef62017-11-21 20:04:2375} // namespace gfx