blob: 2d05f8fe74e07ca527d38d8d24b49ad8331c8a09 [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <stddef.h>
#include <utility>
#include "base/strings/utf_string_conversions.h"
#include "testing/gtest/include/gtest/gtest.h"
#include "ui/accessibility/ax_enums.mojom.h"
#include "ui/accessibility/ax_text_utils.h"
namespace ui {
TEST(AXTextUtils, FindAccessibleTextBoundaryWord) {
const base::string16 text =
base::UTF8ToUTF16("Hello there.This/is\ntesting.");
const size_t text_length = text.length();
std::vector<int> line_start_offsets;
line_start_offsets.push_back(19);
size_t result;
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
0, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(6UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
5, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(0UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
6, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(12UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
11, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(6UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
12, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(12UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
15, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(17UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
15, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(12UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
16, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(17UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
17, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(20UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
20, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(text_length, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, WORD_BOUNDARY,
text_length, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(20UL, result);
}
TEST(AXTextUtils, FindAccessibleTextBoundaryLine) {
const base::string16 text = base::UTF8ToUTF16("Line 1.\nLine 2\n\t");
const size_t text_length = text.length();
std::vector<int> line_start_offsets;
line_start_offsets.push_back(8);
line_start_offsets.push_back(15);
size_t result;
// Basic cases.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
5, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(8UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
9, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(8UL, result);
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
10, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(15UL, result);
// Edge cases.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
text_length, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(15UL, result);
// When the start_offset is at the start of the next line and we are searching
// backwards, it should not move.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
15, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(15UL, result);
// When the start_offset is at a hard line break and we are searching
// backwards, it should return the start of the previous line.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
14, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(8UL, result);
// When the start_offset is at the start of a line and we are searching
// forwards, it should return the start of the next line.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
8, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(15UL, result);
// When there is no previous line break and we are searching backwards,
// it should return 0.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
4, BACKWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(0UL, result);
// When we are at the start of the last line and we are searching forwards.
// it should return the text length.
result = FindAccessibleTextBoundary(text, line_start_offsets, LINE_BOUNDARY,
15, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
EXPECT_EQ(text_length, result);
}
TEST(AXTextUtils, FindAccessibleTextBoundarySentence) {
auto find_sentence_boundaries_at_offset = [](const base::string16& text,
int offset) {
std::vector<int> line_start_offsets;
size_t backwards = FindAccessibleTextBoundary(
text, line_start_offsets, SENTENCE_BOUNDARY, offset,
BACKWARDS_DIRECTION, ax::mojom::TextAffinity::kDownstream);
size_t forwards = FindAccessibleTextBoundary(
text, line_start_offsets, SENTENCE_BOUNDARY, offset, FORWARDS_DIRECTION,
ax::mojom::TextAffinity::kDownstream);
return std::make_pair(backwards, forwards);
};
const base::string16 text =
base::UTF8ToUTF16("Sentence 1. Sentence 2...\n\tSentence 3! Sentence 4");
std::pair<size_t, size_t> boundaries =
find_sentence_boundaries_at_offset(text, 5);
EXPECT_EQ(0UL, boundaries.first);
EXPECT_EQ(12UL, boundaries.second);
// When a sentence ends with multiple punctuation, we should look for the
// first word character that follows.
boundaries = find_sentence_boundaries_at_offset(text, 16);
EXPECT_EQ(12UL, boundaries.first);
EXPECT_EQ(27UL, boundaries.second);
// This is also true if we start in the middle of that punctuation.
boundaries = find_sentence_boundaries_at_offset(text, 23);
EXPECT_EQ(12UL, boundaries.first);
EXPECT_EQ(27UL, boundaries.second);
// When the offset is in the whitespace between two sentences, the boundaries
// should be those of the previous sentence to the beginning of the first
// non-whitespace character of the next one.
boundaries = find_sentence_boundaries_at_offset(text, 38);
EXPECT_EQ(27UL, boundaries.first);
EXPECT_EQ(39UL, boundaries.second);
// The end of the string should be considered the end of the last sentence
// regardless of whether or not there is punctuation.
boundaries = find_sentence_boundaries_at_offset(text, 44);
EXPECT_EQ(39UL, boundaries.first);
EXPECT_EQ(49UL, boundaries.second);
// The sentence should include whitespace all the way until the end of the
// string.
const base::string16 text2 = base::UTF8ToUTF16("A sentence . \n\n\t\t\n");
boundaries = find_sentence_boundaries_at_offset(text2, 10);
EXPECT_EQ(0UL, boundaries.first);
EXPECT_EQ(18UL, boundaries.second);
}
} // namespace ui