Fixed one-off error when finding line boundaries.

BUG=343578
R=dmazzoni

Review URL: https://codereview.chromium.org/755223004

Cr-Commit-Position: refs/heads/master@{#311129}
diff --git a/ui/accessibility/ax_text_utils_unittest.cc b/ui/accessibility/ax_text_utils_unittest.cc
new file mode 100644
index 0000000..7163ef84
--- /dev/null
+++ b/ui/accessibility/ax_text_utils_unittest.cc
@@ -0,0 +1,63 @@
+// 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 "base/strings/utf_string_conversions.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/accessibility/ax_text_utils.h"
+
+namespace ui {
+
+TEST(AXTextUtils, FindAccessibleTextBoundaryLine) {
+  const base::string16 text = base::UTF8ToUTF16("Line 1.\nLine 2\n");
+  const size_t text_length = text.length();
+  std::vector<int> line_breaks;
+  line_breaks.push_back(7);
+  line_breaks.push_back(14);
+  size_t result;
+
+
+  // Basic cases.
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 5,
+                                      FORWARDS_DIRECTION);
+  EXPECT_EQ(7UL, result);
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 9,
+                                      BACKWARDS_DIRECTION);
+  EXPECT_EQ(7UL, result);
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 10,
+                                      FORWARDS_DIRECTION);
+  EXPECT_EQ(14UL, result);
+
+
+  // Edge cases.
+
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY,
+                                      text_length, BACKWARDS_DIRECTION);
+  EXPECT_EQ(14UL, result);
+
+  // When the start_offset is on a line break and we are searching backwards,
+  // it should return the previous line break.
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 14,
+                                      BACKWARDS_DIRECTION);
+  EXPECT_EQ(7UL, result);
+
+  // When the start_offset is on a line break and we are searching forwards,
+  // it should return the next line break.
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 7,
+                                      FORWARDS_DIRECTION);
+  EXPECT_EQ(14UL, result);
+
+  // When there is no previous line break and we are searching backwards,
+  // it should return 0.
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 4,
+                                      BACKWARDS_DIRECTION);
+  EXPECT_EQ(0UL, result);
+
+  // When we are on the last line break and we are searching forwards.
+  // it should return the text length.
+  result = FindAccessibleTextBoundary(text, line_breaks, LINE_BOUNDARY, 14,
+                                      FORWARDS_DIRECTION);
+  EXPECT_EQ(text_length, result);
+}
+
+} // Namespace ui.