X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fpackage%2FCatalogTest.cxx;h=12dd42d7a72ca5b2a916a349c86dd74b323adb13;hb=a3f1bb546fec72b07f11f69934e6894696fea57a;hp=e2b98aca74557fa254ce480795169f5d6f2ca7de;hpb=d12d1b2c3ac5ae4981665a65f49a34c465063f02;p=simgear.git diff --git a/simgear/package/CatalogTest.cxx b/simgear/package/CatalogTest.cxx index e2b98aca..12dd42d7 100644 --- a/simgear/package/CatalogTest.cxx +++ b/simgear/package/CatalogTest.cxx @@ -46,7 +46,7 @@ int parseTest() COMPARE(cat->description(), "First test catalog"); // check the packages too - COMPARE(cat->packages().size(), 2); + COMPARE(cat->packages().size(), 3); pkg::PackageRef p1 = cat->packages().front(); COMPARE(p1->catalog(), cat.ptr()); @@ -66,6 +66,34 @@ int parseTest() // test filtering / searching too + string_set tags(p2->tags()); + COMPARE(tags.size(), 4); + VERIFY(tags.find("ifr") != tags.end()); + VERIFY(tags.find("cessna") != tags.end()); + VERIFY(tags.find("jet") == tags.end()); + + + SGPropertyNode_ptr queryA(new SGPropertyNode); + queryA->setStringValue("tag", "ifr"); + VERIFY(p2->matches(queryA.ptr())); + + SGPropertyNode_ptr queryB(new SGPropertyNode); + queryB->setStringValue("name", "ces"); + VERIFY(p2->matches(queryB.ptr())); + + SGPropertyNode_ptr queryC(new SGPropertyNode); + queryC->setStringValue("name", "foo"); + VERIFY(!p2->matches(queryC.ptr())); + + SGPropertyNode_ptr queryD(new SGPropertyNode); + queryD->setIntValue("rating-FDM", 3); + VERIFY(p2->matches(queryD.ptr())); + + SGPropertyNode_ptr queryE(new SGPropertyNode); + queryE->setIntValue("rating-model", 5); + queryE->setStringValue("description", "cessna"); + VERIFY(p2->matches(queryE.ptr())); + delete root; return EXIT_SUCCESS;