2018-11-04 15:17:22 -05:00
|
|
|
/*******************************************************************************
|
|
|
|
* unittests/libretroshare/serialiser/rsturtleitems_test.cc *
|
|
|
|
* *
|
2018-11-11 14:42:48 -05:00
|
|
|
* Copyright 2007-2008 by Cyril Soler <retroshare.project@gmail.com> *
|
2018-11-04 15:17:22 -05:00
|
|
|
* *
|
|
|
|
* This program is free software: you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU Affero General Public License as *
|
|
|
|
* published by the Free Software Foundation, either version 3 of the *
|
|
|
|
* License, or (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
* This program 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 Lesser General Public License for more details. *
|
|
|
|
* *
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License *
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
|
|
|
* *
|
|
|
|
******************************************************************************/
|
2014-04-05 03:27:18 -04:00
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
#include "turtle/rsturtleitem.h"
|
|
|
|
#include "ft/ftturtlefiletransferitem.h"
|
|
|
|
|
|
|
|
#include "support.h"
|
|
|
|
#include "rstlvutil.h"
|
|
|
|
|
|
|
|
|
|
|
|
RsSerialType* init_item(CompressedChunkMap& map)
|
|
|
|
{
|
|
|
|
map._map.clear() ;
|
|
|
|
for(uint32_t i=0;i<15;++i)
|
|
|
|
map._map.push_back(rand()) ;
|
|
|
|
}
|
|
|
|
bool operator==(const CompressedChunkMap& m1,const CompressedChunkMap& m2)
|
|
|
|
{
|
|
|
|
if(m1._map.size() != m2._map.size()) return false ;
|
|
|
|
|
|
|
|
for(uint32_t i=0;i<m1._map.size();++i)
|
|
|
|
if(m1._map[i] != m2._map[i])
|
|
|
|
return false ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleFileMapRequestItem& it1,const RsTurtleFileMapRequestItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.direction != it2.direction) return false ;
|
|
|
|
if(it1.tunnel_id != it2.tunnel_id) return false ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleFileMapRequestItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.direction = 1 ;
|
|
|
|
item.tunnel_id = 0x4ff823e2 ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleFileMapItem& it1,const RsTurtleFileMapItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.direction != it2.direction) return false ;
|
|
|
|
if(it1.tunnel_id != it2.tunnel_id) return false ;
|
|
|
|
if(!(it1.compressed_map == it2.compressed_map)) return false ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleFileMapItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.direction = 1 ;
|
|
|
|
item.tunnel_id = 0xf48fe232 ;
|
|
|
|
init_item(item.compressed_map) ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleFileDataItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
static const uint32_t S = 3456 ;
|
|
|
|
item.tunnel_id = 0x33eef982 ;
|
|
|
|
item.chunk_offset = 0x25ea228437894379ull ;
|
|
|
|
item.chunk_size = S ;
|
|
|
|
item.chunk_data = new unsigned char[S] ;
|
|
|
|
for(uint32_t i=0;i<S;++i)
|
|
|
|
((unsigned char *)item.chunk_data)[i] = rand()%256 ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleFileDataItem& i1,const RsTurtleFileDataItem& i2)
|
|
|
|
{
|
|
|
|
if(i1.tunnel_id != i2.tunnel_id) return false ;
|
|
|
|
if(i1.chunk_offset != i2.chunk_offset) return false ;
|
|
|
|
if(i1.chunk_size != i2.chunk_size) return false ;
|
|
|
|
for(uint32_t i=0;i<i1.chunk_size;++i)
|
|
|
|
if( ((unsigned char *)i1.chunk_data)[i] != ((unsigned char *)i2.chunk_data)[i])
|
|
|
|
return false ;
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleFileRequestItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.tunnel_id = rand() ;
|
|
|
|
item.chunk_offset = 0x25ea228437894379ull ;
|
|
|
|
item.chunk_size = rand() ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleFileRequestItem& it1,const RsTurtleFileRequestItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.tunnel_id != it2.tunnel_id) return false ;
|
|
|
|
if(it1.chunk_offset != it2.chunk_offset) return false ;
|
|
|
|
if(it1.chunk_size != it2.chunk_size) return false ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleTunnelOkItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.tunnel_id = rand() ;
|
|
|
|
item.request_id = rand() ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleTunnelOkItem& it1,const RsTurtleTunnelOkItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.tunnel_id != it2.tunnel_id) return false ;
|
|
|
|
if(it1.request_id != it2.request_id) return false ;
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleOpenTunnelItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.depth = rand() ;
|
|
|
|
item.request_id = rand() ;
|
|
|
|
item.partial_tunnel_id = rand() ;
|
2014-04-25 18:02:34 -04:00
|
|
|
item.file_hash = RsFileHash("c0edcfecc0844ef175d61dd589ab288d262b6bc8") ;
|
2014-04-05 03:27:18 -04:00
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleOpenTunnelItem& it1,const RsTurtleOpenTunnelItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.depth != it2.depth) return false ;
|
|
|
|
if(it1.request_id != it2.request_id) return false ;
|
|
|
|
if(it1.partial_tunnel_id != it2.partial_tunnel_id) return false ;
|
|
|
|
if(it1.file_hash != it2.file_hash) return false ;
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleRegExpSearchRequestItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.request_id = rand() ;
|
|
|
|
item.depth = rand() ;
|
|
|
|
item.expr._tokens.clear() ;
|
|
|
|
item.expr._ints.clear() ;
|
|
|
|
item.expr._strings.clear() ;
|
|
|
|
|
|
|
|
for(uint32_t i=0;i<10u;++i) item.expr._tokens.push_back(rand()%8) ;
|
|
|
|
for(uint32_t i=0;i<6u;++i) item.expr._ints.push_back(rand()) ;
|
|
|
|
for(uint32_t i=0;i<8u;++i) item.expr._strings.push_back("test string") ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleRegExpSearchRequestItem& it1,const RsTurtleRegExpSearchRequestItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.request_id != it2.request_id) return false ;
|
|
|
|
if(it1.depth != it2.depth) return false ;
|
|
|
|
if(it1.expr._tokens.size() != it2.expr._tokens.size()) return false ;
|
|
|
|
if(it1.expr._ints.size() != it2.expr._ints.size()) return false ;
|
|
|
|
if(it1.expr._strings.size() != it2.expr._strings.size()) return false ;
|
|
|
|
for(uint32_t i=0;i<it1.expr._tokens.size();++i) if(it1.expr._tokens[i] != it2.expr._tokens[i]) return false ;
|
|
|
|
for(uint32_t i=0;i<it1.expr._ints.size();++i) if(it1.expr._ints[i] != it2.expr._ints[i]) return false ;
|
|
|
|
for(uint32_t i=0;i<it1.expr._strings.size();++i) if(it1.expr._strings[i] != it2.expr._strings[i]) return false ;
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleStringSearchRequestItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.request_id = rand() ;
|
|
|
|
item.depth = rand() ;
|
|
|
|
item.match_string = std::string("432hkjfdsjkhjk43r3fw") ;
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleStringSearchRequestItem& it1,const RsTurtleStringSearchRequestItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.request_id != it2.request_id) return false ;
|
|
|
|
if(it1.depth != it2.depth) return false ;
|
|
|
|
if(it1.match_string != it2.match_string)
|
|
|
|
return false ;
|
|
|
|
return true ;
|
|
|
|
}
|
2016-03-20 07:10:56 -04:00
|
|
|
void init_item(TurtleFileInfo& info)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
2014-04-25 18:02:34 -04:00
|
|
|
info.hash = RsFileHash("3f753e8ac3b94ab9fddfad94480f747bf4418370");
|
2014-04-05 03:27:18 -04:00
|
|
|
info.name = "toto.png";
|
|
|
|
info.size = 0x3392085443897ull ;
|
|
|
|
}
|
|
|
|
bool operator==(const TurtleFileInfo& it1,const TurtleFileInfo& it2)
|
|
|
|
{
|
|
|
|
if(it1.hash != it2.hash) return false ;
|
|
|
|
if(it1.name != it2.name) return false ;
|
|
|
|
if(it1.size != it2.size) return false ;
|
|
|
|
return true ;
|
|
|
|
}
|
2017-07-25 15:21:24 -04:00
|
|
|
void init_item(RsTurtleSearchResultItem& item)
|
2014-04-05 03:27:18 -04:00
|
|
|
{
|
|
|
|
item.depth = rand() ;
|
|
|
|
item.request_id = rand() ;
|
|
|
|
item.result.clear() ;
|
|
|
|
static const uint32_t S = 10 ;
|
|
|
|
for(uint32_t i=0;i<S;++i)
|
|
|
|
{
|
|
|
|
TurtleFileInfo f;
|
|
|
|
init_item(f) ;
|
|
|
|
item.result.push_back(f) ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
bool operator==(const RsTurtleSearchResultItem& it1,const RsTurtleSearchResultItem& it2)
|
|
|
|
{
|
|
|
|
if(it1.request_id != it2.request_id) return false ;
|
|
|
|
if(it1.depth != it2.depth) return false ;
|
|
|
|
|
|
|
|
std::list<TurtleFileInfo>::const_iterator i1(it1.result.begin()) ;
|
|
|
|
std::list<TurtleFileInfo>::const_iterator i2(it2.result.begin()) ;
|
|
|
|
|
|
|
|
for(;i1!=it1.result.end() && i2!=it2.result.end();++i1,++i2)
|
|
|
|
if( !(*i1 == *i2))
|
|
|
|
return false ;
|
|
|
|
|
|
|
|
return true ;
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(libretroshare_serialiser, RsTurtleItem)
|
|
|
|
{
|
|
|
|
for(uint32_t i=0;i<20;++i)
|
|
|
|
{
|
|
|
|
//test_RsItem<RsTurtleFileMapRequestItem>();
|
|
|
|
//test_RsItem<RsTurtleFileMapItem >();
|
|
|
|
//test_RsItem<RsTurtleFileDataItem >();
|
|
|
|
//test_RsItem<RsTurtleFileRequestItem >();
|
2017-07-24 06:16:06 -04:00
|
|
|
|
|
|
|
test_RsItem<RsTurtleTunnelOkItem ,RsTurtleSerialiser>();
|
|
|
|
test_RsItem<RsTurtleOpenTunnelItem ,RsTurtleSerialiser>();
|
|
|
|
test_RsItem<RsTurtleSearchResultItem ,RsTurtleSerialiser>();
|
|
|
|
test_RsItem<RsTurtleStringSearchRequestItem ,RsTurtleSerialiser>();
|
|
|
|
test_RsItem<RsTurtleRegExpSearchRequestItem ,RsTurtleSerialiser>();
|
2014-04-05 03:27:18 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|