Use 64 bits random bytes as GID

This change replaces the current 64 bit sequential GID with 64 bits
random bytes GID in an attempt to support persistent GID. Internally,
the GID is stored as uint64_t. For human representation and RPC
interface, GID is represented as 16 bytes hex string. For console
readout, 16 bytes are too long, so it is abbreviated to first 6 bytes.
When querying GID in RPC calls, user can speicfy the prefix of GID as
long as the prefix is shared by more than 1 GID entries.
pull/38/head
Tatsuhiro Tsujikawa 2012-12-16 16:00:18 +09:00
parent 04586f50b1
commit b9da9d4ed3
32 changed files with 627 additions and 192 deletions

View File

@ -155,20 +155,20 @@ bool BtDependency::resolve()
}
} catch(RecoverableException& e) {
A2_LOG_ERROR_EX(EX_EXCEPTION_CAUGHT, e);
A2_LOG_INFO(fmt("BtDependency for GID#%" PRId64 " failed. Go without Bt.",
dependant_->getGID()));
A2_LOG_INFO(fmt("BtDependency for GID#%s failed. Go without Bt.",
GroupId::toHex(dependant_->getGID()).c_str()));
return true;
}
A2_LOG_INFO(fmt("Dependency resolved for GID#%" PRId64 "",
dependant_->getGID()));
A2_LOG_INFO(fmt("Dependency resolved for GID#%s",
GroupId::toHex(dependant_->getGID()).c_str()));
dependant_->setDownloadContext(context);
return true;
} else if(dependee_->getNumCommand() == 0) {
// dependee_'s download failed.
// cut reference here
dependee_.reset();
A2_LOG_INFO(fmt("BtDependency for GID#%" PRId64 " failed. Go without Bt.",
dependant_->getGID()));
A2_LOG_INFO(fmt("BtDependency for GID#%s failed. Go without Bt.",
GroupId::toHex(dependant_->getGID()).c_str()));
return true;
} else {
return false;

View File

@ -62,9 +62,9 @@ void BtStopDownloadCommand::preProcess()
enableExit();
}
if(checkPoint_.difference(global::wallclock()) >= timeout_) {
A2_LOG_NOTICE(fmt(_("GID#%" PRId64 " Stop downloading torrent due to"
A2_LOG_NOTICE(fmt(_("GID#%s Stop downloading torrent due to"
" --bt-stop-timeout option."),
requestGroup_->getGID()));
GroupId::toHex(requestGroup_->getGID()).c_str()));
requestGroup_->setForceHaltRequested(true);
getDownloadEngine()->setRefreshInterval(0);
enableExit();

View File

@ -146,7 +146,7 @@ void printProgressCompact(std::ostream& o, const DownloadEngine* e,
i = groups.begin(), eoi = groups.end(); i != eoi && cnt < MAX_ITEM;
++i, ++cnt) {
TransferStat stat = (*i)->calculateStat();
o << "[#" << (*i)->getGID() << " ";
o << "[#" << GroupId::toAbbrevHex((*i)->getGID()) << " ";
printSizeProgress(o, *i, stat, sizeFormatter);
o << "]";
}
@ -166,7 +166,7 @@ void printProgress
if(rg->getTotalLength() > 0 && stat.downloadSpeed > 0) {
eta = (rg->getTotalLength()-rg->getCompletedLength())/stat.downloadSpeed;
}
o << "[#" << rg->getGID() << " ";
o << "[#" << GroupId::toAbbrevHex(rg->getGID()) << " ";
printSizeProgress(o, rg, stat, sizeFormatter);
o << " CN:"
<< rg->getNumConnection();
@ -330,7 +330,7 @@ ConsoleStatCalc::calculateStat(const DownloadEngine* e)
e->getFileAllocationMan()->getPickedEntry();
if(entry) {
o << " [FileAlloc:#"
<< entry->getRequestGroup()->getGID() << " "
<< GroupId::toAbbrevHex(entry->getRequestGroup()->getGID()) << " "
<< sizeFormatter(entry->getCurrentLength()) << "B/"
<< sizeFormatter(entry->getTotalLength()) << "B(";
if(entry->getTotalLength() > 0) {
@ -350,7 +350,7 @@ ConsoleStatCalc::calculateStat(const DownloadEngine* e)
e->getCheckIntegrityMan()->getPickedEntry();
if(entry) {
o << " [Checksum:#"
<< entry->getRequestGroup()->getGID() << " "
<< GroupId::toAbbrevHex(entry->getRequestGroup()->getGID()) << " "
<< sizeFormatter(entry->getCurrentLength()) << "B/"
<< sizeFormatter(entry->getTotalLength()) << "B(";
if(entry->getTotalLength() > 0) {

View File

@ -54,7 +54,7 @@ class MetadataInfo;
struct DownloadResult
{
a2_gid_t gid;
SharedHandle<GroupId> gid;
std::vector<SharedHandle<FileEntry> > fileEntries;

View File

@ -423,7 +423,7 @@ bool FtpNegotiationCommand::onFileSizeDetermined(int64_t totalLength)
sequence_ = SEQ_DOWNLOAD_ALREADY_COMPLETED;
A2_LOG_NOTICE
(fmt(MSG_DOWNLOAD_ALREADY_COMPLETED,
getRequestGroup()->getGID(),
GroupId::toHex(getRequestGroup()->getGID()).c_str(),
getRequestGroup()->getFirstFilePath().c_str()));
}
poolConnection();

158
src/GroupId.cc Normal file
View File

@ -0,0 +1,158 @@
/* <!-- copyright */
/*
* aria2 - The high speed download utility
*
* Copyright (C) 2012 Tatsuhiro Tsujikawa
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of portions of this program with the
* OpenSSL library under certain conditions as described in each
* individual source file, and distribute linked combinations
* including the two.
* You must obey the GNU General Public License in all respects
* for all of the code used other than OpenSSL. If you modify
* file(s) with this exception, you may extend this exception to your
* version of the file(s), but you are not obligated to do so. If you
* do not wish to do so, delete this exception statement from your
* version. If you delete this exception statement from all source
* files in the program, then also delete it here.
*/
/* copyright --> */
#include "GroupId.h"
#include "util.h"
namespace aria2 {
std::set<a2_gid_t> GroupId::set_;
SharedHandle<GroupId> GroupId::create()
{
a2_gid_t n;
for(;;) {
util::generateRandomData(reinterpret_cast<unsigned char*>(&n), sizeof(n));
if(n != 0 && set_.count(n) == 0) {
break;
}
}
SharedHandle<GroupId> res(new GroupId(n));
return res;
}
SharedHandle<GroupId> GroupId::import(a2_gid_t n)
{
SharedHandle<GroupId> res;
if(n == 0 || set_.count(n) != 0) {
return res;
}
res.reset(new GroupId(n));
return res;
}
void GroupId::clear()
{
set_.clear();
}
int GroupId::expandUnique(a2_gid_t& n, const char* hex)
{
a2_gid_t p = 0;
size_t i;
for(i = 0; hex[i]; ++i) {
unsigned int c = util::hexCharToUInt(hex[i]);
if(c == 255) {
return ERR_INVALID;
}
p <<= 4;
p |= c;
}
if(i == 0 || i > sizeof(a2_gid_t)*2) {
return ERR_INVALID;
}
p <<= 64-i*4;
a2_gid_t mask = UINT64_MAX-((1LL << (64-i*4))-1);
std::set<a2_gid_t>::const_iterator itr = set_.lower_bound(p);
if(itr == set_.end()) {
return ERR_NOT_FOUND;
}
if(p == ((*itr)&mask)) {
n = *itr;
++itr;
if(itr == set_.end() || p != ((*itr)&mask)) {
return 0;
} else {
return ERR_NOT_UNIQUE;
}
} else {
return ERR_NOT_FOUND;
}
}
int GroupId::toNumericId(a2_gid_t& n, const char* hex)
{
a2_gid_t p = 0;
size_t i;
for(i = 0; hex[i]; ++i) {
unsigned int c = util::hexCharToUInt(hex[i]);
if(c == 255) {
return ERR_INVALID;
}
p <<= 4;
p |= c;
}
if(p == 0 || i != sizeof(a2_gid_t)*2) {
return ERR_INVALID;
}
n = p;
return 0;
}
std::string GroupId::toHex(a2_gid_t gid)
{
a2_gid_t n = hton64(gid);
return util::toHex(reinterpret_cast<unsigned char*>(&n), sizeof(n));
}
std::string GroupId::toAbbrevHex(a2_gid_t gid)
{
const size_t abbrevSize = 6;
std::string h = toHex(gid);
assert(h.size() >= abbrevSize);
return toHex(gid).erase(abbrevSize);
}
std::string GroupId::toHex() const
{
return toHex(gid_);
}
std::string GroupId::toAbbrevHex() const
{
return toAbbrevHex(gid_);
}
GroupId::GroupId(a2_gid_t gid)
: gid_(gid)
{
set_.insert(gid_);
}
GroupId::~GroupId()
{
set_.erase(gid_);
}
} // namespace aria2

81
src/GroupId.h Normal file
View File

@ -0,0 +1,81 @@
/* <!-- copyright */
/*
* aria2 - The high speed download utility
*
* Copyright (C) 2012 Tatsuhiro Tsujikawa
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* In addition, as a special exception, the copyright holders give
* permission to link the code of portions of this program with the
* OpenSSL library under certain conditions as described in each
* individual source file, and distribute linked combinations
* including the two.
* You must obey the GNU General Public License in all respects
* for all of the code used other than OpenSSL. If you modify
* file(s) with this exception, you may extend this exception to your
* version of the file(s), but you are not obligated to do so. If you
* do not wish to do so, delete this exception statement from your
* version. If you delete this exception statement from all source
* files in the program, then also delete it here.
*/
/* copyright --> */
#ifndef D_GROUP_ID_H
#define D_GROUP_ID_H
#include "common.h"
#include <set>
#include <string>
#include "SharedHandle.h"
namespace aria2 {
typedef uint64_t a2_gid_t;
class GroupId {
public:
static SharedHandle<GroupId> create();
static SharedHandle<GroupId> import(a2_gid_t n);
static void clear();
enum {
ERR_NOT_UNIQUE = -1,
ERR_NOT_FOUND = -2,
ERR_INVALID = -3
};
static int expandUnique(a2_gid_t& n, const char* hex);
static int toNumericId(a2_gid_t& n, const char* hex);
static std::string toHex(a2_gid_t n);
static std::string toAbbrevHex(a2_gid_t n);
~GroupId();
a2_gid_t getNumericId() const
{
return gid_;
}
std::string toHex() const;
std::string toAbbrevHex() const;
private:
static std::set<a2_gid_t> set_;
GroupId(a2_gid_t gid);
a2_gid_t gid_;
};
} // namespace aria2
#endif // D_GROUP_ID_H

View File

@ -189,7 +189,7 @@ bool HttpResponseCommand::executeInternal()
getDownloadContext()->setChecksumVerified(true);
A2_LOG_NOTICE
(fmt(MSG_DOWNLOAD_ALREADY_COMPLETED,
getRequestGroup()->getGID(),
GroupId::toHex(getRequestGroup()->getGID()).c_str(),
getRequestGroup()->getFirstFilePath().c_str()));
poolConnection();
getFileEntry()->poolRequest(getRequest());
@ -453,7 +453,7 @@ bool HttpResponseCommand::handleOtherEncoding
getDownloadContext()->setChecksumVerified(true);
A2_LOG_NOTICE
(fmt(MSG_DOWNLOAD_ALREADY_COMPLETED,
getRequestGroup()->getGID(),
GroupId::toHex(getRequestGroup()->getGID()).c_str(),
getRequestGroup()->getFirstFilePath().c_str()));
}
poolConnection();

View File

@ -242,7 +242,8 @@ SRCS = SocketCore.cc SocketCore.h\
AnonDiskWriterFactory.h\
XmlRpcRequestParserController.cc XmlRpcRequestParserController.h\
WrDiskCache.cc WrDiskCache.h\
WrDiskCacheEntry.cc WrDiskCacheEntry.h
WrDiskCacheEntry.cc WrDiskCacheEntry.h\
GroupId.cc GroupId.h
if MINGW_BUILD
SRCS += WinConsoleFile.cc WinConsoleFile.h

View File

@ -241,7 +241,7 @@ Metalink2RequestGroup::createRequestGroup
}
#endif // ENABLE_BITTORRENT
SharedHandle<Option> option = util::copy(optionTemplate);
SharedHandle<RequestGroup> rg(new RequestGroup(option));
SharedHandle<RequestGroup> rg(new RequestGroup(GroupId::create(), option));
SharedHandle<DownloadContext> dctx;
int numSplit = option->getAsInt(PREF_SPLIT);
int maxConn = option->getAsInt(PREF_MAX_CONNECTION_PER_SERVER);

View File

@ -120,10 +120,9 @@
namespace aria2 {
a2_gid_t RequestGroup::gidCounter_ = 0;
RequestGroup::RequestGroup(const SharedHandle<Option>& option)
: gid_(newGID()),
RequestGroup::RequestGroup(const SharedHandle<GroupId>& gid,
const SharedHandle<Option>& option)
: gid_(gid),
state_(STATE_WAITING),
option_(option),
numConcurrentCommand_(option->getAsInt(PREF_SPLIT)),
@ -244,7 +243,8 @@ SharedHandle<CheckIntegrityEntry> RequestGroup::createCheckIntegrityEntry()
{
downloadContext_->setChecksumVerified(true);
A2_LOG_NOTICE(fmt(MSG_DOWNLOAD_ALREADY_COMPLETED,
gid_, downloadContext_->getBasePath().c_str()));
gid_->toHex().c_str(),
downloadContext_->getBasePath().c_str()));
}
} else {
checkEntry.reset(new StreamCheckIntegrityEntry(this));
@ -346,9 +346,9 @@ void RequestGroup::createInitialCommand
btAnnouncePtr->shuffleAnnounce();
SharedHandle<BtAnnounce> btAnnounce(btAnnouncePtr);
assert(!btRegistry->get(gid_));
assert(!btRegistry->get(gid_->getNumericId()));
btRegistry->put
(gid_, SharedHandle<BtObject>
(gid_->getNumericId(), SharedHandle<BtObject>
(new BtObject
(downloadContext_,
pieceStorage_,
@ -962,7 +962,7 @@ void RequestGroup::decreaseNumCommand()
{
--numCommand_;
if(!numCommand_ && requestGroupMan_) {
A2_LOG_DEBUG(fmt("GID#%" PRId64 " - Request queue check", gid_));
A2_LOG_DEBUG(fmt("GID#%s - Request queue check", gid_->toHex().c_str()));
requestGroupMan_->requestQueueCheck();
}
}
@ -1007,7 +1007,7 @@ void RequestGroup::setPauseRequested(bool f)
void RequestGroup::releaseRuntimeResource(DownloadEngine* e)
{
#ifdef ENABLE_BITTORRENT
e->getBtRegistry()->remove(gid_);
e->getBtRegistry()->remove(gid_->getNumericId());
btRuntime_ = 0;
peerStorage_ = 0;
#endif // ENABLE_BITTORRENT
@ -1152,7 +1152,8 @@ bool RequestGroup::needsFileAllocation() const
SharedHandle<DownloadResult> RequestGroup::createDownloadResult() const
{
A2_LOG_DEBUG(fmt("GID#%" PRId64 " - Creating DownloadResult.", gid_));
A2_LOG_DEBUG(fmt("GID#%s - Creating DownloadResult.",
gid_->toHex().c_str()));
TransferStat st = calculateStat();
SharedHandle<DownloadResult> res(new DownloadResult());
res->gid = gid_;
@ -1298,12 +1299,4 @@ bool RequestGroup::p2pInvolved() const
#endif // !ENABLE_BITTORRENT
}
a2_gid_t RequestGroup::newGID()
{
if(gidCounter_ == INT64_MAX) {
gidCounter_ = 0;
}
return ++gidCounter_;
}
} // namespace aria2

View File

@ -47,6 +47,7 @@
#include "Request.h"
#include "error_code.h"
#include "MetadataInfo.h"
#include "GroupId.h"
namespace aria2 {
@ -73,8 +74,6 @@ class BtRuntime;
class PeerStorage;
#endif // ENABLE_BITTORRENT
typedef int64_t a2_gid_t;
class RequestGroup {
public:
enum HaltReason {
@ -89,9 +88,7 @@ public:
STATE_ACTIVE
};
private:
static a2_gid_t gidCounter_;
a2_gid_t gid_;
SharedHandle<GroupId> gid_;
int state_;
@ -201,7 +198,8 @@ private:
(const SharedHandle<BtProgressInfoFile>& progressInfoFile);
public:
RequestGroup(const SharedHandle<Option>& option);
RequestGroup(const SharedHandle<GroupId>& gid,
const SharedHandle<Option>& option);
~RequestGroup();
@ -264,7 +262,7 @@ public:
a2_gid_t getGID() const
{
return gid_;
return gid_->getNumericId();
}
TransferStat calculateStat() const;
@ -550,10 +548,6 @@ public:
{
state_ = state;
}
static void resetGIDCounter() { gidCounter_ = 0; }
static a2_gid_t newGID();
};
} // namespace aria2

View File

@ -261,7 +261,8 @@ size_t RequestGroupMan::changeReservedGroupPosition
std::deque<SharedHandle<RequestGroup> >::iterator i =
findByGID(reservedGroups_.begin(), reservedGroups_.end(), gid);
if(i == reservedGroups_.end()) {
throw DL_ABORT_EX(fmt("GID#%" PRId64 " not found in the waiting queue.", gid));
throw DL_ABORT_EX(fmt("GID#%s not found in the waiting queue.",
GroupId::toHex(gid).c_str()));
}
SharedHandle<RequestGroup> rg = *i;
const size_t maxPos = reservedGroups_.size()-1;
@ -401,7 +402,8 @@ public:
group->closeFile();
if(group->isPauseRequested()) {
A2_LOG_NOTICE
(fmt(_("Download GID#%" PRId64 " paused"), group->getGID()));
(fmt(_("Download GID#%s paused"),
GroupId::toHex(group->getGID()).c_str()));
group->saveControlFile();
} else if(group->downloadFinished() &&
!group->getDownloadContext()->isChecksumVerificationNeeded()) {
@ -429,7 +431,8 @@ public:
if(group->getOption()->getAsBool(PREF_BT_REMOVE_UNSELECTED_FILE) &&
!group->inMemoryDownload() &&
dctx->hasAttribute(CTX_ATTR_BT)) {
A2_LOG_INFO(fmt(MSG_REMOVING_UNSELECTED_FILE, group->getGID()));
A2_LOG_INFO(fmt(MSG_REMOVING_UNSELECTED_FILE,
GroupId::toHex(group->getGID()).c_str()));
const std::vector<SharedHandle<FileEntry> >& files =
dctx->getFileEntries();
for(std::vector<SharedHandle<FileEntry> >::const_iterator i =
@ -447,8 +450,8 @@ public:
#endif // ENABLE_BITTORRENT
} else {
A2_LOG_NOTICE
(fmt(_("Download GID#%" PRId64 " not complete: %s"),
group->getGID(),
(fmt(_("Download GID#%s not complete: %s"),
GroupId::toHex(group->getGID()).c_str(),
group->getDownloadContext()->getBasePath().c_str()));
group->saveControlFile();
}
@ -760,24 +763,20 @@ const char* getStatusStr(DownloadStatus status, bool useColor)
void RequestGroupMan::showDownloadResults(OutputFile& o, bool full) const
{
#ifdef __MINGW32__
int pathRowSize = 58;
#else // !__MINGW32__
int pathRowSize = 59;
#endif // !__MINGW32__
int pathRowSize = 55;
// Download Results:
// idx|stat|path/length
// ===+====+=======================================================================
o.printf("\n%s"
"\ngid|stat|avg speed |",
"\ngid |stat|avg speed |",
_("Download Results:"));
if(full) {
o.write(" %|path/URI"
"\n===+====+===========+===+");
"\n======+====+===========+===+");
pathRowSize -= 4;
} else {
o.write("path/URI"
"\n===+====+===========+");
"\n======+====+===========+");
}
std::string line(pathRowSize, '=');
o.printf("%s\n", line.c_str());
@ -837,7 +836,7 @@ void formatDownloadResultCommon
const char* status,
const SharedHandle<DownloadResult>& downloadResult)
{
o << std::setw(3) << downloadResult->gid << "|"
o << std::setw(3) << downloadResult->gid->toAbbrevHex() << "|"
<< std::setw(4) << status << "|"
<< std::setw(11);
if(downloadResult->sessionTime > 0) {
@ -975,7 +974,7 @@ RequestGroupMan::findDownloadResult(a2_gid_t gid) const
{
for(std::deque<SharedHandle<DownloadResult> >::const_iterator i =
downloadResults_.begin(), eoi = downloadResults_.end(); i != eoi; ++i) {
if((*i)->gid == gid) {
if((*i)->gid->getNumericId() == gid) {
return *i;
}
}
@ -986,7 +985,7 @@ bool RequestGroupMan::removeDownloadResult(a2_gid_t gid)
{
for(std::deque<SharedHandle<DownloadResult> >::iterator i =
downloadResults_.begin(), eoi = downloadResults_.end(); i != eoi; ++i) {
if((*i)->gid == gid) {
if((*i)->gid->getNumericId() == gid) {
downloadResults_.erase(i);
return true;
}

View File

@ -148,7 +148,7 @@ const std::string KEY_NUM_ACTIVE = "numActive";
namespace {
SharedHandle<ValueBase> createGIDResponse(a2_gid_t gid)
{
return String::g(util::itos(gid));
return String::g(GroupId::toHex(gid));
}
} // namespace
@ -185,12 +185,19 @@ namespace {
a2_gid_t str2Gid(const String* str)
{
assert(str);
int64_t gid;
if(util::parseLLIntNoThrow(gid, str->s())) {
return gid;
} else {
throw DL_ABORT_EX(fmt("Bad GID %s", str->s().c_str()));
if(str->s().size() > sizeof(a2_gid_t)*2) {
throw DL_ABORT_EX(fmt("Invalid GID %s", str->s().c_str()));
}
a2_gid_t n;
switch(GroupId::expandUnique(n, str->s().c_str())) {
case GroupId::ERR_NOT_UNIQUE:
throw DL_ABORT_EX(fmt("GID %s is not unique", str->s().c_str()));
case GroupId::ERR_NOT_FOUND:
throw DL_ABORT_EX(fmt("GID %s is not found", str->s().c_str()));
case GroupId::ERR_INVALID:
throw DL_ABORT_EX(fmt("Invalid GID %s", str->s().c_str()));
}
return n;
}
} // namespace
@ -364,7 +371,7 @@ SharedHandle<ValueBase> AddMetalinkRpcMethod::process
}
for(std::vector<SharedHandle<RequestGroup> >::const_iterator i =
result.begin(), eoi = result.end(); i != eoi; ++i) {
gids->append(util::itos((*i)->getGID()));
gids->append(GroupId::toHex((*i)->getGID()));
}
}
return gids;
@ -391,12 +398,13 @@ SharedHandle<ValueBase> removeDownload
if(group->isDependencyResolved()) {
e->getRequestGroupMan()->removeReservedGroup(gid);
} else {
throw DL_ABORT_EX(fmt("GID#%" PRId64 " cannot be removed now", gid));
throw DL_ABORT_EX(fmt("GID#%s cannot be removed now",
GroupId::toHex(gid).c_str()));
}
}
} else {
throw DL_ABORT_EX(fmt("Active Download not found for GID#%" PRId64,
gid));
throw DL_ABORT_EX(fmt("Active Download not found for GID#%s",
GroupId::toHex(gid).c_str()));
}
return createGIDResponse(gid);
}
@ -455,7 +463,8 @@ SharedHandle<ValueBase> pauseDownload
return createGIDResponse(gid);
}
}
throw DL_ABORT_EX(fmt("GID#%" PRId64 " cannot be paused now", gid));
throw DL_ABORT_EX(fmt("GID#%s cannot be paused now",
GroupId::toHex(gid).c_str()));
}
} // namespace
@ -519,7 +528,8 @@ SharedHandle<ValueBase> UnpauseRpcMethod::process
if(!group ||
group->getState() != RequestGroup::STATE_WAITING ||
!group->isPauseRequested()) {
throw DL_ABORT_EX(fmt("GID#%" PRId64 " cannot be unpaused now", gid));
throw DL_ABORT_EX(fmt("GID#%s cannot be unpaused now",
GroupId::toHex(gid).c_str()));
} else {
group->setPauseRequested(false);
e->getRequestGroupMan()->requestQueueCheck();
@ -644,7 +654,7 @@ void gatherProgressCommon
{
const SharedHandle<PieceStorage>& ps = group->getPieceStorage();
if(requested_key(keys, KEY_GID)) {
entryDict->put(KEY_GID, util::itos(group->getGID()));
entryDict->put(KEY_GID, GroupId::toHex(group->getGID()).c_str());
}
if(requested_key(keys, KEY_TOTAL_LENGTH)) {
// This is "filtered" total length if --select-file is used.
@ -690,14 +700,14 @@ void gatherProgressCommon
// The element is GID.
for(std::vector<a2_gid_t>::const_iterator i = group->followedBy().begin(),
eoi = group->followedBy().end(); i != eoi; ++i) {
list->append(util::itos(*i));
list->append(GroupId::toHex(*i));
}
entryDict->put(KEY_FOLLOWED_BY, list);
}
}
if(requested_key(keys, KEY_BELONGS_TO)) {
if(group->belongsTo()) {
entryDict->put(KEY_BELONGS_TO, util::itos(group->belongsTo()));
entryDict->put(KEY_BELONGS_TO, GroupId::toHex(group->belongsTo()));
}
}
if(requested_key(keys, KEY_FILES)) {
@ -832,7 +842,7 @@ void gatherStoppedDownload
const std::vector<std::string>& keys)
{
if(requested_key(keys, KEY_GID)) {
entryDict->put(KEY_GID, util::itos(ds->gid));
entryDict->put(KEY_GID, ds->gid->toHex());
}
if(requested_key(keys, KEY_ERROR_CODE)) {
entryDict->put(KEY_ERROR_CODE, util::itos(static_cast<int>(ds->result)));
@ -852,14 +862,14 @@ void gatherStoppedDownload
// The element is GID.
for(std::vector<a2_gid_t>::const_iterator i = ds->followedBy.begin(),
eoi = ds->followedBy.end(); i != eoi; ++i) {
list->append(util::itos(*i));
list->append(GroupId::toHex(*i));
}
entryDict->put(KEY_FOLLOWED_BY, list);
}
}
if(requested_key(keys, KEY_BELONGS_TO)) {
if(ds->belongsTo) {
entryDict->put(KEY_BELONGS_TO, util::itos(ds->belongsTo));
entryDict->put(KEY_BELONGS_TO, GroupId::toHex(ds->belongsTo));
}
}
if(requested_key(keys, KEY_FILES)) {
@ -922,8 +932,8 @@ SharedHandle<ValueBase> GetFilesRpcMethod::process
SharedHandle<DownloadResult> dr =
e->getRequestGroupMan()->findDownloadResult(gid);
if(!dr) {
throw DL_ABORT_EX(fmt("No file data is available for GID#%" PRId64 "",
gid));
throw DL_ABORT_EX(fmt("No file data is available for GID#%s",
GroupId::toHex(gid).c_str()));
} else {
createFileEntry(files, dr->fileEntries.begin(), dr->fileEntries.end(),
dr->totalLength, dr->pieceLength, dr->bitfield);
@ -949,7 +959,8 @@ SharedHandle<ValueBase> GetUrisRpcMethod::process
a2_gid_t gid = str2Gid(gidParam);
SharedHandle<RequestGroup> group = e->getRequestGroupMan()->findGroup(gid);
if(!group) {
throw DL_ABORT_EX(fmt("No URI data is available for GID#%" PRId64, gid));
throw DL_ABORT_EX(fmt("No URI data is available for GID#%s",
GroupId::toHex(gid).c_str()));
}
SharedHandle<List> uriList = List::g();
// TODO Current implementation just returns first FileEntry's URIs.
@ -968,7 +979,8 @@ SharedHandle<ValueBase> GetPeersRpcMethod::process
a2_gid_t gid = str2Gid(gidParam);
SharedHandle<RequestGroup> group = e->getRequestGroupMan()->findGroup(gid);
if(!group) {
throw DL_ABORT_EX(fmt("No peer data is available for GID#%" PRId64, gid));
throw DL_ABORT_EX(fmt("No peer data is available for GID#%s",
GroupId::toHex(gid).c_str()));
}
SharedHandle<List> peers = List::g();
const SharedHandle<BtObject>& btObject =
@ -998,7 +1010,8 @@ SharedHandle<ValueBase> TellStatusRpcMethod::process
SharedHandle<DownloadResult> ds =
e->getRequestGroupMan()->findDownloadResult(gid);
if(!ds) {
throw DL_ABORT_EX(fmt("No such download for GID#%" PRId64 "", gid));
throw DL_ABORT_EX(fmt("No such download for GID#%s",
GroupId::toHex(gid).c_str()));
}
gatherStoppedDownload(entryDict, ds, keys);
} else {
@ -1090,7 +1103,8 @@ SharedHandle<ValueBase> RemoveDownloadResultRpcMethod::process
a2_gid_t gid = str2Gid(gidParam);
if(!e->getRequestGroupMan()->removeDownloadResult(gid)) {
throw DL_ABORT_EX(fmt("Could not remove download result of GID#%" PRId64 "", gid));
throw DL_ABORT_EX(fmt("Could not remove download result of GID#%s",
GroupId::toHex(gid).c_str()));
}
return VLB_OK;
}
@ -1191,7 +1205,8 @@ SharedHandle<ValueBase> ChangeOptionRpcMethod::process
}
changeOption(group, option, e);
} else {
throw DL_ABORT_EX(fmt("Cannot change option for GID#%" PRId64, gid));
throw DL_ABORT_EX(fmt("Cannot change option for GID#%s",
GroupId::toHex(gid).c_str()));
}
return VLB_OK;
}
@ -1277,7 +1292,8 @@ SharedHandle<ValueBase> GetOptionRpcMethod::process
a2_gid_t gid = str2Gid(gidParam);
SharedHandle<RequestGroup> group = e->getRequestGroupMan()->findGroup(gid);
if(!group) {
throw DL_ABORT_EX(fmt("Cannot get option for GID#%" PRId64 "", gid));
throw DL_ABORT_EX(fmt("Cannot get option for GID#%s",
GroupId::toHex(gid).c_str()));
}
SharedHandle<Dict> result = Dict::g();
SharedHandle<Option> option = group->getOption();
@ -1344,7 +1360,8 @@ SharedHandle<ValueBase> GetServersRpcMethod::process
a2_gid_t gid = str2Gid(gidParam);
SharedHandle<RequestGroup> group = e->getRequestGroupMan()->findGroup(gid);
if(!group || group->getState() != RequestGroup::STATE_ACTIVE) {
throw DL_ABORT_EX(fmt("No active download for GID#%" PRId64, gid));
throw DL_ABORT_EX(fmt("No active download for GID#%s",
GroupId::toHex(gid).c_str()));
}
const SharedHandle<DownloadContext>& dctx = group->getDownloadContext();
const std::vector<SharedHandle<FileEntry> >& files = dctx->getFileEntries();
@ -1390,7 +1407,8 @@ SharedHandle<ValueBase> ChangeUriRpcMethod::process
size_t index = indexParam->i()-1;
SharedHandle<RequestGroup> group = e->getRequestGroupMan()->findGroup(gid);
if(!group) {
throw DL_ABORT_EX(fmt("Cannot remove URIs from GID#%" PRId64 "", gid));
throw DL_ABORT_EX(fmt("Cannot remove URIs from GID#%s",
GroupId::toHex(gid).c_str()));
}
const SharedHandle<DownloadContext>& dctx = group->getDownloadContext();
const std::vector<SharedHandle<FileEntry> >& files = dctx->getFileEntries();

View File

@ -221,7 +221,7 @@ TrackerWatcherCommand::createRequestGroup(const std::string& uri)
std::vector<std::string> uris;
uris.push_back(uri);
SharedHandle<Option> option = util::copy(getOption());
SharedHandle<RequestGroup> rg(new RequestGroup(option));
SharedHandle<RequestGroup> rg(new RequestGroup(GroupId::create(), option));
if(backupTrackerIsAvailable(requestGroup_->getDownloadContext())) {
A2_LOG_DEBUG("This is multi-tracker announce.");
} else {
@ -255,7 +255,8 @@ TrackerWatcherCommand::createRequestGroup(const std::string& uri)
rg->clearPreDownloadHandler();
rg->clearPostDownloadHandler();
dctx->setAcceptMetalink(false);
A2_LOG_INFO(fmt("Creating tracker request group GID#%" PRId64 "", rg->getGID()));
A2_LOG_INFO(fmt("Creating tracker request group GID#%s",
GroupId::toHex(rg->getGID()).c_str()));
return rg;
}

View File

@ -66,7 +66,7 @@ void WebSocketSessionMan::addNotification
dict->put("jsonrpc", "2.0");
dict->put("method", method);
SharedHandle<Dict> eventSpec = Dict::g();
eventSpec->put("gid", util::itos(group->getGID()));
eventSpec->put("gid", GroupId::toHex((group->getGID())));
SharedHandle<List> params = List::g();
params->append(eventSpec);
dict->put("params", params);

View File

@ -112,7 +112,7 @@ SharedHandle<RequestGroup> createRequestGroup
bool useOutOption = false)
{
SharedHandle<Option> option = util::copy(optionTemplate);
SharedHandle<RequestGroup> rg(new RequestGroup(option));
SharedHandle<RequestGroup> rg(new RequestGroup(GroupId::create(), option));
SharedHandle<DownloadContext> dctx
(new DownloadContext
(option->getAsInt(PREF_PIECE_LENGTH),
@ -168,7 +168,7 @@ createBtRequestGroup(const std::string& metaInfoUri,
bool adjustAnnounceUri = true)
{
SharedHandle<Option> option = util::copy(optionTemplate);
SharedHandle<RequestGroup> rg(new RequestGroup(option));
SharedHandle<RequestGroup> rg(new RequestGroup(GroupId::create(), option));
SharedHandle<DownloadContext> dctx(new DownloadContext());
// may throw exception
bittorrent::loadFromMemory(torrent, dctx, option, auxUris,
@ -210,7 +210,7 @@ createBtMagnetRequestGroup
const SharedHandle<Option>& optionTemplate)
{
SharedHandle<Option> option = util::copy(optionTemplate);
SharedHandle<RequestGroup> rg(new RequestGroup(option));
SharedHandle<RequestGroup> rg(new RequestGroup(GroupId::create(), option));
SharedHandle<DownloadContext> dctx
(new DownloadContext(METADATA_PIECE_SIZE, 0,
A2STR::NIL));

View File

@ -54,7 +54,7 @@
#define MSG_GOT_NEW_PIECE "CUID#%" PRId64 " - we got new piece. index=%lu"
#define MSG_GOT_WRONG_PIECE "CUID#%" PRId64 " - we got wrong piece. index=%lu"
#define MSG_DOWNLOAD_NOT_COMPLETE "CUID#%" PRId64 " - Download not complete: %s"
#define MSG_DOWNLOAD_ALREADY_COMPLETED _("GID#%" PRId64 " - Download has already completed: %s")
#define MSG_DOWNLOAD_ALREADY_COMPLETED _("GID#%s - Download has already completed: %s")
#define MSG_RESOLVING_HOSTNAME "CUID#%" PRId64 " - Resolving hostname %s"
#define MSG_NAME_RESOLUTION_COMPLETE \
"CUID#%" PRId64 " - Name resolution complete: %s -> %s"
@ -197,7 +197,7 @@
#define MSG_DIR_TRAVERSAL_DETECTED _("Detected directory traversal directive in %s")
#define MSG_HASH_CHECK_NOT_DONE \
"File has already been downloaded but hash check has not been done yet."
#define MSG_REMOVING_UNSELECTED_FILE _("GID#%" PRId64 " - Removing unselected file.")
#define MSG_REMOVING_UNSELECTED_FILE _("GID#%s - Removing unselected file.")
#define MSG_FILE_REMOVED _("File %s removed.")
#define MSG_FILE_COULD_NOT_REMOVED _("File %s could not be removed.")

View File

@ -1691,7 +1691,7 @@ void executeHook
size_t numFiles,
const std::string& firstFilename)
{
const std::string gidStr = util::itos(gid);
const std::string gidStr = GroupId::toHex(gid);
const std::string numFilesStr = util::uitos(numFiles);
#ifndef __MINGW32__
A2_LOG_INFO(fmt("Executing user command: %s %s %s %s",

View File

@ -38,7 +38,8 @@ class BtDependencyTest:public CppUnit::TestFixture {
SharedHandle<RequestGroup> createDependant(const SharedHandle<Option>& option)
{
SharedHandle<RequestGroup> dependant(new RequestGroup(util::copy(option)));
SharedHandle<RequestGroup> dependant(new RequestGroup(GroupId::create(),
util::copy(option)));
SharedHandle<DownloadContext> dctx
(new DownloadContext(0, 0, "/tmp/outfile.path"));
std::vector<std::string> uris;
@ -56,7 +57,8 @@ class BtDependencyTest:public CppUnit::TestFixture {
const std::string& torrentFile,
int64_t length)
{
SharedHandle<RequestGroup> dependee(new RequestGroup(util::copy(option)));
SharedHandle<RequestGroup> dependee(new RequestGroup(GroupId::create(),
util::copy(option)));
SharedHandle<DownloadContext> dctx
(new DownloadContext(1024*1024, length, torrentFile));
dependee->setDownloadContext(dctx);

View File

@ -39,7 +39,7 @@ void BtPostDownloadHandlerTest::testCanHandle_extension()
{
SharedHandle<DownloadContext> dctx
(new DownloadContext(0, 0, A2_TEST_DIR"/test.torrent"));
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
BtPostDownloadHandler handler;
@ -54,7 +54,7 @@ void BtPostDownloadHandlerTest::testCanHandle_contentType()
{
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0, "test"));
dctx->getFirstFileEntry()->setContentType("application/x-bittorrent");
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
BtPostDownloadHandler handler;
@ -69,7 +69,7 @@ void BtPostDownloadHandlerTest::testGetNextRequestGroups()
{
SharedHandle<DownloadContext> dctx
(new DownloadContext(1024, 0, A2_TEST_DIR"/test.torrent"));
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
rg.initPieceStorage();
rg.getPieceStorage()->getDiskAdaptor()->enableReadOnly();

View File

@ -138,7 +138,7 @@ public:
option_.reset(new Option());
option_->put(PREF_DIR, ".");
rg_.reset(new RequestGroup(option_));
rg_.reset(new RequestGroup(GroupId::create(), option_));
dctx_.reset(new DownloadContext());
bittorrent::load(A2_TEST_DIR"/test.torrent", dctx_, option_);

View File

@ -64,7 +64,7 @@ public:
dctx_.reset(new DownloadContext());
SharedHandle<Option> option(new Option());
requestGroup_.reset(new RequestGroup(option));
requestGroup_.reset(new RequestGroup(GroupId::create(), option));
requestGroup_->setDownloadContext(dctx_);
factory_.reset(new DefaultExtensionMessageFactory());

View File

@ -51,7 +51,7 @@ CPPUNIT_TEST_SUITE_REGISTRATION( DownloadHandlerFactoryTest );
void DownloadHandlerFactoryTest::testGetMetalinkPreDownloadHandler_extension()
{
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0, "test.metalink"));
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
SharedHandle<PreDownloadHandler> handler = DownloadHandlerFactory::getMetalinkPreDownloadHandler();
@ -66,7 +66,7 @@ void DownloadHandlerFactoryTest::testGetMetalinkPreDownloadHandler_contentType()
{
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0, "test"));
dctx->getFirstFileEntry()->setContentType("application/metalink+xml");
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
SharedHandle<PreDownloadHandler> handler = DownloadHandlerFactory::getMetalinkPreDownloadHandler();
@ -85,7 +85,7 @@ void DownloadHandlerFactoryTest::testGetBtPreDownloadHandler_extension()
{
SharedHandle<DownloadContext> dctx
(new DownloadContext(0, 0, A2_TEST_DIR"/test.torrent"));
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
SharedHandle<PreDownloadHandler> handler = DownloadHandlerFactory::getBtPreDownloadHandler();
@ -100,7 +100,7 @@ void DownloadHandlerFactoryTest::testGetBtPreDownloadHandler_contentType()
{
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0, "test"));
dctx->getFirstFileEntry()->setContentType("application/x-bittorrent");
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
SharedHandle<PreDownloadHandler> handler = DownloadHandlerFactory::getBtPreDownloadHandler();

127
test/GroupIdTest.cc Normal file
View File

@ -0,0 +1,127 @@
#include "GroupId.h"
#include <cppunit/extensions/HelperMacros.h>
#include "TestUtil.h"
#include "array_fun.h"
namespace aria2 {
class GroupIdTest:public CppUnit::TestFixture {
CPPUNIT_TEST_SUITE(GroupIdTest);
CPPUNIT_TEST(testCreate);
CPPUNIT_TEST(testToNumericId);
CPPUNIT_TEST(testExpandUnique);
CPPUNIT_TEST(testToHex);
CPPUNIT_TEST(testToAbbrevHex);
CPPUNIT_TEST_SUITE_END();
public:
void setUp()
{
GroupId::clear();
}
void testCreate();
void testToNumericId();
void testExpandUnique();
void testToHex();
void testToAbbrevHex();
};
CPPUNIT_TEST_SUITE_REGISTRATION( GroupIdTest );
void GroupIdTest::testCreate()
{
SharedHandle<GroupId> gid = GroupId::create();
CPPUNIT_ASSERT(gid);
CPPUNIT_ASSERT(0 != gid->getNumericId());
CPPUNIT_ASSERT(!GroupId::import(gid->getNumericId()));
CPPUNIT_ASSERT(!GroupId::import(0));
}
void GroupIdTest::testToNumericId()
{
a2_gid_t gid;
std::string hex;
hex = std::string(16, '0');
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::toNumericId(gid, hex.c_str()));
hex = std::string(16, 'f');
CPPUNIT_ASSERT_EQUAL(0, GroupId::toNumericId(gid, hex.c_str()));
CPPUNIT_ASSERT_EQUAL((a2_gid_t)UINT64_MAX, gid);
CPPUNIT_ASSERT_EQUAL(0, GroupId::toNumericId(gid, "1234567890abcdef"));
CPPUNIT_ASSERT_EQUAL((a2_gid_t)1311768467294899695LL, gid);
hex = std::string(15, 'f');
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::toNumericId(gid, hex.c_str()));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::toNumericId(gid, ""));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::toNumericId(gid, "1234567890abcdeg"));
}
void GroupIdTest::testExpandUnique()
{
a2_gid_t gid;
SharedHandle<GroupId> ids[] = {
GroupId::import(0xff80000000010000LL),
GroupId::import(0xff80000000020001LL),
GroupId::import(0xfff8000000030000LL)
};
for(SharedHandle<GroupId>* i = vbegin(ids), *eoi = vend(ids); i != eoi;
++i) {
CPPUNIT_ASSERT(*i);
}
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_NOT_UNIQUE,
GroupId::expandUnique(gid, "ff8"));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::expandUnique(gid, "ffg"));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::expandUnique(gid,
std::string(17, 'a').c_str()));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_INVALID,
GroupId::expandUnique(gid, ""));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_NOT_UNIQUE,
GroupId::expandUnique(gid, "ff800000000"));
CPPUNIT_ASSERT_EQUAL(0, GroupId::expandUnique(gid, "ff8000000001"));
CPPUNIT_ASSERT_EQUAL(std::string("ff80000000010000"), GroupId::toHex(gid));
CPPUNIT_ASSERT_EQUAL(0, GroupId::expandUnique(gid, "ff8000000002"));
CPPUNIT_ASSERT_EQUAL(std::string("ff80000000020001"), GroupId::toHex(gid));
CPPUNIT_ASSERT_EQUAL(0, GroupId::expandUnique(gid, "fff800000003"));
CPPUNIT_ASSERT_EQUAL(std::string("fff8000000030000"), GroupId::toHex(gid));
CPPUNIT_ASSERT_EQUAL((int)GroupId::ERR_NOT_FOUND,
GroupId::expandUnique(gid, "ff80000000031"));
}
void GroupIdTest::testToHex()
{
CPPUNIT_ASSERT_EQUAL(std::string("1234567890abcdef"),
GroupId::toHex(1311768467294899695LL));
CPPUNIT_ASSERT_EQUAL(std::string("0000000000000001"),
GroupId::toHex(0000000000000000001LL));
}
void GroupIdTest::testToAbbrevHex()
{
CPPUNIT_ASSERT_EQUAL(std::string("123456"),
GroupId::toAbbrevHex(1311768467294899695LL));
CPPUNIT_ASSERT_EQUAL(std::string("000000"),
GroupId::toAbbrevHex(0000000000000000001LL));
}
} // namespace aria2

View File

@ -94,7 +94,7 @@ void HandshakeExtensionMessageTest::testDoReceivedAction()
SharedHandle<DownloadContext> dctx
(new DownloadContext(METADATA_PIECE_SIZE, 0));
SharedHandle<Option> op(new Option());
RequestGroup rg(op);
RequestGroup rg(GroupId::create(), op);
rg.setDownloadContext(dctx);
SharedHandle<TorrentAttribute> attrs(new TorrentAttribute());

View File

@ -87,7 +87,8 @@ aria2c_SOURCES = AllTest.cc\
AbstractCommandTest.cc\
SinkStreamFilterTest.cc\
WrDiskCacheTest.cc\
WrDiskCacheEntryTest.cc
WrDiskCacheEntryTest.cc\
GroupIdTest.cc
if ENABLE_XML_RPC
aria2c_SOURCES += XmlRpcRequestParserControllerTest.cc

View File

@ -40,7 +40,7 @@ void MetalinkPostDownloadHandlerTest::testCanHandle_extension()
{
SharedHandle<DownloadContext> dctx
(new DownloadContext(0, 0, "test.metalink"));
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
MetalinkPostDownloadHandler handler;
@ -55,7 +55,7 @@ void MetalinkPostDownloadHandlerTest::testCanHandle_contentType()
{
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0, "test"));
dctx->getFirstFileEntry()->setContentType("application/metalink+xml");
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
MetalinkPostDownloadHandler handler;
@ -70,7 +70,7 @@ void MetalinkPostDownloadHandlerTest::testGetNextRequestGroups()
{
SharedHandle<DownloadContext> dctx
(new DownloadContext(1024, 0, A2_TEST_DIR"/test.xml"));
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
rg.initPieceStorage();
rg.getPieceStorage()->getDiskAdaptor()->enableReadOnly();
@ -90,7 +90,7 @@ void MetalinkPostDownloadHandlerTest::testGetNextRequestGroups_withBaseUri()
SharedHandle<DownloadContext> dctx
(new DownloadContext(1024, 0, A2_TEST_DIR"/base_uri.xml"));
dctx->getFirstFileEntry()->addUri("http://base/dir/base_uri.xml");
RequestGroup rg(option_);
RequestGroup rg(GroupId::create(), option_);
rg.setDownloadContext(dctx);
rg.initPieceStorage();
rg.getPieceStorage()->getDiskAdaptor()->enableReadOnly();

View File

@ -33,7 +33,6 @@ private:
public:
void setUp()
{
RequestGroup::resetGIDCounter();
option_.reset(new Option());
}
@ -49,8 +48,10 @@ CPPUNIT_TEST_SUITE_REGISTRATION( RequestGroupManTest );
void RequestGroupManTest::testIsSameFileBeingDownloaded()
{
SharedHandle<RequestGroup> rg1(new RequestGroup(util::copy(option_)));
SharedHandle<RequestGroup> rg2(new RequestGroup(util::copy(option_)));
SharedHandle<RequestGroup> rg1(new RequestGroup(GroupId::create(),
util::copy(option_)));
SharedHandle<RequestGroup> rg2(new RequestGroup(GroupId::create(),
util::copy(option_)));
SharedHandle<DownloadContext> dctx1
(new DownloadContext(0, 0, "aria2.tar.bz2"));
@ -118,51 +119,71 @@ void RequestGroupManTest::testLoadServerStat()
void RequestGroupManTest::testChangeReservedGroupPosition()
{
SharedHandle<RequestGroup> gs[] = {
SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_))),
SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_))),
SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_))),
SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_)))
SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
util::copy(option_))),
SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
util::copy(option_))),
SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
util::copy(option_))),
SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
util::copy(option_)))
};
std::vector<SharedHandle<RequestGroup> > groups(vbegin(gs), vend(gs));
RequestGroupMan rm(groups, 0, option_.get());
CPPUNIT_ASSERT_EQUAL
((size_t)0, rm.changeReservedGroupPosition(1, 0, RequestGroupMan::POS_SET));
((size_t)0, rm.changeReservedGroupPosition(gs[0]->getGID(),
0, RequestGroupMan::POS_SET));
CPPUNIT_ASSERT_EQUAL
((size_t)1, rm.changeReservedGroupPosition(1, 1, RequestGroupMan::POS_SET));
((size_t)1, rm.changeReservedGroupPosition(gs[0]->getGID(),
1, RequestGroupMan::POS_SET));
CPPUNIT_ASSERT_EQUAL
((size_t)3, rm.changeReservedGroupPosition(1, 10,RequestGroupMan::POS_SET));
((size_t)3, rm.changeReservedGroupPosition(gs[0]->getGID(),
10,RequestGroupMan::POS_SET));
CPPUNIT_ASSERT_EQUAL
((size_t)0, rm.changeReservedGroupPosition(1,-10,RequestGroupMan::POS_SET));
((size_t)0, rm.changeReservedGroupPosition(gs[0]->getGID(),
-10, RequestGroupMan::POS_SET));
CPPUNIT_ASSERT_EQUAL
((size_t)1, rm.changeReservedGroupPosition(2, 0, RequestGroupMan::POS_CUR));
((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
0, RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)2, rm.changeReservedGroupPosition(2, 1, RequestGroupMan::POS_CUR));
((size_t)2, rm.changeReservedGroupPosition(gs[1]->getGID(),
1, RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)1, rm.changeReservedGroupPosition(2, -1,RequestGroupMan::POS_CUR));
((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
-1,RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)0, rm.changeReservedGroupPosition(2,-10,RequestGroupMan::POS_CUR));
((size_t)0, rm.changeReservedGroupPosition(gs[1]->getGID(),
-10, RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)1, rm.changeReservedGroupPosition(2, 1, RequestGroupMan::POS_CUR));
((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
1, RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)3, rm.changeReservedGroupPosition(2, 10,RequestGroupMan::POS_CUR));
((size_t)3, rm.changeReservedGroupPosition(gs[1]->getGID(),
10, RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)1, rm.changeReservedGroupPosition(2, -2,RequestGroupMan::POS_CUR));
((size_t)1, rm.changeReservedGroupPosition(gs[1]->getGID(),
-2,RequestGroupMan::POS_CUR));
CPPUNIT_ASSERT_EQUAL
((size_t)3, rm.changeReservedGroupPosition(4, 0, RequestGroupMan::POS_END));
((size_t)3, rm.changeReservedGroupPosition(gs[3]->getGID(),
0, RequestGroupMan::POS_END));
CPPUNIT_ASSERT_EQUAL
((size_t)2, rm.changeReservedGroupPosition(4, -1,RequestGroupMan::POS_END));
((size_t)2, rm.changeReservedGroupPosition(gs[3]->getGID(),
-1,RequestGroupMan::POS_END));
CPPUNIT_ASSERT_EQUAL
((size_t)0, rm.changeReservedGroupPosition(4,-10,RequestGroupMan::POS_END));
((size_t)0, rm.changeReservedGroupPosition(gs[3]->getGID(),
-10, RequestGroupMan::POS_END));
CPPUNIT_ASSERT_EQUAL
((size_t)3, rm.changeReservedGroupPosition(4, 10,RequestGroupMan::POS_END));
((size_t)3, rm.changeReservedGroupPosition(gs[3]->getGID(),
10, RequestGroupMan::POS_END));
CPPUNIT_ASSERT_EQUAL((size_t)4, rm.getReservedGroups().size());
try {
rm.changeReservedGroupPosition(5, 0, RequestGroupMan::POS_CUR);
rm.changeReservedGroupPosition(GroupId::create()->getNumericId(),
0, RequestGroupMan::POS_CUR);
CPPUNIT_FAIL("exception must be thrown.");
} catch(RecoverableException& e) {
// success

View File

@ -36,7 +36,7 @@ void RequestGroupTest::testGetFirstFilePath()
SharedHandle<DownloadContext> ctx
(new DownloadContext(1024, 1024, "/tmp/myfile"));
RequestGroup group(option_);
RequestGroup group(GroupId::create(), option_);
group.setDownloadContext(ctx);
CPPUNIT_ASSERT_EQUAL(std::string("/tmp/myfile"), group.getFirstFilePath());
@ -50,7 +50,7 @@ void RequestGroupTest::testCreateDownloadResult()
{
SharedHandle<DownloadContext> ctx
(new DownloadContext(1024, 1024*1024, "/tmp/myfile"));
RequestGroup group(option_);
RequestGroup group(GroupId::create(), option_);
group.setDownloadContext(ctx);
group.initPieceStorage();
{

View File

@ -83,7 +83,6 @@ private:
public:
void setUp()
{
RequestGroup::resetGIDCounter();
option_.reset(new Option());
option_->put(PREF_DIR, A2_TEST_OUT_DIR"/aria2_RpcMethodTest");
option_->put(PREF_PIECE_LENGTH, "1048576");
@ -176,8 +175,11 @@ void RpcMethodTest::testAddUri()
{
RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code);
a2_gid_t gid;
CPPUNIT_ASSERT_EQUAL(0, GroupId::toNumericId
(gid, downcast<String>(res.param)->s().c_str()));
CPPUNIT_ASSERT_EQUAL(std::string("/sink"),
e_->getRequestGroupMan()->findReservedGroup(2)->
e_->getRequestGroupMan()->findReservedGroup(gid)->
getOption()->get(PREF_DIR));
}
}
@ -271,7 +273,8 @@ void RpcMethodTest::testAddTorrent()
(!File(e_->getOption()->get(PREF_DIR)+
"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").exists());
CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL(std::string("1"), downcast<String>(res.param)->s());
CPPUNIT_ASSERT_EQUAL(sizeof(a2_gid_t)*2,
downcast<String>(res.param)->s().size());
}
e_->getOption()->put(PREF_RPC_SAVE_UPLOAD_METADATA, A2_V_TRUE);
{
@ -280,10 +283,12 @@ void RpcMethodTest::testAddTorrent()
(File(e_->getOption()->get(PREF_DIR)+
"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").exists());
CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL(std::string("2"), downcast<String>(res.param)->s());
a2_gid_t gid;
CPPUNIT_ASSERT_EQUAL(0, GroupId::toNumericId
(gid, downcast<String>(res.param)->s().c_str()));
SharedHandle<RequestGroup> group =
e_->getRequestGroupMan()->findReservedGroup(1);
e_->getRequestGroupMan()->findReservedGroup(gid);
CPPUNIT_ASSERT(group);
CPPUNIT_ASSERT_EQUAL(e_->getOption()->get(PREF_DIR)+"/aria2-0.8.2.tar.bz2",
group->getFirstFilePath());
@ -304,9 +309,12 @@ void RpcMethodTest::testAddTorrent()
{
RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code);
a2_gid_t gid;
CPPUNIT_ASSERT_EQUAL(0, GroupId::toNumericId
(gid, downcast<String>(res.param)->s().c_str()));
CPPUNIT_ASSERT_EQUAL
(dir+"/aria2-0.8.2.tar.bz2",
e_->getRequestGroupMan()->findReservedGroup(3)->getFirstFilePath());
e_->getRequestGroupMan()->findReservedGroup(gid)->getFirstFilePath());
CPPUNIT_ASSERT
(File(dir+"/0a3893293e27ac0490424c06de4d09242215f0a6.torrent").exists());
}
@ -367,8 +375,13 @@ void RpcMethodTest::testAddMetalink()
CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = downcast<List>(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
CPPUNIT_ASSERT_EQUAL(std::string("1"), downcast<String>(resParams->get(0))->s());
CPPUNIT_ASSERT_EQUAL(std::string("2"), downcast<String>(resParams->get(1))->s());
a2_gid_t gid1, gid2;
CPPUNIT_ASSERT_EQUAL
(0, GroupId::toNumericId
(gid1, downcast<String>(resParams->get(0))->s().c_str()));
CPPUNIT_ASSERT_EQUAL
(0, GroupId::toNumericId
(gid2, downcast<String>(resParams->get(1))->s().c_str()));
CPPUNIT_ASSERT
(!File(e_->getOption()->get(PREF_DIR)+
"/c908634fbc257fd56f0114912c2772aeeb4064f4.meta4").exists());
@ -379,8 +392,13 @@ void RpcMethodTest::testAddMetalink()
CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = downcast<List>(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
CPPUNIT_ASSERT_EQUAL(std::string("3"), downcast<String>(resParams->get(0))->s());
CPPUNIT_ASSERT_EQUAL(std::string("4"), downcast<String>(resParams->get(1))->s());
a2_gid_t gid3, gid4;
CPPUNIT_ASSERT_EQUAL
(0, GroupId::toNumericId
(gid3, downcast<String>(resParams->get(0))->s().c_str()));
CPPUNIT_ASSERT_EQUAL
(0, GroupId::toNumericId
(gid4, downcast<String>(resParams->get(1))->s().c_str()));
#ifdef ENABLE_MESSAGE_DIGEST
CPPUNIT_ASSERT
(File(e_->getOption()->get(PREF_DIR)+
@ -388,12 +406,12 @@ void RpcMethodTest::testAddMetalink()
#endif // ENABLE_MESSAGE_DIGEST
SharedHandle<RequestGroup> tar =
e_->getRequestGroupMan()->findReservedGroup(1);
e_->getRequestGroupMan()->findReservedGroup(gid3);
CPPUNIT_ASSERT(tar);
CPPUNIT_ASSERT_EQUAL(e_->getOption()->get(PREF_DIR)+"/aria2-5.0.0.tar.bz2",
tar->getFirstFilePath());
SharedHandle<RequestGroup> deb =
e_->getRequestGroupMan()->findReservedGroup(2);
e_->getRequestGroupMan()->findReservedGroup(gid4);
CPPUNIT_ASSERT(deb);
CPPUNIT_ASSERT_EQUAL(e_->getOption()->get(PREF_DIR)+"/aria2-5.0.0.deb",
deb->getFirstFilePath());
@ -408,8 +426,14 @@ void RpcMethodTest::testAddMetalink()
{
RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = downcast<List>(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
a2_gid_t gid5;
CPPUNIT_ASSERT_EQUAL
(0, GroupId::toNumericId
(gid5, downcast<String>(resParams->get(0))->s().c_str()));
CPPUNIT_ASSERT_EQUAL(dir+"/aria2-5.0.0.tar.bz2",
e_->getRequestGroupMan()->findReservedGroup(5)->
e_->getRequestGroupMan()->findReservedGroup(gid5)->
getFirstFilePath());
#ifdef ENABLE_MESSAGE_DIGEST
CPPUNIT_ASSERT
@ -462,12 +486,13 @@ void RpcMethodTest::testAddMetalink_withPosition()
void RpcMethodTest::testChangeOption()
{
SharedHandle<RequestGroup> group(new RequestGroup(option_));
SharedHandle<RequestGroup> group(new RequestGroup(GroupId::create(),
option_));
e_->getRequestGroupMan()->addReservedGroup(group);
ChangeOptionRpcMethod m;
RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
req.params->append("1");
req.params->append(GroupId::toHex(group->getGID()));
SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_DOWNLOAD_LIMIT->k, "100K");
#ifdef ENABLE_BITTORRENT
@ -505,12 +530,13 @@ void RpcMethodTest::testChangeOption()
void RpcMethodTest::testChangeOption_withBadOption()
{
SharedHandle<RequestGroup> group(new RequestGroup(option_));
SharedHandle<RequestGroup> group(new RequestGroup(GroupId::create(),
option_));
e_->getRequestGroupMan()->addReservedGroup(group);
ChangeOptionRpcMethod m;
RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
req.params->append("1");
req.params->append(GroupId::toHex(group->getGID()));
SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_DOWNLOAD_LIMIT->k, "badvalue");
req.params->append(opt);
@ -520,12 +546,13 @@ void RpcMethodTest::testChangeOption_withBadOption()
void RpcMethodTest::testChangeOption_withNotAllowedOption()
{
SharedHandle<RequestGroup> group(new RequestGroup(option_));
SharedHandle<RequestGroup> group(new RequestGroup(GroupId::create(),
option_));
e_->getRequestGroupMan()->addReservedGroup(group);
ChangeOptionRpcMethod m;
RpcRequest req(ChangeOptionRpcMethod::getMethodName(), List::g());
req.params->append("1");
req.params->append(GroupId::toHex(group->getGID()));
SharedHandle<Dict> opt = Dict::g();
opt->put(PREF_MAX_OVERALL_DOWNLOAD_LIMIT->k, "100K");
req.params->append(opt);
@ -648,7 +675,7 @@ void RpcMethodTest::testTellWaiting()
#else // !ENABLE_BITTORRENT
addUri("http://4/", e_);
#endif // !ENABLE_BITTORRENT
const SharedHandle<RequestGroupMan>& rgman = e_->getRequestGroupMan();
TellWaitingRpcMethod m;
RpcRequest req(TellWaitingRpcMethod::getMethodName(), List::g());
req.params->append(Integer::g(1));
@ -657,9 +684,9 @@ void RpcMethodTest::testTellWaiting()
CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = downcast<List>(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
CPPUNIT_ASSERT_EQUAL(std::string("2"),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(rgman->getReservedGroups()[1]->getGID()),
getString(downcast<Dict>(resParams->get(0)), "gid"));
CPPUNIT_ASSERT_EQUAL(std::string("3"),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(rgman->getReservedGroups()[2]->getGID()),
getString(downcast<Dict>(resParams->get(1)), "gid"));
// waiting.size() == offset+num
req = RpcRequest(TellWaitingRpcMethod::getMethodName(), List::g());
@ -715,9 +742,9 @@ void RpcMethodTest::testTellWaiting()
CPPUNIT_ASSERT_EQUAL(0, res.code);
resParams = downcast<List>(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)2, resParams->size());
CPPUNIT_ASSERT_EQUAL(std::string("4"),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(rgman->getReservedGroups()[3]->getGID()),
getString(downcast<Dict>(resParams->get(0)), "gid"));
CPPUNIT_ASSERT_EQUAL(std::string("3"),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(rgman->getReservedGroups()[2]->getGID()),
getString(downcast<Dict>(resParams->get(1)), "gid"));
// negative offset and size < num
req.params->set(1, Integer::g(100));
@ -774,7 +801,7 @@ void RpcMethodTest::testGatherStoppedDownload()
followedBy.push_back(3);
followedBy.push_back(4);
SharedHandle<DownloadResult> d(new DownloadResult());
d->gid = 1;
d->gid = GroupId::create();
d->fileEntries = fileEntries;
d->inMemoryDownload = false;
d->sessionDownloadLength = UINT64_MAX;
@ -787,9 +814,11 @@ void RpcMethodTest::testGatherStoppedDownload()
gatherStoppedDownload(entry, d, keys);
const List* followedByRes = downcast<List>(entry->get("followedBy"));
CPPUNIT_ASSERT_EQUAL(std::string("3"), downcast<String>(followedByRes->get(0))->s());
CPPUNIT_ASSERT_EQUAL(std::string("4"), downcast<String>(followedByRes->get(1))->s());
CPPUNIT_ASSERT_EQUAL(std::string("2"),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(3),
downcast<String>(followedByRes->get(0))->s());
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(4),
downcast<String>(followedByRes->get(1))->s());
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(2),
downcast<String>(entry->get("belongsTo"))->s());
keys.push_back("gid");
@ -805,26 +834,30 @@ void RpcMethodTest::testGatherProgressCommon()
SharedHandle<DownloadContext> dctx(new DownloadContext(0, 0,"aria2.tar.bz2"));
std::string uris[] = { "http://localhost/aria2.tar.bz2" };
dctx->getFirstFileEntry()->addUris(vbegin(uris), vend(uris));
SharedHandle<RequestGroup> group(new RequestGroup(util::copy(option_)));
SharedHandle<RequestGroup> group(new RequestGroup(GroupId::create(),
util::copy(option_)));
group->setDownloadContext(dctx);
std::vector<SharedHandle<RequestGroup> > followedBy;
for(int i = 0; i < 2; ++i) {
followedBy.push_back(SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_))));
followedBy.push_back(SharedHandle<RequestGroup>
(new RequestGroup(GroupId::create(),
util::copy(option_))));
}
group->followedBy(followedBy.begin(), followedBy.end());
group->belongsTo(2);
SharedHandle<GroupId> parent = GroupId::create();
group->belongsTo(parent->getNumericId());
SharedHandle<Dict> entry = Dict::g();
std::vector<std::string> keys;
gatherProgressCommon(entry, group, keys);
const List* followedByRes = downcast<List>(entry->get("followedBy"));
CPPUNIT_ASSERT_EQUAL(util::itos(followedBy[0]->getGID()),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(followedBy[0]->getGID()),
downcast<String>(followedByRes->get(0))->s());
CPPUNIT_ASSERT_EQUAL(util::itos(followedBy[1]->getGID()),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(followedBy[1]->getGID()),
downcast<String>(followedByRes->get(1))->s());
CPPUNIT_ASSERT_EQUAL(std::string("2"),
CPPUNIT_ASSERT_EQUAL(parent->toHex(),
downcast<String>(entry->get("belongsTo"))->s());
const List* files = downcast<List>(entry->get("files"));
CPPUNIT_ASSERT_EQUAL((size_t)1, files->size());
@ -897,20 +930,23 @@ void RpcMethodTest::testGatherBitTorrentMetadata()
void RpcMethodTest::testChangePosition()
{
e_->getRequestGroupMan()->addReservedGroup
(SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_))));
(SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
util::copy(option_))));
e_->getRequestGroupMan()->addReservedGroup
(SharedHandle<RequestGroup>(new RequestGroup(util::copy(option_))));
(SharedHandle<RequestGroup>(new RequestGroup(GroupId::create(),
util::copy(option_))));
a2_gid_t gid = e_->getRequestGroupMan()->getReservedGroups()[0]->getGID();
ChangePositionRpcMethod m;
RpcRequest req(ChangePositionRpcMethod::getMethodName(), List::g());
req.params->append("1");
req.params->append(GroupId::toHex(gid));
req.params->append(Integer::g(1));
req.params->append("POS_SET");
RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code);
CPPUNIT_ASSERT_EQUAL((int64_t)1, downcast<Integer>(res.param)->i());
CPPUNIT_ASSERT_EQUAL
((a2_gid_t)1, e_->getRequestGroupMan()->getReservedGroups()[1]->getGID());
(gid, e_->getRequestGroupMan()->getReservedGroups()[1]->getGID());
}
void RpcMethodTest::testChangePosition_fail()
@ -937,13 +973,14 @@ void RpcMethodTest::testChangeUri()
files[1]->addUri("http://example.org/mustremove2");
SharedHandle<DownloadContext> dctx(new DownloadContext());
dctx->setFileEntries(&files[0], &files[3]);
SharedHandle<RequestGroup> group(new RequestGroup(option_));
SharedHandle<RequestGroup> group(new RequestGroup(GroupId::create(),
option_));
group->setDownloadContext(dctx);
e_->getRequestGroupMan()->addReservedGroup(group);
ChangeUriRpcMethod m;
RpcRequest req(ChangeUriRpcMethod::getMethodName(), List::g());
req.params->append("1"); // GID
req.params->append(GroupId::toHex(group->getGID())); // GID
req.params->append(Integer::g(2)); // index of FileEntry
SharedHandle<List> removeuris = List::g();
removeuris->append("http://example.org/mustremove1");
@ -1007,13 +1044,14 @@ void RpcMethodTest::testChangeUri_fail()
}
SharedHandle<DownloadContext> dctx(new DownloadContext());
dctx->setFileEntries(&files[0], &files[3]);
SharedHandle<RequestGroup> group(new RequestGroup(option_));
SharedHandle<RequestGroup> group(new RequestGroup(GroupId::create(),
option_));
group->setDownloadContext(dctx);
e_->getRequestGroupMan()->addReservedGroup(group);
ChangeUriRpcMethod m;
RpcRequest req(ChangeUriRpcMethod::getMethodName(), List::g());
req.params->append("1"); // GID
req.params->append(GroupId::toHex(group->getGID())); // GID
req.params->append(Integer::g(1)); // index of FileEntry
SharedHandle<List> removeuris = List::g();
req.params->append(removeuris);
@ -1028,12 +1066,12 @@ void RpcMethodTest::testChangeUri_fail()
CPPUNIT_ASSERT_EQUAL(1, res.code);
req.params->set(1, Integer::g(1));
req.params->set(0, String::g("2"));
req.params->set(0, String::g(GroupId::create()->toHex()));
res = m.execute(req, e_.get());
// RPC request fails because GID#2 does not exist.
// RPC request fails because the given GID does not exist.
CPPUNIT_ASSERT_EQUAL(1, res.code);
req.params->set(0, String::g("1"));
req.params->set(0, String::g(GroupId::toHex(group->getGID())));
req.params->set(1, Integer::g(4));
res = m.execute(req, e_.get());
// RPC request fails because FileEntry#3 does not exist.
@ -1083,7 +1121,7 @@ void RpcMethodTest::testPause()
{
PauseRpcMethod m;
RpcRequest req(PauseRpcMethod::getMethodName(), List::g());
req.params->append("1");
req.params->append(GroupId::toHex(groups[0]->getGID()));
RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code);
}
@ -1091,7 +1129,7 @@ void RpcMethodTest::testPause()
{
UnpauseRpcMethod m;
RpcRequest req(UnpauseRpcMethod::getMethodName(), List::g());
req.params->append("1");
req.params->append(GroupId::toHex(groups[0]->getGID()));
RpcResponse res = m.execute(req, e_.get());
CPPUNIT_ASSERT_EQUAL(0, res.code);
}
@ -1172,9 +1210,10 @@ void RpcMethodTest::testSystemMulticall()
CPPUNIT_ASSERT_EQUAL(0, res.code);
const List* resParams = downcast<List>(res.param);
CPPUNIT_ASSERT_EQUAL((size_t)7, resParams->size());
CPPUNIT_ASSERT_EQUAL(std::string("1"),
SharedHandle<RequestGroupMan> rgman = e_->getRequestGroupMan();
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(rgman->getReservedGroups()[0]->getGID()),
downcast<String>(downcast<List>(resParams->get(0))->get(0))->s());
CPPUNIT_ASSERT_EQUAL(std::string("2"),
CPPUNIT_ASSERT_EQUAL(GroupId::toHex(rgman->getReservedGroups()[1]->getGID()),
downcast<String>(downcast<List>(resParams->get(1))->get(0))->s());
CPPUNIT_ASSERT_EQUAL((int64_t)1,
downcast<Integer>

View File

@ -35,7 +35,7 @@ public:
option_.reset(new Option());
option_->put(PREF_DIR, A2_TEST_OUT_DIR);
dctx_.reset(new DownloadContext(0, 0, A2_TEST_OUT_DIR"/something"));
requestGroup_.reset(new RequestGroup(option_));
requestGroup_.reset(new RequestGroup(GroupId::create(), option_));
requestGroup_->setDownloadContext(dctx_);
}