| /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ |
| /** |
| * Copyright (c) 2013-2016, Regents of the University of California. |
| * |
| * This file is part of ChronoShare, a decentralized file sharing application over NDN. |
| * |
| * ChronoShare 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. |
| * |
| * ChronoShare 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 copies of the GNU General Public License along with |
| * ChronoShare, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>. |
| * |
| * See AUTHORS.md for complete list of ChronoShare authors and contributors. |
| */ |
| #include "logging.hpp" |
| #include "sync-core.hpp" |
| |
| #include <boost/filesystem.hpp> |
| #include <boost/make_shared.hpp> |
| #include <boost/test/unit_test.hpp> |
| |
| using namespace std; |
| using namespace Ndnx; |
| using namespace boost; |
| using namespace boost::filesystem; |
| |
| INIT_LOGGER("Test.SyncCore"); |
| |
| BOOST_AUTO_TEST_SUITE(SyncCoreTests) |
| |
| void |
| callback(const SyncStateMsgPtr& msg) |
| { |
| BOOST_CHECK(msg->state_size() > 0); |
| int size = msg->state_size(); |
| int index = 0; |
| while (index < size) { |
| SyncState state = msg->state(index); |
| BOOST_CHECK(state.has_old_seq()); |
| BOOST_CHECK(state.old_seq() >= 0); |
| if (state.seq() != 0) { |
| BOOST_CHECK(state.old_seq() != state.seq()); |
| } |
| index++; |
| } |
| } |
| |
| void |
| checkRoots(const HashPtr& root1, const HashPtr& root2) |
| { |
| BOOST_CHECK_EQUAL(*root1, *root2); |
| } |
| |
| BOOST_AUTO_TEST_CASE(SyncCoreTest) |
| { |
| INIT_LOGGERS(); |
| |
| string dir = "./SyncCoreTest"; |
| // clean the test dir |
| path d(dir); |
| if (exists(d)) { |
| remove_all(d); |
| } |
| |
| string dir1 = "./SyncCoreTest/1"; |
| string dir2 = "./SyncCoreTest/2"; |
| Name user1("/joker"); |
| Name loc1("/gotham1"); |
| Name user2("/darkknight"); |
| Name loc2("/gotham2"); |
| Name syncPrefix("/broadcast/darkknight"); |
| NdnxWrapperPtr c1(new NdnxWrapper()); |
| NdnxWrapperPtr c2(new NdnxWrapper()); |
| SyncLogPtr log1(new SyncLog(dir1, user1.toString())); |
| SyncLogPtr log2(new SyncLog(dir2, user2.toString())); |
| |
| SyncCore* core1 = new SyncCore(log1, user1, loc1, syncPrefix, bind(callback, _1), c1); |
| usleep(10000); |
| SyncCore* core2 = new SyncCore(log2, user2, loc2, syncPrefix, bind(callback, _1), c2); |
| |
| sleep(1); |
| checkRoots(core1->root(), core2->root()); |
| |
| // _LOG_TRACE ("\n\n\n\n\n\n----------\n"); |
| |
| core1->updateLocalState(1); |
| usleep(100000); |
| checkRoots(core1->root(), core2->root()); |
| BOOST_CHECK_EQUAL(core2->seq(user1), 1); |
| BOOST_CHECK_EQUAL(log2->LookupLocator(user1), loc1); |
| |
| core1->updateLocalState(5); |
| usleep(100000); |
| checkRoots(core1->root(), core2->root()); |
| BOOST_CHECK_EQUAL(core2->seq(user1), 5); |
| BOOST_CHECK_EQUAL(log2->LookupLocator(user1), loc1); |
| |
| core2->updateLocalState(10); |
| usleep(100000); |
| checkRoots(core1->root(), core2->root()); |
| BOOST_CHECK_EQUAL(core1->seq(user2), 10); |
| BOOST_CHECK_EQUAL(log1->LookupLocator(user2), loc2); |
| |
| // simple simultaneous data generation |
| // _LOG_TRACE ("\n\n\n\n\n\n----------Simultaneous\n"); |
| _LOG_TRACE("Simultaneous"); |
| |
| core1->updateLocalState(11); |
| usleep(100); |
| core2->updateLocalState(15); |
| usleep(2000000); |
| checkRoots(core1->root(), core2->root()); |
| BOOST_CHECK_EQUAL(core1->seq(user2), 15); |
| BOOST_CHECK_EQUAL(core2->seq(user1), 11); |
| |
| BOOST_CHECK_EQUAL(log1->LookupLocator(user1), loc1); |
| BOOST_CHECK_EQUAL(log1->LookupLocator(user2), loc2); |
| BOOST_CHECK_EQUAL(log2->LookupLocator(user1), loc1); |
| BOOST_CHECK_EQUAL(log2->LookupLocator(user2), loc2); |
| |
| // clean the test dir |
| if (exists(d)) { |
| remove_all(d); |
| } |
| } |
| |
| BOOST_AUTO_TEST_SUITE_END() |