2018-11-04 21:17:22 +01:00
/*******************************************************************************
* unittests / libretroshare / serialiser / rsbaseitem_test . cc *
* *
2018-11-11 20:42:48 +01:00
* Copyright 2007 - 2008 by Robert Fernie < retroshare . project @ gmail . com > *
2018-11-04 21:17:22 +01: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 07:27:18 +00:00
# include <gtest/gtest.h>
# include <iostream>
# include <sstream>
# include "serialiser/rstlvfileitem.h"
# include "rstlvutil.h"
TEST ( libretroshare_serialiser , RsTlvFileItem )
{
RsTlvFileItem i1 ;
RsTlvFileItem i2 ;
/* initialise */
i1 . filesize = 101010 ;
2016-07-15 15:03:41 +02:00
i1 . hash = RsFileHash ( " 123456789ABCDEF67890123456789ABCDEF67890 " ) ; //SHA1_SIZE*2 = 40
2014-04-05 07:27:18 +00:00
i1 . name = " TestFile.txt " ;
i1 . pop = 12 ;
i1 . age = 456 ;
EXPECT_TRUE ( test_SerialiseTlvItem ( std : : cerr , & i1 , & i2 ) ) ;
/* check the data is the same */
EXPECT_TRUE ( i1 . filesize = = i2 . filesize ) ;
EXPECT_TRUE ( i1 . hash = = i2 . hash ) ;
EXPECT_TRUE ( i1 . name = = i2 . name ) ;
EXPECT_TRUE ( i1 . path = = i2 . path ) ;
EXPECT_TRUE ( i1 . pop = = i2 . pop ) ;
EXPECT_TRUE ( i1 . age = = i2 . age ) ;
/* do it again without optional data */
i1 . filesize = 123 ;
i1 . name = " " ;
i1 . pop = 0 ;
i1 . age = 0 ;
EXPECT_TRUE ( test_SerialiseTlvItem ( std : : cerr , & i1 , & i2 ) ) ;
/* check the data is the same */
EXPECT_TRUE ( i1 . filesize = = i2 . filesize ) ;
EXPECT_TRUE ( i1 . hash = = i2 . hash ) ;
EXPECT_TRUE ( i1 . name = = i2 . name ) ;
EXPECT_TRUE ( i1 . path = = i2 . path ) ;
EXPECT_TRUE ( i1 . pop = = i2 . pop ) ;
EXPECT_TRUE ( i1 . age = = i2 . age ) ;
/* one more time - long file name, some optional data */
i1 . filesize = 123 ;
i1 . name = " A Very Long File name that should fit in easily ??? with som $&%&^%* strange char (**$^%#&^$#*^%(&^ in there too!!!! ~~~!!$#(^$)$)(&%^)& \" oiyu thend " ;
i1 . pop = 666 ;
i1 . age = 0 ;
EXPECT_TRUE ( test_SerialiseTlvItem ( std : : cerr , & i1 , & i2 ) ) ;
/* check the data is the same */
EXPECT_TRUE ( i1 . filesize = = i2 . filesize ) ;
EXPECT_TRUE ( i1 . hash = = i2 . hash ) ;
EXPECT_TRUE ( i1 . name = = i2 . name ) ;
EXPECT_TRUE ( i1 . path = = i2 . path ) ;
EXPECT_TRUE ( i1 . pop = = i2 . pop ) ;
EXPECT_TRUE ( i1 . age = = i2 . age ) ;
}
TEST ( libretroshare_serialiser , RsTlvFileSet )
{
RsTlvFileSet s1 ;
RsTlvFileSet s2 ;
int i = 0 ;
for ( i = 0 ; i < 15 ; i + + )
{
RsTlvFileItem fi ;
fi . filesize = 16 + i * i ;
2016-07-15 15:03:41 +02:00
fi . hash = RsFileHash ( " 123456789ABCDEF67890123456789ABCDEF67890 " ) ; //SHA1_SIZE*2 = 40
2014-04-05 07:27:18 +00:00
std : : ostringstream out ;
out < < " File " < < i < < " _inSet.txt " ;
fi . name = out . str ( ) ;
if ( i % 2 = = 0 )
{
fi . age = 10 * i ;
}
else
{
fi . age = 0 ;
}
fi . pop = 0 ;
s1 . items . push_back ( fi ) ;
}
EXPECT_TRUE ( test_SerialiseTlvItem ( std : : cerr , & s1 , & s2 ) ) ;
}
TEST ( libretroshare_serialiser , RsTlvFileData )
{
RsTlvFileData d1 ;
RsTlvFileData d2 ;
/* initialise */
d1 . file . filesize = 101010 ;
2016-07-15 15:03:41 +02:00
d1 . file . hash = RsFileHash ( " 123456789ABCDEF67890123456789ABCDEF67890 " ) ; //SHA1_SIZE*2 = 40
2014-04-05 07:27:18 +00:00
d1 . file . name = " " ;
d1 . file . age = 0 ;
d1 . file . pop = 0 ;
2014-04-05 12:27:40 +00:00
unsigned char data [ 15 ] ;
RSRandom : : random_bytes ( data , 15 ) ;
2014-04-05 07:27:18 +00:00
d1 . binData . setBinData ( data , 15 ) ;
d1 . file_offset = 222 ;
EXPECT_TRUE ( test_SerialiseTlvItem ( std : : cerr , & d1 , & d2 ) ) ;
/* check the data is the same */
EXPECT_TRUE ( d1 . file . filesize = = d2 . file . filesize ) ;
EXPECT_TRUE ( d1 . file . hash = = d2 . file . hash ) ;
EXPECT_TRUE ( d1 . file . name = = d2 . file . name ) ;
EXPECT_TRUE ( d1 . file . path = = d2 . file . path ) ;
EXPECT_TRUE ( d1 . file . pop = = d2 . file . pop ) ;
EXPECT_TRUE ( d1 . file . age = = d2 . file . age ) ;
EXPECT_TRUE ( d1 . file_offset = = d2 . file_offset ) ;
EXPECT_TRUE ( d1 . binData . bin_len = = d2 . binData . bin_len ) ;
}