X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/764829f87878f239dc6173d0201b5249531da2db..6be553dd1298f55aa334929c3b2eff178eb4e158:/src/mc/explo/udpor/EventSet_test.cpp diff --git a/src/mc/explo/udpor/EventSet_test.cpp b/src/mc/explo/udpor/EventSet_test.cpp index 776d3b3ce4..3fc73499be 100644 --- a/src/mc/explo/udpor/EventSet_test.cpp +++ b/src/mc/explo/udpor/EventSet_test.cpp @@ -41,7 +41,9 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Initial conditions when creating sets") SECTION("Initialization with one or more elements") { - UnfoldingEvent e1, e2, e3; + UnfoldingEvent e1; + UnfoldingEvent e2; + UnfoldingEvent e3; SECTION("Set initializer") { @@ -68,7 +70,9 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Initial conditions when creating sets") TEST_CASE("simgrid::mc::udpor::EventSet: Insertions") { EventSet event_set; - UnfoldingEvent e1, e2, e3; + UnfoldingEvent e1; + UnfoldingEvent e2; + UnfoldingEvent e3; SECTION("Inserting unique elements") { @@ -192,7 +196,9 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Set Equality") UnfoldingEvent e2; UnfoldingEvent e3; UnfoldingEvent e4; - EventSet A{&e1, &e2, &e3}, B{&e1, &e2, &e3}, C{&e1, &e2, &e3}; + EventSet A{&e1, &e2, &e3}; + EventSet B{&e1, &e2, &e3}; + EventSet C{&e1, &e2, &e3}; SECTION("Equality implies containment") { @@ -267,10 +273,16 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Set Equality") TEST_CASE("simgrid::mc::udpor::EventSet: Set Union Tests") { - UnfoldingEvent e1, e2, e3, e4; + UnfoldingEvent e1; + UnfoldingEvent e2; + UnfoldingEvent e3; + UnfoldingEvent e4; // C = A + B - EventSet A{&e1, &e2, &e3}, B{&e2, &e3, &e4}, C{&e1, &e2, &e3, &e4}, D{&e1, &e3}; + EventSet A{&e1, &e2, &e3}; + EventSet B{&e2, &e3, &e4}; + EventSet C{&e1, &e2, &e3, &e4}; + EventSet D{&e1, &e3}; SECTION("Unions with no effect") { @@ -280,7 +292,7 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Set Union Tests") { // A = A union A EventSet A_union = A.make_union(A); - REQUIRE(A == A_copy); + REQUIRE(A == A_union); A.form_union(A); REQUIRE(A == A_copy); @@ -395,7 +407,12 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Set Difference Tests") // D is a subset of A and C // E is a subset of B and C // F is a subset of A, C, and D - EventSet A{&e1, &e2, &e3}, B{&e2, &e3, &e4}, C{&e1, &e2, &e3, &e4}, D{&e1, &e3}, E{&e4}, F{&e1}; + EventSet A{&e1, &e2, &e3}; + EventSet B{&e2, &e3, &e4}; + EventSet C{&e1, &e2, &e3, &e4}; + EventSet D{&e1, &e3}; + EventSet E{&e4}; + EventSet F{&e1}; SECTION("Difference with no effect") { @@ -465,7 +482,10 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Set Difference Tests") TEST_CASE("simgrid::mc::udpor::EventSet: Subset Tests") { - UnfoldingEvent e1, e2, e3, e4; + UnfoldingEvent e1; + UnfoldingEvent e2; + UnfoldingEvent e3; + UnfoldingEvent e4; // A is a subset of C only // B is a subset of C only @@ -473,7 +493,12 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Subset Tests") // D is NOT a subset of B // B is NOT a subset of D // ... - EventSet A{&e1, &e2, &e3}, B{&e2, &e3, &e4}, C{&e1, &e2, &e3, &e4}, D{&e1, &e3}, E{&e2, &e3}, F{&e1, &e2, &e3}; + EventSet A{&e1, &e2, &e3}; + EventSet B{&e2, &e3, &e4}; + EventSet C{&e1, &e2, &e3, &e4}; + EventSet D{&e1, &e3}; + EventSet E{&e2, &e3}; + EventSet F{&e1, &e2, &e3}; SECTION("Subset operator properties") { @@ -527,12 +552,12 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Testing Configurations") // The tests enumerate all possible subsets of the events // in the structure and test whether those subsets are // maximal and/or valid configurations - UnfoldingEvent e1; - UnfoldingEvent e2{&e1}; - UnfoldingEvent e3{&e2}; - UnfoldingEvent e4{&e2}; - UnfoldingEvent e5{&e1}; - UnfoldingEvent e6{&e5}; + UnfoldingEvent e1(EventSet(), std::make_shared(0)); + UnfoldingEvent e2(EventSet({&e1}), std::make_shared(1)); + UnfoldingEvent e3(EventSet({&e2}), std::make_shared(2)); + UnfoldingEvent e4(EventSet({&e2}), std::make_shared(3)); + UnfoldingEvent e5(EventSet({&e1}), std::make_shared(4)); + UnfoldingEvent e6(EventSet({&e5}), std::make_shared(5)); SECTION("Valid Configurations") { @@ -778,12 +803,12 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Checking conflicts") SECTION("No conflicts throughout the whole structure with independent actions") { - UnfoldingEvent e1(EventSet(), std::make_shared()); - UnfoldingEvent e2(EventSet({&e1}), std::make_shared()); - UnfoldingEvent e3(EventSet({&e2}), std::make_shared()); - UnfoldingEvent e4(EventSet({&e2}), std::make_shared()); - UnfoldingEvent e5(EventSet({&e1}), std::make_shared()); - UnfoldingEvent e6(EventSet({&e5}), std::make_shared()); + UnfoldingEvent e1(EventSet(), std::make_shared(0)); + UnfoldingEvent e2(EventSet({&e1}), std::make_shared(1)); + UnfoldingEvent e3(EventSet({&e2}), std::make_shared(2)); + UnfoldingEvent e4(EventSet({&e2}), std::make_shared(3)); + UnfoldingEvent e5(EventSet({&e1}), std::make_shared(4)); + UnfoldingEvent e6(EventSet({&e5}), std::make_shared(5)); // 6 choose 0 = 1 test CHECK(EventSet().is_conflict_free()); @@ -958,12 +983,12 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Checking conflicts") SECTION("Conditional conflicts") { - UnfoldingEvent e1(EventSet(), std::make_shared()); - UnfoldingEvent e2(EventSet({&e1}), std::make_shared()); - UnfoldingEvent e3(EventSet({&e2}), std::make_shared()); - UnfoldingEvent e4(EventSet({&e2}), std::make_shared()); - UnfoldingEvent e5(EventSet({&e1}), std::make_shared()); - UnfoldingEvent e6(EventSet({&e5}), std::make_shared()); + UnfoldingEvent e1(EventSet(), std::make_shared(0)); + UnfoldingEvent e2(EventSet({&e1}), std::make_shared(1)); + UnfoldingEvent e3(EventSet({&e2}), std::make_shared(2)); + UnfoldingEvent e4(EventSet({&e2}), std::make_shared(3)); + UnfoldingEvent e5(EventSet({&e1}), std::make_shared(4)); + UnfoldingEvent e6(EventSet({&e5}), std::make_shared(5)); // 6 choose 0 = 1 test // There are no events even to be in conflict with @@ -1080,7 +1105,7 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Topological Ordering Property Observed const EventSet subset = [&subset_of_iterators]() { EventSet subset_local; - for (const auto iter : subset_of_iterators) { + for (const auto& iter : subset_of_iterators) { subset_local.insert(*iter); } return subset_local; @@ -1126,4 +1151,4 @@ TEST_CASE("simgrid::mc::udpor::EventSet: Topological Ordering Property Observed }); } } -} \ No newline at end of file +}