Refactor aopacket tests
This commit is contained in:
parent
9c4f8dfc97
commit
7a1d6743e1
@ -6,42 +6,38 @@
|
||||
TEST_CASE("AOPacket construct", "[aopacket]") {
|
||||
// Parameters
|
||||
QString packet_string = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/123/edit##%";
|
||||
QString header = "CT";
|
||||
QStringList contents = {"MY_OOC_NAME", "/doc https://docs.google.com/document/d/123/edit#"};
|
||||
|
||||
// Packet string only
|
||||
AOPacket p(packet_string);
|
||||
REQUIRE(p.to_string() == packet_string);
|
||||
|
||||
// Header and Contents Separate
|
||||
AOPacket p2(header, contents);
|
||||
REQUIRE(p2.to_string() == packet_string);
|
||||
SECTION("Packet string") {
|
||||
AOPacket p(packet_string);
|
||||
REQUIRE(p.to_string() == packet_string);
|
||||
}
|
||||
SECTION("Header and contents") {
|
||||
AOPacket p("CT", {"MY_OOC_NAME", "/doc https://docs.google.com/document/d/123/edit#"});
|
||||
REQUIRE(p.to_string() == packet_string);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("AOPacket encode/decode", "[aopacket]") {
|
||||
// Parameters
|
||||
QString packet_string = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/%$&/edit##%";
|
||||
QString header = "CT";
|
||||
QStringList contents = {"MY_OOC_NAME", "/doc https://docs.google.com/document/d/%$&/edit#"};
|
||||
QString good_encode = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/<percent><dollar><and>/edit<num>#%";
|
||||
|
||||
// Encodes that get "sent" to the server
|
||||
QString bad_send = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/<percent><dollar><and>/edit##%";
|
||||
QString good_send = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/<percent><dollar><and>/edit<num>#%";
|
||||
SECTION("Bad encode/decode because packet string constructor splits the '#' after 'edit'") {
|
||||
AOPacket p(packet_string);
|
||||
p.net_encode();
|
||||
REQUIRE(p.to_string() != good_encode);
|
||||
|
||||
// Bad encode/decode for docs because the split on '#' after "edit" in the doc url
|
||||
AOPacket p(packet_string);
|
||||
p.net_encode();
|
||||
REQUIRE(p.to_string() == bad_send);
|
||||
p.net_decode();
|
||||
REQUIRE(p.to_string() == packet_string);
|
||||
}
|
||||
|
||||
p.net_decode();
|
||||
REQUIRE(p.to_string() == packet_string);
|
||||
SECTION("Good encode/decode with header and contents constructor") {
|
||||
AOPacket p("CT", {"MY_OOC_NAME", "/doc https://docs.google.com/document/d/%$&/edit#"});
|
||||
|
||||
// Good encode/decode for docs because header and contents are separate
|
||||
AOPacket p2(header, contents);
|
||||
p.net_encode();
|
||||
REQUIRE(p.to_string() == good_encode);
|
||||
|
||||
p2.net_encode();
|
||||
REQUIRE(p2.to_string() == good_send);
|
||||
|
||||
p2.net_decode();
|
||||
REQUIRE(p2.to_string() == packet_string);
|
||||
p.net_decode();
|
||||
REQUIRE(p.to_string() == packet_string);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user