306 lines
7.8 KiB
C++
Raw Normal View History

/*
* libretroshare/src/tests/serialiser: rsconfigitemstest.cc
*
* RetroShare Serialiser tests.
*
* Copyright 2011 by Christopher Evi-Parker
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License Version 2 as published by the Free Software Foundation.
*
* This library 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
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
* USA.
*
* Please report all bugs and problems to "retroshare@lunamutt.com".
*
*/
#include "support.h"
#include "serialiser/rsconfigitems.h"
RsSerialType* init_item(RsPeerNetItem& rpn)
{
randString(SHORT_STR, rpn.dyndns);
rpn.nodePeerId.random();
rpn.pgpId.random();
randString(SHORT_STR, rpn.location);
rpn.lastContact = rand()%42424;
rpn.netMode = rand()%313190;
rpn.visState = rand()%63635;
inet_aton("10.0.0.111", &(rpn.currentlocaladdr.sin_addr));
rpn.currentlocaladdr.sin_port = htons(1111);
inet_aton("123.1.2.123", &(rpn.currentremoteaddr.sin_addr));
rpn.currentremoteaddr.sin_port = htons(1234);
RsTlvIpAddressInfo ipa1, ipa2;
ipa1.addr = rpn.currentlocaladdr;
ipa1.seenTime = rand()%40149013;
ipa1.source = rand()%13423;
ipa2.addr = rpn.currentremoteaddr;
ipa2.seenTime = rand()%40139013;
ipa2.source = rand()%1343443;
rpn.extAddrList.mList.push_back(ipa1);
rpn.extAddrList.mList.push_back(ipa2);
rpn.localAddrList.mList.push_back(ipa1);
rpn.localAddrList.mList.push_back(ipa2);
return new RsPeerConfigSerialiser();
}
RsSerialType* init_item(RsPeerGroupItem& rpgi){
rpgi.flag = rand()%134344;
randString(SHORT_STR, rpgi.id);
randString(SHORT_STR, rpgi.name);
std::string p1, p2, p3;
randString(SHORT_STR, p1);
randString(SHORT_STR, p2);
randString(SHORT_STR, p3);
rpgi.peerIds.push_back(p1);
rpgi.peerIds.push_back(p2);
rpgi.peerIds.push_back(p3);
return new RsPeerConfigSerialiser();
}
RsSerialType* init_item(CompressedChunkMap& map)
{
map._map.clear() ;
for(uint32_t i=0;i<15;++i)
map._map.push_back(rand()) ;
return new RsTurtleSerialiser();
}
RsSerialType* init_item(RsPeerStunItem& rpsi)
{
std::string p1, p2, p3;
randString(SHORT_STR, p1);
randString(SHORT_STR, p2);
randString(SHORT_STR, p3);
rpsi.stunList.ids.push_back(p1);
rpsi.stunList.ids.push_back(p2);
rpsi.stunList.ids.push_back(p3);
rpsi.stunList.mType = TLV_TYPE_PEERSET;
return new RsPeerConfigSerialiser();
}
RsSerialType* init_item(RsCacheConfig& rcc)
{
rcc.cachesubid = rand()%2342;
rcc.cachetypeid = rand()%323;
rcc.recvd = rand()%2252243;
rcc.size = rand()%02203;
randString(SHORT_STR, rcc.hash);
randString(SHORT_STR, rcc.name);
randString(SHORT_STR, rcc.path);
randString(SHORT_STR, rcc.pid);
return new RsCacheConfigSerialiser();
}
RsSerialType* init_item(RsFileTransfer& rft)
{
std::string p1, p2, p3;
randString(SHORT_STR, p1);
randString(SHORT_STR, p2);
randString(SHORT_STR, p3);
rft.allPeerIds.ids.push_back(p1);
rft.allPeerIds.ids.push_back(p2);
rft.allPeerIds.ids.push_back(p3);
rft.allPeerIds.mType = TLV_TYPE_PEERSET;
//
// rft.compressed_chunk_map._map.clear();
// const int mapSize = 15;
// rft.compressed_chunk_map._map.resize(mapSize);
// for(int i=0; i<mapSize; i++)
// rft.compressed_chunk_map._map[i] = rand();
init_item(rft.compressed_chunk_map);
randString(SHORT_STR, rft.cPeerId);
rft.chunk_strategy = rand()%4242;
rft.crate = rand()%4242;
rft.flags = rand()%42422;
rft.in = rand()%2323;
rft.lrate = rand()%25234;
rft.ltransfer = rand()%42232;
rft.state = rand()%42122;
rft.transferred = rand()%42242;
rft.trate = rand()%1212;
init_item(rft.file);
return new RsFileConfigSerialiser();
}
bool operator==(const RsPeerNetItem& left, const RsPeerNetItem& right)
{
if(left.dyndns != right.dyndns) return false;
if(left.pgpId != right.pgpId) return false;
if(left.location != right.location) return false;
if(left.nodePeerId != right.nodePeerId) return false;
if(left.lastContact != right.lastContact) return false;
if(left.netMode != right.netMode) return false;
if(left.visState != right.visState) return false;
if(left.currentlocaladdr != right.currentlocaladdr) return false;
if(left.currentremoteaddr != right.currentremoteaddr) return false;
if(!(left.extAddrList.mList == right.extAddrList.mList)) return false;
if(!(left.localAddrList.mList == right.localAddrList.mList)) return false;
return true;
}
bool operator==(const std::list<RsTlvIpAddressInfo>& left,
const std::list<RsTlvIpAddressInfo>& right)
{
std::list<RsTlvIpAddressInfo>::const_iterator cit1 = left.begin(),
cit2 = right.begin();
for(; cit1 != left.end() ; cit1++, cit2++){
if(*cit1 != *cit2)
return false;
}
return true;
}
bool operator!=(const sockaddr_in& left, const sockaddr_in& right)
{
if(left.sin_addr.s_addr != right.sin_addr.s_addr) return true;
if(left.sin_port != right.sin_port) return true;
return false;
}
bool operator!=(const RsTlvIpAddressInfo& left, const RsTlvIpAddressInfo& right)
{
if(left.addr != right.addr) return true;
if(left.seenTime != right.seenTime) return true;
if(left.source != right.source) return true;
return false;
}
bool operator==(const RsPeerGroupItem& left, const RsPeerGroupItem& right)
{
if(left.flag != right.flag) return false;
if(left.id != right.id) return false;
if(left.name != right.name) return false;
if(left.peerIds != right.peerIds) return false;
return true;
}
bool operator!=(const std::list<std::string>& left,
const std::list<std::string>& right)
{
std::list<std::string>::const_iterator cit1 = left.begin(),
cit2 = right.begin();
for(; cit1 != left.end(); cit1++, cit2++){
if(*cit1 != *cit2)
return true;
}
return false;
}
bool operator==(const RsPeerStunItem& left, const RsPeerStunItem& right)
{
if(!(left.stunList == right.stunList)) return false;
return true;
}
//bool operator==(const RsTlvPeerIdSet& left, const RsTlvPeerIdSet& right)
//{
// if(left.mType != right.mType) return false;
//
// std::list<std::string>::iterator cit1 = left.ids.begin(),
// cit2 = right.ids.begin();
//
// for(; cit1 != left.ids.end(); cit1++, cit2++){
//
// if(*cit1 != *cit2)
// return false;
// }
//
// return true;
//}
bool operator==(const RsCacheConfig& left, const RsCacheConfig& right)
{
if(left.cachesubid != right.cachesubid) return false;
if(left.cachetypeid != right.cachetypeid) return false;
if(left.hash != right.hash) return false;
if(left.path != right.path) return false;
if(left.pid != right.pid) return false;
if(left.recvd != right.recvd) return false;
if(left.size != right.size) return false;
return true;
}
bool operator==(const RsFileTransfer& left, const RsFileTransfer& right)
{
if(!(left.allPeerIds == right.allPeerIds)) return false;
if(left.cPeerId != right.cPeerId) return false;
if(left.chunk_strategy != right.chunk_strategy) return false;
if(left.compressed_chunk_map._map != right.compressed_chunk_map._map) return false;
if(left.crate != right.crate) return false;
if(!(left.file == right.file)) return false;
if(left.flags != right.flags) return false;
if(left.in != right.in) return false;
if(left.lrate != right.lrate) return false;
if(left.ltransfer != right.ltransfer) return false;
if(left.state != right.state) return false;
if(left.transferred != right.transferred) return false;
if(left.trate != right.trate) return false;
return true;
}
TEST(libretroshare_serialiser, RsConfigItem)
{
test_RsItem<RsPeerNetItem>();
test_RsItem<RsPeerGroupItem>();
test_RsItem<RsPeerStunItem>();
test_RsItem<RsCacheConfig>();
test_RsItem<RsFileTransfer>();
}