File: Strdiff3test.cpp

package info (click to toggle)
dtl 1.21-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 440 kB
  • sloc: cpp: 2,285; makefile: 2
file content (208 lines) | stat: -rw-r--r-- 8,776 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
#include "dtl_test_common.hpp"
#include "comparators.hpp"

class Strdiff3test : public ::testing::Test
{
protected :
    dtl_test_typedefs(char, string)
    typedef struct case_t {
        sequence S;
        bool     is_merge_success;
        sequence merged_seq;
    } case_t;
    typedef vector< case_t > caseVec;
    
    caseVec merge_cases;
    caseVec detect_cases;
    caseVec custom_cases;
    
    template < typename comparator >
    case_t createCase (sequence a, sequence b, sequence c, sequence s) {
        Diff3< elem, sequence, comparator > diff3(a, b, c);
        case_t ct;

        diff3.compose();

        ct.S                = s;
        ct.is_merge_success = diff3.merge();
        ct.merged_seq       = diff3.getMergedSequence();
        return ct;
    }
    
    void SetUp() {
        // merge test
        merge_cases.push_back(createCase< Compare < elem > >("ab",            "b",             "bc",           "abc"));              // 0
        merge_cases.push_back(createCase< Compare < elem > >("bc",            "b",             "ab",           "abc"));              // 1
        merge_cases.push_back(createCase< Compare < elem > >("qqqabc",        "abc",           "abcdef",       "qqqabcdef"));        // 2
        merge_cases.push_back(createCase< Compare < elem > >("abcdef",        "abc",           "qqqabc",       "qqqabcdef"));        // 3
        merge_cases.push_back(createCase< Compare < elem > >("aaacccbbb",     "aaabbb",        "aaabbbqqq",    "aaacccbbbqqq"));     // 4
        merge_cases.push_back(createCase< Compare < elem > >("aaabbbqqq",     "aaabbb",        "aaacccbbb",    "aaacccbbbqqq"));     // 5
        merge_cases.push_back(createCase< Compare < elem > >("aeaacccbbb",    "aaabbb",        "aaabbbqqq",    "aeaacccbbbqqq"));    // 6
        merge_cases.push_back(createCase< Compare < elem > >("aaabbbqqq",     "aaabbb",        "aeaacccbbb",   "aeaacccbbbqqq"));    // 7
        merge_cases.push_back(createCase< Compare < elem > >("aeaacccbbb",    "aaabbb",        "aaabebbqqq",   "aeaacccbebbqqq"));   // 8
        merge_cases.push_back(createCase< Compare < elem > >("aaabebbqqq",    "aaabbb",        "aeaacccbbb",   "aeaacccbebbqqq"));   // 9
        merge_cases.push_back(createCase< Compare < elem > >("aaacccbbb",     "aaabbb",        "aeaabbbqqq",   "aeaacccbbbqqq"));    // 10
        merge_cases.push_back(createCase< Compare < elem > >("aeaabbbqqq",    "aaabbb",        "aaacccbbb",    "aeaacccbbbqqq"));    // 11
        merge_cases.push_back(createCase< Compare < elem > >("aaacccbbb",     "aaabbb",        "aaabeebbeeqqq","aaacccbeebbeeqqq")); // 12
        merge_cases.push_back(createCase< Compare < elem > >("aaabeebbeeqqq", "aaabbb",        "aaacccbbb",    "aaacccbeebbeeqqq")); // 13
        merge_cases.push_back(createCase< Compare < elem > >("aiueo",         "aeo",           "aeKokaki",     "aiueKokaki"));       // 14
        merge_cases.push_back(createCase< Compare < elem > >("aeKokaki",      "aeo",           "aiueo",        "aiueKokaki"));       // 15
        merge_cases.push_back(createCase< Compare < elem > >("1234567390",    "1234567890",    "1239567890",   "1239567390"));       // 16
        merge_cases.push_back(createCase< Compare < elem > >("1239567890",    "1234567890",    "1234567390",   "1239567390"));       // 17
        merge_cases.push_back(createCase< Compare < elem > >("qabcdef",       "abcdef",        "ab",           "qab"));              // 18
        merge_cases.push_back(createCase< Compare < elem > >("ab",            "abcdef",        "qabcdef",      "qab"));              // 19
        merge_cases.push_back(createCase< Compare < elem > >("abcdf",         "abcdef",        "acdef",        "acdf"));             // 20
        merge_cases.push_back(createCase< Compare < elem > >("acdef",         "abcdef",        "abcdf",        "acdf"));             // 21
        merge_cases.push_back(createCase< Compare < elem > >("acdef",         "abcdef",        "abcdfaa",      "acdfaa"));           // 22
        merge_cases.push_back(createCase< Compare < elem > >("abcdfaa",       "abcdef",        "acdef",        "acdfaa"));           // 23
        
        // detect confliction test
        detect_cases.push_back(createCase< Compare < elem > >("adc",           "abc",          "aec",          ""));                 // 0
        detect_cases.push_back(createCase< Compare < elem > >("abqdcf",        "abcdef",       "abqqef",       ""));                 // 1
        
        // use custom comparator
        custom_cases.push_back(createCase< CaseInsensitive >("abc", "abc", "abC", "abc"));
    }
    
    void TearDown () {}
    
};

/**
 * Strdiff3test
 * check list is following
 * - merge function
 * - detect confliction
 */
TEST_F (Strdiff3test, merge_test0) {
    ASSERT_TRUE(merge_cases[0].is_merge_success);
    ASSERT_EQ(merge_cases[0].S, merge_cases[0].merged_seq);
}

TEST_F (Strdiff3test, merge_test1) {
    ASSERT_TRUE(merge_cases[1].is_merge_success);
    ASSERT_EQ(merge_cases[1].S, merge_cases[1].merged_seq);
}

TEST_F (Strdiff3test, merge_test2) {
    ASSERT_TRUE(merge_cases[2].is_merge_success);
    ASSERT_EQ(merge_cases[2].S, merge_cases[2].merged_seq);
}

TEST_F (Strdiff3test, merge_test3) {
    ASSERT_TRUE(merge_cases[3].is_merge_success);
    ASSERT_EQ(merge_cases[3].S, merge_cases[3].merged_seq);
}

TEST_F (Strdiff3test, merge_test4) {
    ASSERT_TRUE(merge_cases[4].is_merge_success);
    ASSERT_EQ(merge_cases[4].S, merge_cases[4].merged_seq);
}

TEST_F (Strdiff3test, merge_test5) {
    ASSERT_TRUE(merge_cases[5].is_merge_success);
    ASSERT_EQ(merge_cases[5].S, merge_cases[5].merged_seq);
}

TEST_F (Strdiff3test, merge_test6) {
    ASSERT_TRUE(merge_cases[6].is_merge_success);
    ASSERT_EQ(merge_cases[6].S, merge_cases[6].merged_seq);
}

TEST_F (Strdiff3test, merge_test7) {
    ASSERT_TRUE(merge_cases[7].is_merge_success);
    ASSERT_EQ(merge_cases[7].S, merge_cases[7].merged_seq);
}

TEST_F (Strdiff3test, merge_test8) {
    ASSERT_TRUE(merge_cases[8].is_merge_success);
    ASSERT_EQ(merge_cases[8].S, merge_cases[8].merged_seq);
}

TEST_F (Strdiff3test, merge_test9) {
    ASSERT_TRUE(merge_cases[9].is_merge_success);
    ASSERT_EQ(merge_cases[9].S, merge_cases[9].merged_seq);
}

TEST_F (Strdiff3test, merge_test10) {
    ASSERT_TRUE(merge_cases[10].is_merge_success);
    ASSERT_EQ(merge_cases[10].S, merge_cases[10].merged_seq);
}

TEST_F (Strdiff3test, merge_test11) {
    ASSERT_TRUE(merge_cases[11].is_merge_success);
    ASSERT_EQ(merge_cases[11].S, merge_cases[11].merged_seq);
}

TEST_F (Strdiff3test, merge_test12) {
    ASSERT_TRUE(merge_cases[12].is_merge_success);
    ASSERT_EQ(merge_cases[12].S, merge_cases[12].merged_seq);
}

TEST_F (Strdiff3test, merge_test13) {
    ASSERT_TRUE(merge_cases[13].is_merge_success);
    ASSERT_EQ(merge_cases[13].S, merge_cases[13].merged_seq);
}

TEST_F (Strdiff3test, merge_test14) {
    ASSERT_TRUE(merge_cases[14].is_merge_success);
    ASSERT_EQ(merge_cases[14].S, merge_cases[14].merged_seq);
}

TEST_F (Strdiff3test, merge_test15) {
    ASSERT_TRUE(merge_cases[15].is_merge_success);
    ASSERT_EQ(merge_cases[15].S, merge_cases[15].merged_seq);
}

TEST_F (Strdiff3test, merge_test16) {
    ASSERT_TRUE(merge_cases[16].is_merge_success);
    ASSERT_EQ(merge_cases[16].S, merge_cases[16].merged_seq);
}

TEST_F (Strdiff3test, merge_test17) {
    ASSERT_TRUE(merge_cases[17].is_merge_success);
    ASSERT_EQ(merge_cases[17].S, merge_cases[17].merged_seq);
}

TEST_F (Strdiff3test, merge_test18) {
    ASSERT_TRUE(merge_cases[18].is_merge_success);
    ASSERT_EQ(merge_cases[18].S, merge_cases[18].merged_seq);
}

TEST_F (Strdiff3test, merge_test19) {
    ASSERT_TRUE(merge_cases[19].is_merge_success);
    ASSERT_EQ(merge_cases[19].S, merge_cases[19].merged_seq);
}

TEST_F (Strdiff3test, merge_test20) {
    ASSERT_TRUE(merge_cases[20].is_merge_success);
    ASSERT_EQ(merge_cases[20].S, merge_cases[20].merged_seq);
}

TEST_F (Strdiff3test, merge_test21) {
    ASSERT_TRUE(merge_cases[21].is_merge_success);
    ASSERT_EQ( merge_cases[21].S, merge_cases[21].merged_seq);
}

TEST_F (Strdiff3test, merge_test22) {
    ASSERT_TRUE(merge_cases[22].is_merge_success);
    ASSERT_EQ( merge_cases[22].S, merge_cases[22].merged_seq);
}

TEST_F (Strdiff3test, merge_test23) {
    ASSERT_TRUE(merge_cases[23].is_merge_success);
    ASSERT_EQ(merge_cases[23].S, merge_cases[23].merged_seq);
}

TEST_F (Strdiff3test, detect_confliction_test0) {
    ASSERT_FALSE(detect_cases[0].is_merge_success);
}

TEST_F (Strdiff3test, detect_confliction_test1) {
    ASSERT_FALSE(detect_cases[1].is_merge_success);
}

TEST_F (Strdiff3test, custom_comparator_test0) {
    ASSERT_TRUE(custom_cases[0].is_merge_success);
    ASSERT_EQ(custom_cases[0].S, custom_cases[0].merged_seq);
}