mirror of
https://github.com/OpenVPN/openvpn3.git
synced 2024-09-20 12:12:15 +02:00
[test/misc] Convert misc/route to unittest
Signed-off-by: Arne Schwabe <arne@openvpn.net>
This commit is contained in:
parent
3bedfb5458
commit
ecb75b3644
@ -1,146 +0,0 @@
|
||||
// TEST : {"cmd": "./go route", "expected_output": "route.txt"}
|
||||
|
||||
#include <iostream>
|
||||
#include <set>
|
||||
|
||||
#include <openvpn/log/logsimple.hpp>
|
||||
#include <openvpn/common/size.hpp>
|
||||
#include <openvpn/common/exception.hpp>
|
||||
|
||||
#include <openvpn/addr/route.hpp>
|
||||
|
||||
using namespace openvpn;
|
||||
|
||||
void test(const std::string& rstr)
|
||||
{
|
||||
const IP::Route r(rstr);
|
||||
std::cout << rstr << " -> " << r << std::endl;
|
||||
}
|
||||
|
||||
void test4(const std::string& rstr)
|
||||
{
|
||||
const IP::Route4 r(rstr);
|
||||
std::cout << rstr << " -> " << r << std::endl;
|
||||
}
|
||||
|
||||
void test6(const std::string& rstr)
|
||||
{
|
||||
const IP::Route6 r(rstr);
|
||||
std::cout << rstr << " -> " << r << std::endl;
|
||||
}
|
||||
|
||||
void test_set()
|
||||
{
|
||||
OPENVPN_LOG("===== ROUTE SET =====");
|
||||
std::set<IP::Route> routes;
|
||||
routes.emplace("1.2.3.4/24");
|
||||
routes.emplace("1.2.3.0/24");
|
||||
routes.emplace("1.2.3.2/24");
|
||||
routes.emplace("1.2.3.1/24");
|
||||
routes.emplace("128.0.0.0/1");
|
||||
routes.emplace("1:2:3:4:5:6:dead:beef/64");
|
||||
routes.emplace("1:2:3:4:5:6:dead:bead/64");
|
||||
|
||||
for (const auto &r : routes)
|
||||
OPENVPN_LOG(r.to_string());
|
||||
}
|
||||
|
||||
template <typename LIST>
|
||||
void test_split(const LIST& rtlist)
|
||||
{
|
||||
OPENVPN_LOG("TEST SPLIT");
|
||||
typedef typename LIST::value_type RT;
|
||||
for (const auto &r : rtlist)
|
||||
{
|
||||
RT r1, r2;
|
||||
if (r.is_canonical() && r.split(r1, r2))
|
||||
OPENVPN_LOG(r << ' ' << r1 << ' ' << r2);
|
||||
}
|
||||
}
|
||||
|
||||
void test_list4()
|
||||
{
|
||||
OPENVPN_LOG("===== ROUTE4 LIST =====");
|
||||
IP::Route4List routes;
|
||||
routes.emplace_back("1.2.3.4/24");
|
||||
routes.emplace_back("1.2.3.0/24");
|
||||
routes.emplace_back("1.2.3.2/24");
|
||||
routes.emplace_back("1.2.3.1/24");
|
||||
routes.emplace_back("128.0.0.0/1");
|
||||
OPENVPN_LOG_NTNL(routes.to_string());
|
||||
if (routes.contains(IPv4::Addr::from_string("100.1.2.3")))
|
||||
throw Exception("unexpected contains #1");
|
||||
if (!routes.contains(IPv4::Addr::from_string("200.1.2.3")))
|
||||
throw Exception("unexpected contains #2");
|
||||
test_split(routes);
|
||||
}
|
||||
|
||||
void test_list6()
|
||||
{
|
||||
OPENVPN_LOG("===== ROUTE6 LIST =====");
|
||||
IP::Route6List routes;
|
||||
routes.emplace_back("1:2:3:4:5:6:dead:beef/64");
|
||||
routes.emplace_back("cafe:babe::/64");
|
||||
OPENVPN_LOG_NTNL(routes.to_string());
|
||||
if (routes.contains(IPv6::Addr::from_string("1111:2222:3333:4444:5555:6666:7777:8888")))
|
||||
throw Exception("unexpected contains #1");
|
||||
if (!routes.contains(IPv6::Addr::from_string("cafe:babe:0:0:1111:2222:3333:4444")))
|
||||
throw Exception("unexpected contains #2");
|
||||
test_split(routes);
|
||||
}
|
||||
|
||||
void test_list()
|
||||
{
|
||||
OPENVPN_LOG("===== ROUTE LIST =====");
|
||||
IP::RouteList routes;
|
||||
routes.emplace_back("1.2.3.4/24");
|
||||
routes.emplace_back("1.2.3.0/24");
|
||||
routes.emplace_back("1.2.3.2/24");
|
||||
routes.emplace_back("1.2.3.1/24");
|
||||
routes.emplace_back("128.0.0.0/1");
|
||||
routes.emplace_back("1:2:3:4:5:6:dead:beef/64");
|
||||
routes.emplace_back("cafe:babe::/64");
|
||||
OPENVPN_LOG_NTNL(routes.to_string());
|
||||
if (routes.contains(IP::Addr::from_string("100.1.2.3")))
|
||||
throw Exception("unexpected contains #1");
|
||||
if (!routes.contains(IP::Addr::from_string("200.1.2.3")))
|
||||
throw Exception("unexpected contains #2");
|
||||
if (routes.contains(IP::Addr::from_string("1111:2222:3333:4444:5555:6666:7777:8888")))
|
||||
throw Exception("unexpected contains #3");
|
||||
if (!routes.contains(IP::Addr::from_string("cafe:babe:0:0:1111:2222:3333:4444")))
|
||||
throw Exception("unexpected contains #4");
|
||||
test_split(routes);
|
||||
}
|
||||
|
||||
int main(int /*argc*/, char* /*argv*/[])
|
||||
{
|
||||
try {
|
||||
test("1.2.3.4");
|
||||
test("192.168.4.0/24");
|
||||
test("fe80::6470:7dff:fea5:f360/64");
|
||||
|
||||
test4("1.2.3.4");
|
||||
test4("192.168.4.0/24");
|
||||
test6("fe80::6470:7dff:fea5:f360/64");
|
||||
|
||||
try {
|
||||
test("192.168.4.0/33");
|
||||
}
|
||||
catch (const std::exception& e)
|
||||
{
|
||||
OPENVPN_LOG("expected exception: " << e.what());
|
||||
}
|
||||
|
||||
test_set();
|
||||
|
||||
test_list4();
|
||||
test_list6();
|
||||
test_list();
|
||||
}
|
||||
catch (const std::exception& e)
|
||||
{
|
||||
std::cerr << "Exception: " << e.what() << std::endl;
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
116
test/unittests/test_route.cpp
Normal file
116
test/unittests/test_route.cpp
Normal file
@ -0,0 +1,116 @@
|
||||
#include "test_common.h"
|
||||
|
||||
#include <iostream>
|
||||
#include <set>
|
||||
|
||||
#include <openvpn/common/exception.hpp>
|
||||
|
||||
#include <openvpn/addr/route.hpp>
|
||||
|
||||
using namespace openvpn;
|
||||
|
||||
void test_route_parse(const std::string &rstr, const std::string &expected, bool ipv6) {
|
||||
const IP::Route r(rstr);
|
||||
ASSERT_EQ(r.to_string(), expected);
|
||||
|
||||
if (ipv6) {
|
||||
const IP::Route6 r6(rstr);
|
||||
ASSERT_EQ(r6.to_string(), expected);
|
||||
} else {
|
||||
const IP::Route4 r4(rstr);
|
||||
ASSERT_EQ(r4.to_string(), expected);
|
||||
}
|
||||
}
|
||||
|
||||
TEST(IPAddr, routeSet) {
|
||||
std::set<IP::Route> routes;
|
||||
routes.emplace("1.2.3.4/24");
|
||||
routes.emplace("1.2.3.0/24");
|
||||
routes.emplace("1.2.3.2/24");
|
||||
routes.emplace("1.2.3.1/24");
|
||||
routes.emplace("128.0.0.0/1");
|
||||
routes.emplace("1:2:3:4:5:6:dead:beef/64");
|
||||
routes.emplace("1:2:3:4:5:6:dead:bead/64");
|
||||
|
||||
std::stringstream out;
|
||||
for (const auto &r : routes)
|
||||
out << r.to_string() << std::endl;
|
||||
|
||||
ASSERT_EQ("128.0.0.0/1\n"
|
||||
"1.2.3.0/24\n"
|
||||
"1.2.3.1/24\n"
|
||||
"1.2.3.2/24\n"
|
||||
"1.2.3.4/24\n"
|
||||
"1:2:3:4:5:6:dead:bead/64\n"
|
||||
"1:2:3:4:5:6:dead:beef/64\n",
|
||||
out.str()
|
||||
);
|
||||
}
|
||||
|
||||
template<typename LIST>
|
||||
void test_split(const LIST &rtlist, const std::string &expected) {
|
||||
typedef typename LIST::value_type RT;
|
||||
std::stringstream out;
|
||||
for (const auto &r : rtlist) {
|
||||
RT r1, r2;
|
||||
if (r.is_canonical() && r.split(r1, r2)) {
|
||||
out << r << ' ' << r1 << ' ' << r2 << std::endl;
|
||||
}
|
||||
}
|
||||
ASSERT_EQ(expected, out.str());
|
||||
}
|
||||
|
||||
TEST(IPAddr, routeList4) {
|
||||
IP::Route4List routes;
|
||||
routes.emplace_back("1.2.3.4/24");
|
||||
routes.emplace_back("1.2.3.0/24");
|
||||
routes.emplace_back("1.2.3.2/24");
|
||||
routes.emplace_back("1.2.3.1/24");
|
||||
routes.emplace_back("128.0.0.0/1");
|
||||
//OPENVPN_LOG_NTNL(routes.to_string());
|
||||
ASSERT_FALSE(routes.contains(IPv4::Addr::from_string("100.1.2.3")));
|
||||
ASSERT_TRUE(routes.contains(IPv4::Addr::from_string("200.1.2.3")));
|
||||
|
||||
test_split(routes, "1.2.3.0/24 1.2.3.0/25 1.2.3.128/25\n128.0.0.0/1 128.0.0.0/2 192.0.0.0/2\n");
|
||||
}
|
||||
|
||||
TEST(IPAddr, routeList6) {
|
||||
IP::Route6List routes;
|
||||
routes.emplace_back("1:2:3:4:5:6:dead:beef/64");
|
||||
routes.emplace_back("cafe:babe::/64");
|
||||
//OPENVPN_LOG_NTNL(routes.to_string());
|
||||
ASSERT_FALSE(routes.contains(IPv6::Addr::from_string("1111:2222:3333:4444:5555:6666:7777:8888")));
|
||||
ASSERT_TRUE(routes.contains(IPv6::Addr::from_string("cafe:babe:0:0:1111:2222:3333:4444")));
|
||||
test_split(routes, "cafe:babe::/64 cafe:babe::/65 cafe:babe:0:0:8000::/65\n");
|
||||
}
|
||||
|
||||
TEST(IPAddr, routeList) {
|
||||
IP::RouteList routes;
|
||||
routes.emplace_back("1.2.3.4/24");
|
||||
routes.emplace_back("1.2.3.0/24");
|
||||
routes.emplace_back("1.2.3.2/24");
|
||||
routes.emplace_back("1.2.3.1/24");
|
||||
routes.emplace_back("128.0.0.0/1");
|
||||
routes.emplace_back("1:2:3:4:5:6:dead:beef/64");
|
||||
routes.emplace_back("cafe:babe::/64");
|
||||
//OPENVPN_LOG_NTNL(routes.to_string());
|
||||
ASSERT_FALSE (routes.contains(IP::Addr::from_string("100.1.2.3")));
|
||||
ASSERT_TRUE (routes.contains(IP::Addr::from_string("200.1.2.3")));
|
||||
ASSERT_FALSE (routes.contains(IP::Addr::from_string("1111:2222:3333:4444:5555:6666:7777:8888")));
|
||||
ASSERT_TRUE (routes.contains(IP::Addr::from_string("cafe:babe:0:0:1111:2222:3333:4444")));
|
||||
|
||||
test_split(routes, "1.2.3.0/24 1.2.3.0/25 1.2.3.128/25\n"
|
||||
"128.0.0.0/1 128.0.0.0/2 192.0.0.0/2\n"
|
||||
"cafe:babe::/64 cafe:babe::/65 cafe:babe:0:0:8000::/65\n");
|
||||
}
|
||||
|
||||
TEST(IPAddr, parseRoutes) {
|
||||
test_route_parse("1.2.3.4", "1.2.3.4/32", false);
|
||||
test_route_parse("192.168.4.0/24", "192.168.4.0/24", false);
|
||||
test_route_parse("fe80::6470:7dff:fea5:f360/64", "fe80::6470:7dff:fea5:f360/64", true);
|
||||
|
||||
ASSERT_THROW(
|
||||
IP::Route("192.168.4.0/33"),
|
||||
std::exception
|
||||
);
|
||||
}
|
Loading…
Reference in New Issue
Block a user