2016-05-06 03:38:57 +02:00
/*
Copyright ( c ) 2016 , Arvid Norberg
All rights reserved .
Redistribution and use in source and binary forms , with or without
modification , are permitted provided that the following conditions
are met :
* Redistributions of source code must retain the above copyright
notice , this list of conditions and the following disclaimer .
* Redistributions in binary form must reproduce the above copyright
notice , this list of conditions and the following disclaimer in
the documentation and / or other materials provided with the distribution .
* Neither the name of the author nor the names of its
contributors may be used to endorse or promote products derived
from this software without specific prior written permission .
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS " AS IS "
AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
LIABLE FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR
CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF
SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS
INTERRUPTION ) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN
CONTRACT , STRICT LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE )
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE .
*/
# include "test.hpp"
# include "libtorrent/torrent_info.hpp"
# include "libtorrent/create_torrent.hpp"
# include "libtorrent/bencode.hpp"
2018-05-10 13:47:40 +02:00
# include "libtorrent/announce_entry.hpp"
2016-05-06 03:38:57 +02:00
# include "libtorrent/aux_/escape_string.hpp" // for convert_path_to_posix
# include <boost/make_shared.hpp>
# include <cstring>
namespace lt = libtorrent ;
// make sure creating a torrent from an existing handle preserves the
// info-dictionary verbatim, so as to not alter the info-hash
TORRENT_TEST ( create_verbatim_torrent )
{
char const test_torrent [ ] = " d4:infod4:name6:foobar6:lengthi12345e12:piece lengthi65536e6:pieces20:ababababababababababee " ;
lt : : torrent_info info ( test_torrent , sizeof ( test_torrent ) - 1 ) ;
2017-02-12 23:55:34 +01:00
lt : : create_torrent t ( info , true ) ;
2016-05-06 03:38:57 +02:00
std : : vector < char > buffer ;
lt : : bencode ( std : : back_inserter ( buffer ) , t . generate ( ) ) ;
// now, make sure the info dictionary was unchanged
buffer . push_back ( ' \0 ' ) ;
char const * dest_info = std : : strstr ( & buffer [ 0 ] , " 4:info " ) ;
TEST_CHECK ( dest_info ! = NULL ) ;
// +1 and -2 here is to strip the outermost dictionary from the source
// torrent, since create_torrent may have added items next to the info dict
TEST_CHECK ( memcmp ( dest_info , test_torrent + 1 , sizeof ( test_torrent ) - 3 ) = = 0 ) ;
}
2018-05-10 13:47:40 +02:00
TORRENT_TEST ( create_torrent_round_trip )
{
char const test_torrent [ ] = " d8:announce26:udp://testurl.com/announce7:comment22:this is a test comment13:creation datei1337e4:infod6:lengthi12345e4:name6:foobar12:piece lengthi65536e6:pieces20:ababababababababababee " ;
lt : : torrent_info info1 ( test_torrent , sizeof ( test_torrent ) - 1 ) ;
TEST_EQUAL ( info1 . comment ( ) , " this is a test comment " ) ;
TEST_EQUAL ( info1 . trackers ( ) . size ( ) , 1 ) ;
TEST_EQUAL ( info1 . trackers ( ) . front ( ) . url , " udp://testurl.com/announce " ) ;
lt : : create_torrent t ( info1 , true ) ;
std : : vector < char > buffer ;
lt : : bencode ( std : : back_inserter ( buffer ) , t . generate ( ) ) ;
lt : : torrent_info info2 ( & buffer [ 0 ] , buffer . size ( ) ) ;
TEST_EQUAL ( info2 . comment ( ) , " this is a test comment " ) ;
TEST_EQUAL ( info2 . trackers ( ) . size ( ) , 1 ) ;
TEST_EQUAL ( info2 . trackers ( ) . front ( ) . url , " udp://testurl.com/announce " ) ;
TEST_CHECK ( info1 . info_hash ( ) = = info2 . info_hash ( ) ) ;
}