// Copyright (c) 2012 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/version.h" #include "testing/gtest/include/gtest/gtest.h" namespace { TEST(VersionTest, DefaultConstructor) { Version v; EXPECT_FALSE(v.IsValid()); } TEST(VersionTest, ValueSemantics) { Version v1("1.2.3.4"); EXPECT_TRUE(v1.IsValid()); Version v3; EXPECT_FALSE(v3.IsValid()); { Version v2(v1); v3 = v2; EXPECT_TRUE(v2.IsValid()); EXPECT_TRUE(v1.Equals(v2)); } EXPECT_TRUE(v3.Equals(v1)); } TEST(VersionTest, GetVersionFromString) { static const struct version_string { const char* input; size_t parts; bool success; } cases[] = { {"", 0, false}, {" ", 0, false}, {"\t", 0, false}, {"\n", 0, false}, {" ", 0, false}, {".", 0, false}, {" . ", 0, false}, {"0", 1, true}, {"0.0", 2, true}, {"65537.0", 0, false}, {"-1.0", 0, false}, {"1.-1.0", 0, false}, {"+1.0", 0, false}, {"1.+1.0", 0, false}, {"1.0a", 0, false}, {"1.2.3.4.5.6.7.8.9.0", 10, true}, {"02.1", 0, false}, {"f.1", 0, false}, }; for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) { Version version(cases[i].input); EXPECT_EQ(cases[i].success, version.IsValid()); if (cases[i].success) EXPECT_EQ(cases[i].parts, version.components().size()); } } TEST(VersionTest, Compare) { static const struct version_compare { const char* lhs; const char* rhs; int expected; } cases[] = { {"1.0", "1.0", 0}, {"1.0", "0.0", 1}, {"1.0", "2.0", -1}, {"1.0", "1.1", -1}, {"1.1", "1.0", 1}, {"1.0", "1.0.1", -1}, {"1.1", "1.0.1", 1}, {"1.1", "1.0.1", 1}, {"1.0.0", "1.0", 0}, {"1.0.3", "1.0.20", -1}, }; for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) { Version lhs(cases[i].lhs); Version rhs(cases[i].rhs); EXPECT_EQ(lhs.CompareTo(rhs), cases[i].expected) << cases[i].lhs << " ? " << cases[i].rhs; EXPECT_EQ(lhs.IsOlderThan(cases[i].rhs), (cases[i].expected == -1)); } } TEST(VersionTest, CompareToWildcardString) { static const struct version_compare { const char* lhs; const char* rhs; int expected; } cases[] = { {"1.0", "1.*", 0}, {"1.0", "0.*", 1}, {"1.0", "2.*", -1}, {"1.2.3", "1.2.3.*", 0}, {"10.0", "1.0.*", 1}, {"1.0", "3.0.*", -1}, {"1.4", "1.3.0.*", 1}, {"1.3.9", "1.3.*", 0}, {"1.4.1", "1.3.*", 1}, {"1.3", "1.4.5.*", -1}, {"1.5", "1.4.5.*", 1}, {"1.3.9", "1.3.*", 0}, {"1.2.0.0.0.0", "1.2.*", 0}, }; for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) { const Version version(cases[i].lhs); const int result = version.CompareToWildcardString(cases[i].rhs); EXPECT_EQ(result, cases[i].expected) << cases[i].lhs << "?" << cases[i].rhs; } } TEST(VersionTest, IsValidWildcardString) { static const struct version_compare { const char* version; bool expected; } cases[] = { {"1.0", true}, {"", false}, {"1.2.3.4.5.6", true}, {"1.2.3.*", true}, {"1.2.3.5*", false}, {"1.2.3.56*", false}, {"1.*.3", false}, {"20.*", true}, {"+2.*", false}, {"*", false}, {"*.2", false}, }; for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) { EXPECT_EQ(Version::IsValidWildcardString(cases[i].version), cases[i].expected) << cases[i].version << "?" << cases[i].expected; } } } // namespace