aboutsummaryrefslogtreecommitdiffstats
path: root/whisperTopic.cpp
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2015-04-21 18:04:12 +0800
committerchriseth <c@ethdev.com>2015-04-21 18:04:12 +0800
commitddbaa99056b10052f0539a0afdffab53cc941dab (patch)
tree24888094abc1918b779043512893d82b3251ed43 /whisperTopic.cpp
parent8caf1f723ffe9c8592e995f6e82571fbe2185fd0 (diff)
parente375612a7ecbab9ad33a6a40df1c722a82e07630 (diff)
downloaddexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.tar
dexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.tar.gz
dexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.tar.bz2
dexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.tar.lz
dexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.tar.xz
dexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.tar.zst
dexon-solidity-ddbaa99056b10052f0539a0afdffab53cc941dab.zip
Merge remote-tracking branch 'ethereum/develop' into sol_overloadingFunctions
Diffstat (limited to 'whisperTopic.cpp')
-rw-r--r--whisperTopic.cpp301
1 files changed, 0 insertions, 301 deletions
diff --git a/whisperTopic.cpp b/whisperTopic.cpp
deleted file mode 100644
index 0ea681b6..00000000
--- a/whisperTopic.cpp
+++ /dev/null
@@ -1,301 +0,0 @@
-/*
- This file is part of cpp-ethereum.
-
- cpp-ethereum is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
-
- cpp-ethereum is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with cpp-ethereum. If not, see <http://www.gnu.org/licenses/>.
-*/
-/** @file whisperTopic.cpp
- * @author Gav Wood <i@gavwood.com>
- * @date 2014
- */
-#include <functional>
-
-#include <boost/test/unit_test.hpp>
-
-#include <libp2p/Host.h>
-#include <libwhisper/WhisperPeer.h>
-#include <libwhisper/WhisperHost.h>
-using namespace std;
-using namespace dev;
-using namespace dev::p2p;
-using namespace dev::shh;
-
-BOOST_AUTO_TEST_SUITE(whisper)
-
-#if ALEX_HASH_FIXED_NETWORKING
-BOOST_AUTO_TEST_CASE(topic)
-{
- cnote << "Testing Whisper...";
- auto oldLogVerbosity = g_logVerbosity;
- g_logVerbosity = 0;
-
- Host host1("Test", NetworkPreferences(30303, "127.0.0.1", false, true));
- auto whost1 = host1.registerCapability(new WhisperHost());
- host1.start();
-
- while (!host1.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
-
- bool started = false;
- unsigned result = 0;
- std::thread listener([&]()
- {
- setThreadName("other");
- started = true;
-
- /// Only interested in odd packets
- auto w = whost1->installWatch(BuildTopicMask("odd"));
-
- started = true;
- set<unsigned> received;
-
- for (int iterout = 0, last = 0; iterout < 200 && last < 81; ++iterout)
- {
- for (auto i: whost1->checkWatch(w))
- {
- Message msg = whost1->envelope(i).open(whost1->fullTopic(w));
- last = RLP(msg.payload()).toInt<unsigned>();
- if (received.count(last))
- continue;
- received.insert(last);
- cnote << "New message from:" << msg.from().abridged() << RLP(msg.payload()).toInt<unsigned>();
- result += last;
- }
- this_thread::sleep_for(chrono::milliseconds(50));
- }
-
- });
-
- Host host2("Test", NetworkPreferences(30300, "127.0.0.1", false, true));
- auto whost2 = host2.registerCapability(new WhisperHost());
- host2.start();
-
- while (!host2.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
-
- this_thread::sleep_for(chrono::milliseconds(100));
- host2.addNode(host1.id(), "127.0.0.1", 30303, 30303);
-
- this_thread::sleep_for(chrono::milliseconds(500));
-
- while (!started)
- this_thread::sleep_for(chrono::milliseconds(2));
-
- KeyPair us = KeyPair::create();
- for (int i = 0; i < 10; ++i)
- {
- whost2->post(us.sec(), RLPStream().append(i * i).out(), BuildTopic(i)(i % 2 ? "odd" : "even"));
- this_thread::sleep_for(chrono::milliseconds(250));
- }
-
- listener.join();
- g_logVerbosity = oldLogVerbosity;
-
- BOOST_REQUIRE_EQUAL(result, 1 + 9 + 25 + 49 + 81);
-}
-
-BOOST_AUTO_TEST_CASE(forwarding)
-{
- cnote << "Testing Whisper forwarding...";
- auto oldLogVerbosity = g_logVerbosity;
- g_logVerbosity = 0;
-
- // Host must be configured not to share peers.
- Host host1("Listner", NetworkPreferences(30303, "", false, true));
- host1.setIdealPeerCount(0);
- auto whost1 = host1.registerCapability(new WhisperHost());
- host1.start();
- while (!host1.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
-
- unsigned result = 0;
- bool done = false;
-
- bool startedListener = false;
- std::thread listener([&]()
- {
- setThreadName("listener");
-
- startedListener = true;
-
- /// Only interested in odd packets
- auto w = whost1->installWatch(BuildTopicMask("test"));
-
- for (int i = 0; i < 200 && !result; ++i)
- {
- for (auto i: whost1->checkWatch(w))
- {
- Message msg = whost1->envelope(i).open(whost1->fullTopic(w));
- unsigned last = RLP(msg.payload()).toInt<unsigned>();
- cnote << "New message from:" << msg.from().abridged() << RLP(msg.payload()).toInt<unsigned>();
- result = last;
- }
- this_thread::sleep_for(chrono::milliseconds(50));
- }
- });
-
-
- // Host must be configured not to share peers.
- Host host2("Forwarder", NetworkPreferences(30305, "", false, true));
- host2.setIdealPeerCount(1);
- auto whost2 = host2.registerCapability(new WhisperHost());
- host2.start();
- while (!host2.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
-
- Public fwderid;
- bool startedForwarder = false;
- std::thread forwarder([&]()
- {
- setThreadName("forwarder");
-
- while (!startedListener)
- this_thread::sleep_for(chrono::milliseconds(50));
-
- this_thread::sleep_for(chrono::milliseconds(500));
- host2.addNode(host1.id(), "127.0.0.1", 30303, 30303);
-
- startedForwarder = true;
-
- /// Only interested in odd packets
- auto w = whost2->installWatch(BuildTopicMask("test"));
-
- while (!done)
- {
- for (auto i: whost2->checkWatch(w))
- {
- Message msg = whost2->envelope(i).open(whost2->fullTopic(w));
- cnote << "New message from:" << msg.from().abridged() << RLP(msg.payload()).toInt<unsigned>();
- }
- this_thread::sleep_for(chrono::milliseconds(50));
- }
- });
-
- while (!startedForwarder)
- this_thread::sleep_for(chrono::milliseconds(50));
-
- Host ph("Sender", NetworkPreferences(30300, "", false, true));
- ph.setIdealPeerCount(1);
- shared_ptr<WhisperHost> wh = ph.registerCapability(new WhisperHost());
- ph.start();
- ph.addNode(host2.id(), "127.0.0.1", 30305, 30305);
- while (!ph.isStarted())
- this_thread::sleep_for(chrono::milliseconds(10));
-
- KeyPair us = KeyPair::create();
- wh->post(us.sec(), RLPStream().append(1).out(), BuildTopic("test"));
- this_thread::sleep_for(chrono::milliseconds(250));
-
- listener.join();
- done = true;
- forwarder.join();
- g_logVerbosity = oldLogVerbosity;
-
- BOOST_REQUIRE_EQUAL(result, 1);
-}
-
-BOOST_AUTO_TEST_CASE(asyncforwarding)
-{
- cnote << "Testing Whisper async forwarding...";
- auto oldLogVerbosity = g_logVerbosity;
- g_logVerbosity = 2;
-
- unsigned result = 0;
- bool done = false;
-
- // Host must be configured not to share peers.
- Host host1("Forwarder", NetworkPreferences(30305, "", false, true));
- host1.setIdealPeerCount(1);
- auto whost1 = host1.registerCapability(new WhisperHost());
- host1.start();
- while (!host1.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
-
- bool startedForwarder = false;
- std::thread forwarder([&]()
- {
- setThreadName("forwarder");
-
- this_thread::sleep_for(chrono::milliseconds(500));
-// ph.addNode("127.0.0.1", 30303, 30303);
-
- startedForwarder = true;
-
- /// Only interested in odd packets
- auto w = whost1->installWatch(BuildTopicMask("test"));
-
- while (!done)
- {
- for (auto i: whost1->checkWatch(w))
- {
- Message msg = whost1->envelope(i).open(whost1->fullTopic(w));
- cnote << "New message from:" << msg.from().abridged() << RLP(msg.payload()).toInt<unsigned>();
- }
- this_thread::sleep_for(chrono::milliseconds(50));
- }
- });
-
- while (!startedForwarder)
- this_thread::sleep_for(chrono::milliseconds(2));
-
- {
- Host host2("Sender", NetworkPreferences(30300, "", false, true));
- host2.setIdealPeerCount(1);
- shared_ptr<WhisperHost> whost2 = host2.registerCapability(new WhisperHost());
- host2.start();
- while (!host2.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
- host2.addNode(host1.id(), "127.0.0.1", 30305, 30305);
-
- while (!host2.peerCount())
- this_thread::sleep_for(chrono::milliseconds(5));
-
- KeyPair us = KeyPair::create();
- whost2->post(us.sec(), RLPStream().append(1).out(), BuildTopic("test"));
- this_thread::sleep_for(chrono::milliseconds(250));
- }
-
- {
- Host ph("Listener", NetworkPreferences(30300, "", false, true));
- ph.setIdealPeerCount(1);
- shared_ptr<WhisperHost> wh = ph.registerCapability(new WhisperHost());
- ph.start();
- while (!ph.isStarted())
- this_thread::sleep_for(chrono::milliseconds(2));
- ph.addNode(host1.id(), "127.0.0.1", 30305, 30305);
-
- /// Only interested in odd packets
- auto w = wh->installWatch(BuildTopicMask("test"));
-
- for (int i = 0; i < 200 && !result; ++i)
- {
- for (auto i: wh->checkWatch(w))
- {
- Message msg = wh->envelope(i).open(wh->fullTopic(w));
- unsigned last = RLP(msg.payload()).toInt<unsigned>();
- cnote << "New message from:" << msg.from().abridged() << RLP(msg.payload()).toInt<unsigned>();
- result = last;
- }
- this_thread::sleep_for(chrono::milliseconds(50));
- }
- }
-
- done = true;
- forwarder.join();
- g_logVerbosity = oldLogVerbosity;
-
- BOOST_REQUIRE_EQUAL(result, 1);
-}
-#endif
-
-BOOST_AUTO_TEST_SUITE_END()