/* * 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 #include #include #include #include TEST(strings, split_empty) { std::vector parts = android::base::Split("", ","); ASSERT_EQ(1U, parts.size()); ASSERT_EQ("", parts[0]); } TEST(strings, split_single) { std::vector parts = android::base::Split("foo", ","); ASSERT_EQ(1U, parts.size()); ASSERT_EQ("foo", parts[0]); } TEST(strings, split_simple) { std::vector 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 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 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 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 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 list = {}; ASSERT_EQ("", android::base::Join(list, ',')); } TEST(strings, join_single) { std::vector list = {"foo"}; ASSERT_EQ("foo", android::base::Join(list, ',')); } TEST(strings, join_simple) { std::vector list = {"foo", "bar", "baz"}; ASSERT_EQ("foo,bar,baz", android::base::Join(list, ',')); } TEST(strings, join_separator_in_vector) { std::vector list = {",", ","}; ASSERT_EQ(",,,", android::base::Join(list, ',')); } TEST(strings, join_simple_ints) { std::set list = {1, 2, 3}; ASSERT_EQ("1,2,3", android::base::Join(list, ',')); } TEST(strings, join_unordered_set) { std::unordered_set 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")); }