mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
parent
b848fa9af1
commit
2560af3a1d
16
net.cpp
16
net.cpp
@ -32,7 +32,13 @@ using namespace dev::p2p;
|
|||||||
namespace ba = boost::asio;
|
namespace ba = boost::asio;
|
||||||
namespace bi = ba::ip;
|
namespace bi = ba::ip;
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE(net)
|
struct NetFixture
|
||||||
|
{
|
||||||
|
NetFixture() { dev::p2p::NodeIPEndpoint::test_allowLocal = true;; }
|
||||||
|
~NetFixture() { dev::p2p::NodeIPEndpoint::test_allowLocal = false; }
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_FIXTURE_TEST_SUITE(net, NetFixture)
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Only used for testing. Not useful beyond tests.
|
* Only used for testing. Not useful beyond tests.
|
||||||
@ -53,7 +59,7 @@ protected:
|
|||||||
struct TestNodeTable: public NodeTable
|
struct TestNodeTable: public NodeTable
|
||||||
{
|
{
|
||||||
/// Constructor
|
/// Constructor
|
||||||
TestNodeTable(ba::io_service& _io, KeyPair _alias, bi::address const& _addr, uint16_t _port = 30300): NodeTable(_io, _alias, _addr, _port) {}
|
TestNodeTable(ba::io_service& _io, KeyPair _alias, bi::address const& _addr, uint16_t _port = 30300): NodeTable(_io, _alias, NodeIPEndpoint(_addr, _port, _port)) {}
|
||||||
|
|
||||||
static std::vector<std::pair<KeyPair,unsigned>> createTestNodes(unsigned _count)
|
static std::vector<std::pair<KeyPair,unsigned>> createTestNodes(unsigned _count)
|
||||||
{
|
{
|
||||||
@ -93,7 +99,7 @@ struct TestNodeTable: public NodeTable
|
|||||||
// manually add node for test
|
// manually add node for test
|
||||||
{
|
{
|
||||||
Guard ln(x_nodes);
|
Guard ln(x_nodes);
|
||||||
shared_ptr<NodeEntry> node(new NodeEntry(m_node, n.first.pub(), NodeIPEndpoint(bi::udp::endpoint(ourIp, n.second), bi::tcp::endpoint(ourIp, n.second))));
|
shared_ptr<NodeEntry> node(new NodeEntry(m_node, n.first.pub(), NodeIPEndpoint(ourIp, n.second, n.second)));
|
||||||
node->pending = false;
|
node->pending = false;
|
||||||
m_nodes[node->id] = node;
|
m_nodes[node->id] = node;
|
||||||
}
|
}
|
||||||
@ -201,7 +207,7 @@ BOOST_AUTO_TEST_CASE(test_neighbours_packet)
|
|||||||
{
|
{
|
||||||
Neighbours::Node node;
|
Neighbours::Node node;
|
||||||
node.ipAddress = boost::asio::ip::address::from_string("127.0.0.1").to_string();
|
node.ipAddress = boost::asio::ip::address::from_string("127.0.0.1").to_string();
|
||||||
node.port = n.second;
|
node.udpPort = n.second;
|
||||||
node.node = n.first.pub();
|
node.node = n.first.pub();
|
||||||
out.nodes.push_back(node);
|
out.nodes.push_back(node);
|
||||||
}
|
}
|
||||||
@ -213,7 +219,7 @@ BOOST_AUTO_TEST_CASE(test_neighbours_packet)
|
|||||||
int count = 0;
|
int count = 0;
|
||||||
for (auto n: in.nodes)
|
for (auto n: in.nodes)
|
||||||
{
|
{
|
||||||
BOOST_REQUIRE_EQUAL(testNodes[count].second, n.port);
|
BOOST_REQUIRE_EQUAL(testNodes[count].second, n.udpPort);
|
||||||
BOOST_REQUIRE_EQUAL(testNodes[count].first.pub(), n.node);
|
BOOST_REQUIRE_EQUAL(testNodes[count].first.pub(), n.node);
|
||||||
BOOST_REQUIRE_EQUAL(sha3(testNodes[count].first.pub()), sha3(n.node));
|
BOOST_REQUIRE_EQUAL(sha3(testNodes[count].first.pub()), sha3(n.node));
|
||||||
count++;
|
count++;
|
||||||
|
16
peer.cpp
16
peer.cpp
@ -28,7 +28,13 @@ using namespace std;
|
|||||||
using namespace dev;
|
using namespace dev;
|
||||||
using namespace dev::p2p;
|
using namespace dev::p2p;
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE(p2p)
|
struct P2PFixture
|
||||||
|
{
|
||||||
|
P2PFixture() { dev::p2p::NodeIPEndpoint::test_allowLocal = true;; }
|
||||||
|
~P2PFixture() { dev::p2p::NodeIPEndpoint::test_allowLocal = false; }
|
||||||
|
};
|
||||||
|
|
||||||
|
BOOST_FIXTURE_TEST_SUITE(p2p, P2PFixture)
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(host)
|
BOOST_AUTO_TEST_CASE(host)
|
||||||
{
|
{
|
||||||
@ -45,7 +51,7 @@ BOOST_AUTO_TEST_CASE(host)
|
|||||||
auto node2 = host2.id();
|
auto node2 = host2.id();
|
||||||
host2.start();
|
host2.start();
|
||||||
|
|
||||||
host1.addNode(node2, bi::address::from_string("127.0.0.1"), host2prefs.listenPort, host2prefs.listenPort);
|
host1.addNode(node2, NodeIPEndpoint(bi::address::from_string("127.0.0.1"), host2prefs.listenPort, host2prefs.listenPort));
|
||||||
|
|
||||||
this_thread::sleep_for(chrono::seconds(3));
|
this_thread::sleep_for(chrono::seconds(3));
|
||||||
|
|
||||||
@ -82,11 +88,11 @@ BOOST_AUTO_TEST_CASE(save_nodes)
|
|||||||
|
|
||||||
Host& host = *hosts.front();
|
Host& host = *hosts.front();
|
||||||
for (auto const& h: hosts)
|
for (auto const& h: hosts)
|
||||||
host.addNode(h->id(), bi::address::from_string("127.0.0.1"), h->listenPort(), h->listenPort());
|
host.addNode(h->id(), NodeIPEndpoint(bi::address::from_string("127.0.0.1"), h->listenPort(), h->listenPort()));
|
||||||
|
|
||||||
Host& host2 = *hosts.back();
|
Host& host2 = *hosts.back();
|
||||||
for (auto const& h: hosts)
|
for (auto const& h: hosts)
|
||||||
host2.addNode(h->id(), bi::address::from_string("127.0.0.1"), h->listenPort(), h->listenPort());
|
host2.addNode(h->id(), NodeIPEndpoint(bi::address::from_string("127.0.0.1"), h->listenPort(), h->listenPort()));
|
||||||
|
|
||||||
this_thread::sleep_for(chrono::milliseconds(2000));
|
this_thread::sleep_for(chrono::milliseconds(2000));
|
||||||
bytes firstHostNetwork(host.saveNetwork());
|
bytes firstHostNetwork(host.saveNetwork());
|
||||||
@ -131,7 +137,7 @@ int peerTest(int argc, char** argv)
|
|||||||
Host ph("Test", NetworkPreferences(listenPort));
|
Host ph("Test", NetworkPreferences(listenPort));
|
||||||
|
|
||||||
if (!remoteHost.empty() && !remoteAlias)
|
if (!remoteHost.empty() && !remoteAlias)
|
||||||
ph.addNode(remoteAlias, bi::address::from_string(remoteHost), remotePort, remotePort);
|
ph.addNode(remoteAlias, NodeIPEndpoint(bi::address::from_string(remoteHost), remotePort, remotePort));
|
||||||
|
|
||||||
this_thread::sleep_for(chrono::milliseconds(200));
|
this_thread::sleep_for(chrono::milliseconds(200));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user