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
|
/*
* Copyright (C) 2017-2018 Olzhas Rakhimov
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "alignment.h"
#include <catch.hpp>
#include "error.h"
namespace scram::mef::test {
TEST_CASE("PhaseTest.TimeFraction", "[mef::alignment]") {
CHECK_NOTHROW(Phase("phase", 0.5));
CHECK_NOTHROW(Phase("phase", 0.1));
CHECK_NOTHROW(Phase("phase", 1));
CHECK_THROWS_AS(Phase("phase", 0), DomainError);
CHECK_THROWS_AS(Phase("phase", 1.1), DomainError);
CHECK_THROWS_AS(Phase("phase", -0.1), DomainError);
}
TEST_CASE("AlignmentTest.AddPhase", "[mef::alignment]") {
Alignment alignment("mission");
auto phase_one = std::make_unique<Phase>("one", 0.5);
auto phase_two = std::make_unique<Phase>("one", 0.1); // Duplicate name.
auto phase_three = std::make_unique<Phase>("three", 0.1);
CHECK(alignment.phases().empty());
auto* phase_one_address = phase_one.get();
REQUIRE_NOTHROW(alignment.Add(std::move(phase_one)));
CHECK(alignment.phases().size() == 1);
CHECK(alignment.phases().begin()->get() == phase_one_address);
CHECK_THROWS_AS(alignment.Add(std::move(phase_two)), DuplicateArgumentError);
CHECK(alignment.phases().size() == 1);
CHECK(alignment.phases().begin()->get() == phase_one_address);
REQUIRE_NOTHROW(alignment.Add(std::move(phase_three)));
CHECK(alignment.phases().size() == 2);
}
TEST_CASE("AlignmentTest.Validation", "[mef::alignment]") {
Alignment alignment("mission");
auto phase_one = std::make_unique<Phase>("one", 0.5);
auto phase_two = std::make_unique<Phase>("two", 0.5);
auto phase_three = std::make_unique<Phase>("three", 0.1);
CHECK_THROWS_AS(alignment.Validate(), ValidityError);
REQUIRE_NOTHROW(alignment.Add(std::move(phase_one)));
CHECK_THROWS_AS(alignment.Validate(), ValidityError);
REQUIRE_NOTHROW(alignment.Add(std::move(phase_two)));
CHECK_NOTHROW(alignment.Validate());
REQUIRE_NOTHROW(alignment.Add(std::move(phase_three)));
CHECK_THROWS_AS(alignment.Validate(), ValidityError);
}
} // namespace scram::mef::test
|