| /* |
| * 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 "android-base/strings.h" |
| |
| #include <gtest/gtest.h> |
| |
| #include <string> |
| #include <vector> |
| #include <set> |
| #include <unordered_set> |
| |
| TEST(strings, split_empty) { |
| std::vector<std::string> parts = android::base::Split("", ","); |
| ASSERT_EQ(1U, parts.size()); |
| ASSERT_EQ("", parts[0]); |
| } |
| |
| TEST(strings, split_single) { |
| std::vector<std::string> parts = android::base::Split("foo", ","); |
| ASSERT_EQ(1U, parts.size()); |
| ASSERT_EQ("foo", parts[0]); |
| } |
| |
| TEST(strings, split_simple) { |
| std::vector<std::string> parts = android::base::Split("foo,bar,baz", ","); |
| ASSERT_EQ(3U, parts.size()); |
| ASSERT_EQ("foo", parts[0]); |
| ASSERT_EQ("bar", parts[1]); |
| ASSERT_EQ("baz", parts[2]); |
| } |
| |
| TEST(strings, split_with_empty_part) { |
| std::vector<std::string> parts = android::base::Split("foo,,bar", ","); |
| ASSERT_EQ(3U, parts.size()); |
| ASSERT_EQ("foo", parts[0]); |
| ASSERT_EQ("", parts[1]); |
| ASSERT_EQ("bar", parts[2]); |
| } |
| |
| TEST(strings, split_null_char) { |
| std::vector<std::string> parts = |
| android::base::Split(std::string("foo\0bar", 7), std::string("\0", 1)); |
| ASSERT_EQ(2U, parts.size()); |
| ASSERT_EQ("foo", parts[0]); |
| ASSERT_EQ("bar", parts[1]); |
| } |
| |
| TEST(strings, split_any) { |
| std::vector<std::string> parts = android::base::Split("foo:bar,baz", ",:"); |
| ASSERT_EQ(3U, parts.size()); |
| ASSERT_EQ("foo", parts[0]); |
| ASSERT_EQ("bar", parts[1]); |
| ASSERT_EQ("baz", parts[2]); |
| } |
| |
| TEST(strings, split_any_with_empty_part) { |
| std::vector<std::string> parts = android::base::Split("foo:,bar", ",:"); |
| ASSERT_EQ(3U, parts.size()); |
| ASSERT_EQ("foo", parts[0]); |
| ASSERT_EQ("", parts[1]); |
| ASSERT_EQ("bar", parts[2]); |
| } |
| |
| TEST(strings, trim_empty) { |
| ASSERT_EQ("", android::base::Trim("")); |
| } |
| |
| TEST(strings, trim_already_trimmed) { |
| ASSERT_EQ("foo", android::base::Trim("foo")); |
| } |
| |
| TEST(strings, trim_left) { |
| ASSERT_EQ("foo", android::base::Trim(" foo")); |
| } |
| |
| TEST(strings, trim_right) { |
| ASSERT_EQ("foo", android::base::Trim("foo ")); |
| } |
| |
| TEST(strings, trim_both) { |
| ASSERT_EQ("foo", android::base::Trim(" foo ")); |
| } |
| |
| TEST(strings, trim_no_trim_middle) { |
| ASSERT_EQ("foo bar", android::base::Trim("foo bar")); |
| } |
| |
| TEST(strings, trim_other_whitespace) { |
| ASSERT_EQ("foo", android::base::Trim("\v\tfoo\n\f")); |
| } |
| |
| TEST(strings, join_nothing) { |
| std::vector<std::string> list = {}; |
| ASSERT_EQ("", android::base::Join(list, ',')); |
| } |
| |
| TEST(strings, join_single) { |
| std::vector<std::string> list = {"foo"}; |
| ASSERT_EQ("foo", android::base::Join(list, ',')); |
| } |
| |
| TEST(strings, join_simple) { |
| std::vector<std::string> list = {"foo", "bar", "baz"}; |
| ASSERT_EQ("foo,bar,baz", android::base::Join(list, ',')); |
| } |
| |
| TEST(strings, join_separator_in_vector) { |
| std::vector<std::string> list = {",", ","}; |
| ASSERT_EQ(",,,", android::base::Join(list, ',')); |
| } |
| |
| TEST(strings, join_simple_ints) { |
| std::set<int> list = {1, 2, 3}; |
| ASSERT_EQ("1,2,3", android::base::Join(list, ',')); |
| } |
| |
| TEST(strings, join_unordered_set) { |
| std::unordered_set<int> list = {1, 2}; |
| ASSERT_TRUE("1,2" == android::base::Join(list, ',') || |
| "2,1" == android::base::Join(list, ',')); |
| } |
| |
| TEST(strings, startswith_empty) { |
| ASSERT_FALSE(android::base::StartsWith("", "foo")); |
| ASSERT_TRUE(android::base::StartsWith("", "")); |
| } |
| |
| TEST(strings, startswith_simple) { |
| ASSERT_TRUE(android::base::StartsWith("foo", "")); |
| ASSERT_TRUE(android::base::StartsWith("foo", "f")); |
| ASSERT_TRUE(android::base::StartsWith("foo", "fo")); |
| ASSERT_TRUE(android::base::StartsWith("foo", "foo")); |
| } |
| |
| TEST(strings, startswith_prefix_too_long) { |
| ASSERT_FALSE(android::base::StartsWith("foo", "foobar")); |
| } |
| |
| TEST(strings, startswith_contains_prefix) { |
| ASSERT_FALSE(android::base::StartsWith("foobar", "oba")); |
| ASSERT_FALSE(android::base::StartsWith("foobar", "bar")); |
| } |
| |
| TEST(strings, endswith_empty) { |
| ASSERT_FALSE(android::base::EndsWith("", "foo")); |
| ASSERT_TRUE(android::base::EndsWith("", "")); |
| } |
| |
| TEST(strings, endswith_simple) { |
| ASSERT_TRUE(android::base::EndsWith("foo", "")); |
| ASSERT_TRUE(android::base::EndsWith("foo", "o")); |
| ASSERT_TRUE(android::base::EndsWith("foo", "oo")); |
| ASSERT_TRUE(android::base::EndsWith("foo", "foo")); |
| } |
| |
| TEST(strings, endswith_prefix_too_long) { |
| ASSERT_FALSE(android::base::EndsWith("foo", "foobar")); |
| } |
| |
| TEST(strings, endswith_contains_prefix) { |
| ASSERT_FALSE(android::base::EndsWith("foobar", "oba")); |
| ASSERT_FALSE(android::base::EndsWith("foobar", "foo")); |
| } |