version_unittest.cc 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. // Copyright (c) 2012 The Chromium Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style license that can be
  3. // found in the LICENSE file.
  4. #include "butil/version.h"
  5. #include <gtest/gtest.h>
  6. namespace {
  7. TEST(VersionTest, DefaultConstructor) {
  8. Version v;
  9. EXPECT_FALSE(v.IsValid());
  10. }
  11. TEST(VersionTest, ValueSemantics) {
  12. Version v1("1.2.3.4");
  13. EXPECT_TRUE(v1.IsValid());
  14. Version v3;
  15. EXPECT_FALSE(v3.IsValid());
  16. {
  17. Version v2(v1);
  18. v3 = v2;
  19. EXPECT_TRUE(v2.IsValid());
  20. EXPECT_TRUE(v1.Equals(v2));
  21. }
  22. EXPECT_TRUE(v3.Equals(v1));
  23. }
  24. TEST(VersionTest, GetVersionFromString) {
  25. static const struct version_string {
  26. const char* input;
  27. size_t parts;
  28. bool success;
  29. } cases[] = {
  30. {"", 0, false},
  31. {" ", 0, false},
  32. {"\t", 0, false},
  33. {"\n", 0, false},
  34. {" ", 0, false},
  35. {".", 0, false},
  36. {" . ", 0, false},
  37. {"0", 1, true},
  38. {"0.0", 2, true},
  39. {"65537.0", 0, false},
  40. {"-1.0", 0, false},
  41. {"1.-1.0", 0, false},
  42. {"+1.0", 0, false},
  43. {"1.+1.0", 0, false},
  44. {"1.0a", 0, false},
  45. {"1.2.3.4.5.6.7.8.9.0", 10, true},
  46. {"02.1", 0, false},
  47. {"f.1", 0, false},
  48. };
  49. for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) {
  50. Version version(cases[i].input);
  51. EXPECT_EQ(cases[i].success, version.IsValid());
  52. if (cases[i].success) {
  53. EXPECT_EQ(cases[i].parts, version.components().size());
  54. }
  55. }
  56. }
  57. TEST(VersionTest, Compare) {
  58. static const struct version_compare {
  59. const char* lhs;
  60. const char* rhs;
  61. int expected;
  62. } cases[] = {
  63. {"1.0", "1.0", 0},
  64. {"1.0", "0.0", 1},
  65. {"1.0", "2.0", -1},
  66. {"1.0", "1.1", -1},
  67. {"1.1", "1.0", 1},
  68. {"1.0", "1.0.1", -1},
  69. {"1.1", "1.0.1", 1},
  70. {"1.1", "1.0.1", 1},
  71. {"1.0.0", "1.0", 0},
  72. {"1.0.3", "1.0.20", -1},
  73. };
  74. for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) {
  75. Version lhs(cases[i].lhs);
  76. Version rhs(cases[i].rhs);
  77. EXPECT_EQ(lhs.CompareTo(rhs), cases[i].expected) <<
  78. cases[i].lhs << " ? " << cases[i].rhs;
  79. EXPECT_EQ(lhs.IsOlderThan(cases[i].rhs), (cases[i].expected == -1));
  80. }
  81. }
  82. TEST(VersionTest, CompareToWildcardString) {
  83. static const struct version_compare {
  84. const char* lhs;
  85. const char* rhs;
  86. int expected;
  87. } cases[] = {
  88. {"1.0", "1.*", 0},
  89. {"1.0", "0.*", 1},
  90. {"1.0", "2.*", -1},
  91. {"1.2.3", "1.2.3.*", 0},
  92. {"10.0", "1.0.*", 1},
  93. {"1.0", "3.0.*", -1},
  94. {"1.4", "1.3.0.*", 1},
  95. {"1.3.9", "1.3.*", 0},
  96. {"1.4.1", "1.3.*", 1},
  97. {"1.3", "1.4.5.*", -1},
  98. {"1.5", "1.4.5.*", 1},
  99. {"1.3.9", "1.3.*", 0},
  100. {"1.2.0.0.0.0", "1.2.*", 0},
  101. };
  102. for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) {
  103. const Version version(cases[i].lhs);
  104. const int result = version.CompareToWildcardString(cases[i].rhs);
  105. EXPECT_EQ(result, cases[i].expected) << cases[i].lhs << "?" << cases[i].rhs;
  106. }
  107. }
  108. TEST(VersionTest, IsValidWildcardString) {
  109. static const struct version_compare {
  110. const char* version;
  111. bool expected;
  112. } cases[] = {
  113. {"1.0", true},
  114. {"", false},
  115. {"1.2.3.4.5.6", true},
  116. {"1.2.3.*", true},
  117. {"1.2.3.5*", false},
  118. {"1.2.3.56*", false},
  119. {"1.*.3", false},
  120. {"20.*", true},
  121. {"+2.*", false},
  122. {"*", false},
  123. {"*.2", false},
  124. };
  125. for (size_t i = 0; i < ARRAYSIZE_UNSAFE(cases); ++i) {
  126. EXPECT_EQ(Version::IsValidWildcardString(cases[i].version),
  127. cases[i].expected) << cases[i].version << "?" << cases[i].expected;
  128. }
  129. }
  130. } // namespace