File: how_subcases_work.cpp

package info (click to toggle)
doctest 1.2.9%2Brepack0-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 4,264 kB
  • sloc: cpp: 9,836; python: 363; makefile: 14
file content (116 lines) | stat: -rw-r--r-- 2,563 bytes parent folder | download | duplicates (5)
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
/* THE OUTPUT IS:

creating empty vector
+ 2
== size: 2
+ 2
== size: 4

creating empty vector
+ 2
== size: 2
+ 1
== size: 3

creating empty vector
+ 1
== size: 1

*/

#include <iostream>
#include <vector>
#include <set>

using namespace std;

set<pair<const char*, int> > passed_subcases;
set<int> entered_levels;
int current_level;
bool has_skipped;

struct Subcase {
    Subcase(const char* file, int line)
        : m_entered(false)
        , m_file(file)
        , m_line(line)
    {
        m_entered = false;

        // if we have already completed it
        if(passed_subcases.count(pair<const char*, int>(file, line)) != 0)
            return;

        // if a Subcase on the same level has already been entered
        if(entered_levels.count(current_level) != 0) {
            has_skipped = true;
            return;
        }

        entered_levels.insert(current_level++);

        m_entered = true;
    }

    ~Subcase() {
        if(m_entered) {
            current_level--;
            // only mark the subcase as passed if no subcases have been skipped
            if(has_skipped == false)
                passed_subcases.insert(pair<const char*, int>(m_file, m_line));
        }
    }

    operator bool() const { return m_entered; }

    bool m_entered;
    const char* m_file;
    int m_line;
};

#define STR_CONCAT_IMPL(s1, s2) s1##s2
#define STR_CONCAT(s1, s2) STR_CONCAT_IMPL(s1, s2)
#define ANON_VAR STR_CONCAT(anon, __LINE__)

#define subcase(title) if(const Subcase& ANON_VAR = Subcase(__FILE__, __LINE__))

void test() {
    cout << endl << "creating empty vector" << endl;
    vector<int> data;

    subcase("size should grow to 2") {
        cout << "+ 2" << endl;
        data.push_back(42);
        data.push_back(10);
        cout << "== size: " << data.size() << endl;

        subcase("size should grow to 4") {
            cout << "+ 2" << endl;
            data.push_back(666);
            data.push_back(100);
            cout << "== size: " << data.size() << endl;
        }
        subcase("size should grow to 3") {
            cout << "+ 1" << endl;
            data.push_back(666);
            cout << "== size: " << data.size() << endl;
        }
    }
    subcase("size should grow to 1") {
        cout << "+ 1" << endl;
        data.push_back(42);
        cout << "== size: " << data.size() << endl;
    }
}

int main() {
    passed_subcases.clear();
    do {
        has_skipped = false;
        current_level = 0;
        entered_levels.clear();
        test();
    } while(has_skipped == true);

    return 0;
}