Merge pull request #616 from Qv2ray/dev-test-vmess

Add Test Cases for VMess Parser
This commit is contained in:
Qv2ray-dev 2020-05-17 00:08:40 +08:00 committed by GitHub
commit 9fd27f39e3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -2,3 +2,91 @@
#include "src/core/connection/Serialization.hpp"
#define CATCH_CONFIG_MAIN
#include "catch.hpp"
SCENARIO("Test Parse VMess V2 url", "[ParseVMessV2]")
{
GIVEN("vmess+tcp")
{
QString _;
const QString address = "42.255.255.254";
const int alterId = 4;
const QString uuid = "59f34e8c-f310-49b0-b240-11663e365601";
const QString network = "tcp";
const int port = 11451;
const QString comment = "日本 VIP节点5 - 10Mbps带宽 苏州-日本 IPLC-CEN专线 游戏加速用 30倍流量比例 原生日本IP落地";
WHEN("parse Qv2ray 2.5.0 generated uri")
{
const QString vmessString = "vmess://eyJhZGQiOiI0Mi4yNTUuMjU1LjI1NCIsImFpZCI6NCwiaWQiOiI1OWYzNGU4Yy1mMzEw"
"LTQ5YjAtYjI0MC0xMTY2M2UzNjU2MDEiLCJuZXQiOiJ0Y3AiLCJwb3J0IjoxMTQ1MSwicHMiOiLm"
"l6XmnKwgVklQ6IqC54K5NSAtIDEwTWJwc+W4puWuvSDoi4/lt54t5pel5pysIElQTEMtQ0VO5LiT"
"57q/IOa4uOaIj+WKoOmAn+eUqCAzMOWAjea1gemHj+avlOS+iyDljp/nlJ/ml6XmnKxJUOiQveWc"
"sCIsInRscyI6Im5vbmUiLCJ0eXBlIjoibm9uZSIsInYiOjJ9Cg==";
QString commentParsed;
const auto result = vmess::Deserialize(vmessString, &commentParsed, &_);
INFO("Raw VMess: " << vmessString.toStdString());
INFO("Parsed JSON: " << QJsonDocument(result).toJson().toStdString());
const auto networkParsed = QJsonIO::GetValue(result, "outbounds", 0, "streamSettings", "network").toString();
const auto addressParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "address").toString();
const auto portParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "port").toInt();
const auto idParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "users", 0, "id").toString();
const auto alterIdParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "users", 0, "alterId").toInt();
const auto typeParsed = QJsonIO::GetValue(result, "outbounds", 0, "streamSettings", "tcpSettings", "header", "type").toString();
REQUIRE(commentParsed.toStdString() == comment.toStdString());
REQUIRE(addressParsed.toStdString() == address.toStdString());
REQUIRE(portParsed == port);
REQUIRE(idParsed.toStdString() == uuid.toStdString());
REQUIRE(alterIdParsed == alterId);
REQUIRE(networkParsed.toStdString() == network.toStdString());
REQUIRE(typeParsed.toStdString() == "none");
}
}
}
SCENARIO("Test Parse VMess V1 url", "[ParseVMessV1]")
{
GIVEN("vmess+ws")
{
QString _;
const QString address = "motherfucker.net";
const int alterId = 0;
const QString path = "/yaboviss";
const QString network = "ws";
const QString uuid = "40980939-f6bd-4b17-ad26-c2aed2f1b3fc";
const QString comment = "good bye vmess v1";
const int port = 8003;
WHEN("parse all stringified vmess v1")
{
const QString vmessString = "vmess://eyJwcyI6Imdvb2QgYnllIHZtZXNzIHYxIiwiYWRkIjoibW90aGVyZnVja2VyLm5ldCIs"
"InBvcnQiOiI4MDAzIiwiaWQiOiI0MDk4MDkzOS1mNmJkLTRiMTctYWQyNi1jMmFlZDJmMWIzZmMi"
"LCJhaWQiOiIwIiwibmV0Ijoid3MiLCJ0eXBlIjoibm9uZSIsImhvc3QiOiIveWFib3Zpc3MiLCJ0"
"bHMiOiIifQo=";
QString commentParsed;
const auto result = vmess::Deserialize(vmessString, &commentParsed, &_);
INFO("Raw VMess: " << vmessString.toStdString());
INFO("Parsed JSON: " << QJsonDocument(result).toJson().toStdString());
const auto networkParsed = QJsonIO::GetValue(result, "outbounds", 0, "streamSettings", "network").toString();
const auto addressParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "address").toString();
const auto portParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "port").toInt();
const auto idParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "users", 0, "id").toString();
const auto alterIdParsed = QJsonIO::GetValue(result, "outbounds", 0, "settings", "vnext", 0, "users", 0, "alterId").toInt();
const auto typeParsed = QJsonIO::GetValue(result, "outbounds", 0, "streamSettings", "tcpSettings", "header", "type").toString();
const auto tlsParsed = QJsonIO::GetValue(result, "outbounds", 0, "streamSettings", "security").toString();
REQUIRE(commentParsed.toStdString() == comment.toStdString());
REQUIRE(addressParsed.toStdString() == address.toStdString());
REQUIRE(portParsed == port);
REQUIRE(idParsed.toStdString() == uuid.toStdString());
REQUIRE(alterIdParsed == alterId);
REQUIRE(networkParsed.toStdString() == network.toStdString());
REQUIRE(typeParsed.toStdString() == "none");
REQUIRE(tlsParsed.toStdString() == "none");
}
}
}