|
|
@ -69,3 +69,44 @@ TEST_CASE("Parse can messages") { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TEST_CASE("Parse dbc") { |
|
|
|
|
|
|
|
QString content = R"( |
|
|
|
|
|
|
|
BO_ 160 message_1: 8 XXX |
|
|
|
|
|
|
|
SG_ signal_1 : 0|12@1+ (1,0) [0|4095] "unit" XXX |
|
|
|
|
|
|
|
SG_ signal_2 : 12|1@1+ (1.0,0.0) [0.0|1] "" XXX |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
VAL_ 160 signal_1 0 "disabled" 1.2 "initializing" 2 "fault"; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CM_ BO_ 160 "message comment"; |
|
|
|
|
|
|
|
CM_ SG_ 160 signal_1 "signal comment"; |
|
|
|
|
|
|
|
CM_ SG_ 160 signal_2 "multiple line comment |
|
|
|
|
|
|
|
1 |
|
|
|
|
|
|
|
2 |
|
|
|
|
|
|
|
";)"; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
DBCFile file("", content); |
|
|
|
|
|
|
|
auto msg = file.msg(160); |
|
|
|
|
|
|
|
REQUIRE(msg != nullptr); |
|
|
|
|
|
|
|
REQUIRE(msg->name == "message_1"); |
|
|
|
|
|
|
|
REQUIRE(msg->size == 8); |
|
|
|
|
|
|
|
REQUIRE(msg->comment == "message comment"); |
|
|
|
|
|
|
|
REQUIRE(msg->sigs.size() == 2); |
|
|
|
|
|
|
|
REQUIRE(file.msg("message_1") != nullptr); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
auto &sig_1 = msg->sigs[0]; |
|
|
|
|
|
|
|
REQUIRE(sig_1.name == "signal_1"); |
|
|
|
|
|
|
|
REQUIRE(sig_1.start_bit == 0); |
|
|
|
|
|
|
|
REQUIRE(sig_1.size == 12); |
|
|
|
|
|
|
|
REQUIRE(sig_1.min == 0); |
|
|
|
|
|
|
|
REQUIRE(sig_1.max == 4095); |
|
|
|
|
|
|
|
REQUIRE(sig_1.unit == "unit"); |
|
|
|
|
|
|
|
REQUIRE(sig_1.comment == "signal comment"); |
|
|
|
|
|
|
|
REQUIRE(sig_1.val_desc.size() == 3); |
|
|
|
|
|
|
|
REQUIRE(sig_1.val_desc[0] == std::pair<double, QString>{0, "disabled"}); |
|
|
|
|
|
|
|
REQUIRE(sig_1.val_desc[1] == std::pair<double, QString>{1.2, "initializing"}); |
|
|
|
|
|
|
|
REQUIRE(sig_1.val_desc[2] == std::pair<double, QString>{2, "fault"}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
auto &sig_2 = msg->sigs[1]; |
|
|
|
|
|
|
|
REQUIRE(sig_2.comment == "multiple line comment\n1\n2"); |
|
|
|
|
|
|
|
} |
|
|
|