1*40e9b92eSEd Tanous // SPDX-License-Identifier: Apache-2.0
2*40e9b92eSEd Tanous // SPDX-FileCopyrightText: Copyright OpenBMC Authors
3c33a039bSNan Zhou #include "human_sort.hpp"
4c33a039bSNan Zhou
5c33a039bSNan Zhou #include <set>
6c33a039bSNan Zhou #include <string>
7c33a039bSNan Zhou
8478b7adfSEd Tanous #include <gmock/gmock.h>
9478b7adfSEd Tanous #include <gtest/gtest.h>
10c33a039bSNan Zhou
11c33a039bSNan Zhou namespace
12c33a039bSNan Zhou {
13c33a039bSNan Zhou
14c33a039bSNan Zhou using ::testing::ElementsAreArray;
15c33a039bSNan Zhou
TEST(AlphaNum,NumberTests)16c33a039bSNan Zhou TEST(AlphaNum, NumberTests)
17c33a039bSNan Zhou {
18c33a039bSNan Zhou // testcases for the algorithm
19c33a039bSNan Zhou EXPECT_EQ(alphanumComp("", ""), 0);
20c33a039bSNan Zhou EXPECT_LT(alphanumComp("", "a"), 0);
21c33a039bSNan Zhou EXPECT_GT(alphanumComp("a", ""), 0);
22c33a039bSNan Zhou EXPECT_EQ(alphanumComp("a", "a"), 0);
23c33a039bSNan Zhou EXPECT_LT(alphanumComp("", "9"), 0);
24c33a039bSNan Zhou EXPECT_GT(alphanumComp("9", ""), 0);
25c33a039bSNan Zhou EXPECT_EQ(alphanumComp("1", "1"), 0);
26c33a039bSNan Zhou EXPECT_LT(alphanumComp("1", "2"), 0);
27c33a039bSNan Zhou EXPECT_GT(alphanumComp("3", "2"), 0);
28c33a039bSNan Zhou EXPECT_EQ(alphanumComp("a1", "a1"), 0);
29c33a039bSNan Zhou EXPECT_LT(alphanumComp("a1", "a2"), 0);
30c33a039bSNan Zhou EXPECT_GT(alphanumComp("a2", "a1"), 0);
31c33a039bSNan Zhou EXPECT_LT(alphanumComp("a1a2", "a1a3"), 0);
32c33a039bSNan Zhou EXPECT_GT(alphanumComp("a1a2", "a1a0"), 0);
33c33a039bSNan Zhou EXPECT_GT(alphanumComp("134", "122"), 0);
34c33a039bSNan Zhou EXPECT_EQ(alphanumComp("12a3", "12a3"), 0);
35c33a039bSNan Zhou EXPECT_GT(alphanumComp("12a1", "12a0"), 0);
36c33a039bSNan Zhou EXPECT_LT(alphanumComp("12a1", "12a2"), 0);
37c33a039bSNan Zhou EXPECT_LT(alphanumComp("a", "aa"), 0);
38c33a039bSNan Zhou EXPECT_GT(alphanumComp("aaa", "aa"), 0);
39c33a039bSNan Zhou EXPECT_EQ(alphanumComp("Alpha 2", "Alpha 2"), 0);
40c33a039bSNan Zhou EXPECT_LT(alphanumComp("Alpha 2", "Alpha 2A"), 0);
41c33a039bSNan Zhou EXPECT_GT(alphanumComp("Alpha 2 B", "Alpha 2"), 0);
42c33a039bSNan Zhou
43c33a039bSNan Zhou std::string str("Alpha 2");
44c33a039bSNan Zhou EXPECT_EQ(alphanumComp(str, "Alpha 2"), 0);
45c33a039bSNan Zhou EXPECT_LT(alphanumComp(str, "Alpha 2A"), 0);
46c33a039bSNan Zhou EXPECT_GT(alphanumComp("Alpha 2 B", str), 0);
47c33a039bSNan Zhou }
48c33a039bSNan Zhou
TEST(AlphaNum,LessTest)49c33a039bSNan Zhou TEST(AlphaNum, LessTest)
50c33a039bSNan Zhou {
51bd79bce8SPatrick Williams std::set<std::string, AlphanumLess<std::string>> sorted{
52bd79bce8SPatrick Williams "Alpha 10", "Alpha 2"};
53c33a039bSNan Zhou EXPECT_THAT(sorted, ElementsAreArray({"Alpha 2", "Alpha 10"}));
54c33a039bSNan Zhou }
55c33a039bSNan Zhou } // namespace
56