blob: 3c390462b9528454b37e4708deae479b725c7598 [file] [log] [blame]
Alexander Afanasyeva022f3d2012-03-11 18:14:48 -07001/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil -*- */
2/*
3 * Copyright (c) 2012 University of California, Los Angeles
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Author: Zhenkai Zhu <zhenkai@cs.ucla.edu>
19 * 卞超轶 Chaoyi Bian <bcy@pku.edu.cn>
20 * Alexander Afanasyev <alexander.afanasyev@ucla.edu>
21 */
22
23#include <boost/test/unit_test.hpp>
24#include <boost/test/output_test_stream.hpp>
25#include <map>
26using boost::test_tools::output_test_stream;
27
28#include <boost/make_shared.hpp>
29
30#include "../model/sync-interest-table.h"
Alexander Afanasyev387ac952012-03-11 23:49:27 -070031#include "../model/sync-logic.h"
Alexander Afanasyeva022f3d2012-03-11 18:14:48 -070032
33using namespace Sync;
34using namespace std;
35using namespace boost;
36
37BOOST_AUTO_TEST_CASE (InterestTableTest)
38{
39 SyncInterestTable *table = 0;
40 BOOST_CHECK_NO_THROW (table = new SyncInterestTable ());
41
42 BOOST_CHECK_NO_THROW (delete table);
43}
44
Alexander Afanasyev750d1872012-03-12 15:33:56 -070045void funcUpdate (const std::string &, const SeqNo &newSeq, const SeqNo &oldSeq)
Alexander Afanasyev387ac952012-03-11 23:49:27 -070046{
Alexander Afanasyev750d1872012-03-12 15:33:56 -070047 cout << "funcUpdate\n";
48}
49
50void funcRemove (const std::string &)
51{
52 cout << "funcRemove\n";
Alexander Afanasyev387ac952012-03-11 23:49:27 -070053}
54
55BOOST_AUTO_TEST_CASE (SyncLogicTest)
56{
57 SyncLogic *logic = 0;
Alexander Afanasyev750d1872012-03-12 15:33:56 -070058 BOOST_CHECK_NO_THROW (logic = new SyncLogic ("/prefix", funcUpdate, funcRemove, make_shared<CcnxWrapper> ()));
Alexander Afanasyev387ac952012-03-11 23:49:27 -070059 BOOST_CHECK_EQUAL (logic->getListChecksSize (), 0);
60
61 // 0s
62 BOOST_CHECK_NO_THROW (logic->respondSyncInterest ("/prefix/e5fa44f2b31c1fb553b6021e7360d07d5d91ff5e"));
63 sleep (1);
64
65 // 1s
66 BOOST_CHECK_NO_THROW (logic->respondSyncInterest ("/prefix/e5fa44f2b31c1fb553b6021e7360d07d5d91ff5e"));
67 sleep (1);
68
69 // 2s
70 // cout << "Wait queue size: " << logic->getListChecksSize () << endl;
71 BOOST_CHECK_EQUAL (logic->getListChecksSize (), 1);
72
73 // 2s
74 BOOST_CHECK_NO_THROW (logic->respondSyncInterest ("/prefix/e5fa44f2b31c1fb553b6021e7360d07d5d91ff5e"));
75 // cout << "Wait queue size: " << logic->getListChecksSize () << endl;
76 BOOST_CHECK_EQUAL (logic->getListChecksSize (), 2);
77
78 this_thread::sleep (posix_time::milliseconds (2500)); // make two interests expire
79
80 // 4.5s
81 // cout << "(after 3.3s) Wait queue size: " << logic->getListChecksSize () << endl;
82 BOOST_CHECK_EQUAL (logic->getListChecksSize (), 1);
83
84 BOOST_CHECK_NO_THROW (logic->respondSyncInterest ("/prefix/e5fa44f2b31c1fb553b6021e7360d07d5d91ff5e"));
85 sleep (5);
86 BOOST_CHECK_EQUAL (logic->getListChecksSize (), 0);
87
88 BOOST_CHECK_NO_THROW (delete logic);
89}
90