2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2012 cocos2d-x.org
|
|
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "DownloaderTest.h"
|
|
|
|
|
2021-07-04 16:40:34 +08:00
|
|
|
#include "../../testResource.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
#include "ui/UILoadingBar.h"
|
|
|
|
#include "ui/UIButton.h"
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "network/Downloader.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
USING_NS_AX;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
static const char* sURLList[] = {
|
|
|
|
"https://www.cocos2d-x.org/attachments/802/cocos2dx_landscape.png", "https://cocos2d-x.org/images/logo.png",
|
2019-11-23 20:27:39 +08:00
|
|
|
"https://www.cocos2d-x.org/attachments/1503/no_exist.txt", // try to download no exist file
|
2023-08-31 17:48:39 +08:00
|
|
|
"https://cdn-fastly.obsproject.com/downloads/OBS-Studio-27.0.1-Full-Installer-x64.exe" // "https://github.com/openssl/openssl/archive/OpenSSL_1_1_1a.zip",
|
2019-11-23 20:27:39 +08:00
|
|
|
};
|
2021-12-31 12:12:40 +08:00
|
|
|
const static int sListSize = (sizeof(sURLList) / sizeof(sURLList[0]));
|
|
|
|
static const char* sNameList[sListSize] = {
|
2019-11-23 20:27:39 +08:00
|
|
|
"cocos2dx_landscape.png",
|
|
|
|
"logo.png",
|
|
|
|
"inexist file",
|
|
|
|
"big file",
|
|
|
|
};
|
|
|
|
|
|
|
|
struct DownloaderTest : public TestCase
|
|
|
|
{
|
|
|
|
CREATE_FUNC(DownloaderTest);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
virtual std::string title() const override { return "Downloader Test"; }
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
std::unique_ptr<network::Downloader> downloader;
|
2021-12-31 12:12:40 +08:00
|
|
|
|
|
|
|
DownloaderTest() { downloader.reset(new network::Downloader()); }
|
|
|
|
|
|
|
|
enum
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
TAG_TITLE = 1,
|
|
|
|
TAG_BUTTON,
|
|
|
|
TAG_PROGRESS_BAR,
|
|
|
|
TAG_STATUS,
|
|
|
|
TAG_SPRITE,
|
|
|
|
};
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
Node* createDownloadView(const char* name, const ax::ui::Button::ccWidgetClickCallback& callback)
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
Size viewSize(220, 120);
|
|
|
|
float margin = 5;
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// create background
|
|
|
|
auto bg = ui::Scale9Sprite::createWithSpriteFrameName("button_actived.png");
|
|
|
|
bg->setContentSize(viewSize);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// add a title on the top
|
2021-12-31 12:12:40 +08:00
|
|
|
auto title = Label::createWithTTF(name, "fonts/arial.ttf", 16);
|
2019-11-23 20:27:39 +08:00
|
|
|
title->setTag(TAG_TITLE);
|
|
|
|
title->setAnchorPoint(Vec2(0.5f, 1.0f));
|
|
|
|
title->setPosition(viewSize.width / 2, viewSize.height - margin);
|
|
|
|
bg->addChild(title, 10);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// add a button on the bottom
|
2021-12-31 12:12:40 +08:00
|
|
|
auto btn = ui::Button::create("cocosui/animationbuttonnormal.png", "cocosui/animationbuttonpressed.png");
|
2019-11-23 20:27:39 +08:00
|
|
|
btn->setTag(TAG_BUTTON);
|
|
|
|
btn->setTitleText("Download");
|
|
|
|
btn->setAnchorPoint(Vec2(0.5f, 0.0f));
|
|
|
|
btn->setPosition(Vec2(viewSize.width / 2, margin));
|
|
|
|
btn->addClickEventListener(callback);
|
|
|
|
bg->addChild(btn, 10);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// add a progress bar
|
|
|
|
auto bar = ui::LoadingBar::create("ccs-res/cocosui/sliderProgress.png");
|
|
|
|
bar->setTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->ignoreContentAdaptWithSize(false);
|
|
|
|
bar->setAnchorPoint(Vec2(0.5f, 0.0f));
|
|
|
|
bar->setContentSize(Size(viewSize.width - margin * 2, btn->getContentSize().height));
|
|
|
|
bar->setPosition(btn->getPosition());
|
|
|
|
bar->setVisible(false);
|
|
|
|
bg->addChild(bar, 10);
|
|
|
|
|
|
|
|
// add a status label
|
2021-12-31 12:12:40 +08:00
|
|
|
auto label = Label::createWithTTF("", "fonts/arial.ttf", 14);
|
2019-11-23 20:27:39 +08:00
|
|
|
label->setTag(TAG_STATUS);
|
|
|
|
label->setAnchorPoint(Vec2(0.5f, 0.5f));
|
|
|
|
label->setPosition(Vec2(viewSize.width / 2, viewSize.height / 2));
|
|
|
|
label->setContentSize(Size(viewSize.width, 0.0f));
|
|
|
|
label->setAlignment(TextHAlignment::CENTER, TextVAlignment::CENTER);
|
|
|
|
label->setDimensions(viewSize.width, viewSize.height);
|
|
|
|
bg->addChild(label, 20);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
return bg;
|
|
|
|
}
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
virtual void onEnter() override
|
|
|
|
{
|
|
|
|
TestCase::onEnter();
|
|
|
|
_restartTestItem->setVisible(true);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
SpriteFrameCache::getInstance()->addSpriteFramesWithFile(s_s9s_ui_plist);
|
|
|
|
|
|
|
|
// add four download view in test case
|
2021-12-31 12:12:40 +08:00
|
|
|
Node* topRightView = createDownloadView(sNameList[0], [this](Ref*) {
|
|
|
|
auto view = this->getChildByName(sNameList[0]);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto sprite = view->getChildByTag(TAG_SPRITE);
|
|
|
|
if (sprite)
|
|
|
|
{
|
|
|
|
sprite->removeFromParentAndCleanup(true);
|
|
|
|
}
|
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
|
|
|
btn->setEnabled(false);
|
2023-08-31 17:48:39 +08:00
|
|
|
btn->setVisible(false);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->setPercent(0);
|
|
|
|
bar->setVisible(true);
|
|
|
|
this->downloader->createDownloadDataTask(sURLList[0], sNameList[0]);
|
|
|
|
});
|
|
|
|
topRightView->setName(sNameList[0]);
|
|
|
|
topRightView->setAnchorPoint(Vec2(0, 0));
|
|
|
|
topRightView->setPosition(VisibleRect::center());
|
|
|
|
this->addChild(topRightView);
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
Node* topLeftView = createDownloadView(sNameList[1], [this](Ref*) {
|
|
|
|
auto view = this->getChildByName(sNameList[1]);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto sprite = view->getChildByTag(TAG_SPRITE);
|
|
|
|
if (sprite)
|
|
|
|
{
|
|
|
|
sprite->removeFromParentAndCleanup(true);
|
|
|
|
}
|
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
|
|
|
btn->setEnabled(false);
|
2023-08-31 17:48:39 +08:00
|
|
|
btn->setVisible(false);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->setPercent(0);
|
|
|
|
bar->setVisible(true);
|
|
|
|
bar->setEnabled(true);
|
|
|
|
this->downloader->createDownloadDataTask(sURLList[1], sNameList[1]);
|
|
|
|
});
|
|
|
|
topLeftView->setName(sNameList[1]);
|
|
|
|
topLeftView->setAnchorPoint(Vec2(1.0f, 0.0f));
|
|
|
|
topLeftView->setPosition(VisibleRect::center());
|
|
|
|
this->addChild(topLeftView);
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
Node* bottomLeftView = createDownloadView(sNameList[2], [this](Ref*) {
|
|
|
|
auto view = this->getChildByName(sNameList[2]);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto sprite = view->getChildByTag(TAG_SPRITE);
|
|
|
|
if (sprite)
|
|
|
|
{
|
|
|
|
sprite->removeFromParentAndCleanup(true);
|
|
|
|
}
|
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
|
|
|
btn->setEnabled(false);
|
2023-08-31 17:48:39 +08:00
|
|
|
btn->setVisible(false);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->setPercent(0);
|
|
|
|
bar->setVisible(true);
|
|
|
|
bar->setEnabled(true);
|
|
|
|
auto path = FileUtils::getInstance()->getWritablePath() + "CppTests/DownloaderTest/" + sNameList[2];
|
|
|
|
this->downloader->createDownloadFileTask(sURLList[2], path, sNameList[2]);
|
|
|
|
});
|
|
|
|
bottomLeftView->setName(sNameList[2]);
|
|
|
|
bottomLeftView->setAnchorPoint(Vec2(1, 1));
|
|
|
|
bottomLeftView->setPosition(VisibleRect::center());
|
|
|
|
this->addChild(bottomLeftView);
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
Node* bottomRightView = createDownloadView(sNameList[3], [this](Ref*) {
|
2019-11-23 20:27:39 +08:00
|
|
|
auto view = this->getChildByName(sNameList[3]);
|
2021-12-31 12:12:40 +08:00
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
2019-11-23 20:27:39 +08:00
|
|
|
btn->setEnabled(false);
|
|
|
|
btn->setVisible(false);
|
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->setPercent(0);
|
|
|
|
bar->setVisible(true);
|
|
|
|
bar->setEnabled(true);
|
|
|
|
auto path = FileUtils::getInstance()->getWritablePath() + "CppTests/DownloaderTest/" + sNameList[3];
|
2021-12-31 12:12:40 +08:00
|
|
|
auto task = this->downloader->createDownloadFileTask(sURLList[3], path, sNameList[3],
|
2023-08-31 17:48:39 +08:00
|
|
|
"730cfe31b344ba77d87d0a896af710d4", false);
|
2021-07-04 16:40:34 +08:00
|
|
|
task->progressInfo.totalBytesExpected = 89945032;
|
2019-11-23 20:27:39 +08:00
|
|
|
});
|
|
|
|
bottomRightView->setName(sNameList[3]);
|
|
|
|
bottomRightView->setAnchorPoint(Vec2(0, 1));
|
|
|
|
bottomRightView->setPosition(VisibleRect::center());
|
|
|
|
this->addChild(bottomRightView);
|
|
|
|
|
|
|
|
// define progress callback
|
2021-12-31 12:12:40 +08:00
|
|
|
downloader->onTaskProgress = [this](const network::DownloadTask& task) {
|
|
|
|
Node* view = this->getChildByName(task.identifier);
|
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
2019-11-24 23:16:11 +08:00
|
|
|
float percent = float(task.progressInfo.totalBytesReceived * 100) / task.progressInfo.totalBytesExpected;
|
2019-11-23 20:27:39 +08:00
|
|
|
bar->setPercent(percent);
|
2021-07-04 16:40:34 +08:00
|
|
|
char buf[128];
|
2021-12-31 12:12:40 +08:00
|
|
|
sprintf(buf, "%.1f%%[total %d KB]", percent, int(task.progressInfo.totalBytesExpected / 1024));
|
2019-11-23 20:27:39 +08:00
|
|
|
auto status = (Label*)view->getChildByTag(TAG_STATUS);
|
|
|
|
status->setString(buf);
|
|
|
|
};
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// define success callback
|
2022-10-18 19:17:36 +08:00
|
|
|
downloader->onDataTaskSuccess = [this](const ax::network::DownloadTask& task,
|
2021-12-31 12:12:40 +08:00
|
|
|
std::vector<unsigned char>& data) {
|
2019-11-23 20:27:39 +08:00
|
|
|
// create texture from data
|
|
|
|
Texture2D* texture = nullptr;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
Image img;
|
2020-09-01 11:43:03 +08:00
|
|
|
if (false == img.initWithImageData(data.data(), data.size(), false))
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
texture = new Texture2D();
|
|
|
|
if (false == texture->initWithImage(&img))
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
2021-12-31 12:12:40 +08:00
|
|
|
auto sprite = Sprite::createWithTexture(texture);
|
|
|
|
auto view = this->getChildByName(task.identifier);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto viewSize = view->getContentSize();
|
|
|
|
sprite->setPosition(viewSize.width / 2, viewSize.height / 2);
|
|
|
|
auto spriteSize = sprite->getContentSize();
|
|
|
|
float scale = MIN((viewSize.height - 20) / spriteSize.height, (viewSize.width - 20) / spriteSize.width);
|
|
|
|
sprite->setScale(scale);
|
|
|
|
view->addChild(sprite, 5, TAG_SPRITE);
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
|
|
|
btn->setEnabled(true);
|
|
|
|
btn->setVisible(true);
|
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->setVisible(false);
|
|
|
|
} while (0);
|
2022-07-16 10:43:05 +08:00
|
|
|
AX_SAFE_RELEASE(texture);
|
2019-11-23 20:27:39 +08:00
|
|
|
};
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2022-10-18 19:17:36 +08:00
|
|
|
downloader->onFileTaskSuccess = [this](const ax::network::DownloadTask& task) {
|
2019-11-23 20:27:39 +08:00
|
|
|
Texture2D* texture = nullptr;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
auto view = this->getChildByName(task.identifier);
|
2021-12-31 12:12:40 +08:00
|
|
|
if (task.storagePath.find(".png") != std::string::npos)
|
|
|
|
{
|
2021-07-04 16:40:34 +08:00
|
|
|
// create sprite from file
|
|
|
|
auto sprite = Sprite::create(task.storagePath);
|
|
|
|
auto viewSize = view->getContentSize();
|
|
|
|
sprite->setPosition(viewSize.width / 2, viewSize.height / 2);
|
|
|
|
auto spriteSize = sprite->getContentSize();
|
|
|
|
float scale =
|
|
|
|
MIN((viewSize.height - 20) / spriteSize.height, (viewSize.width - 20) / spriteSize.width);
|
|
|
|
sprite->setScale(scale);
|
|
|
|
view->addChild(sprite, 5, TAG_SPRITE);
|
2022-07-16 10:43:05 +08:00
|
|
|
AX_SAFE_RELEASE(texture);
|
2021-12-31 12:12:40 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
// download big file success
|
2021-12-31 12:12:40 +08:00
|
|
|
auto msg = StringUtils::format("Download [%s] success.", task.identifier.c_str());
|
|
|
|
auto status = (Label*)view->getChildByTag(TAG_STATUS);
|
2021-07-04 16:40:34 +08:00
|
|
|
status->setString(msg);
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
|
|
|
btn->setEnabled(true);
|
|
|
|
btn->setVisible(true);
|
|
|
|
auto bar = (ui::LoadingBar*)view->getChildByTag(TAG_PROGRESS_BAR);
|
|
|
|
bar->setVisible(false);
|
|
|
|
} while (0);
|
|
|
|
};
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
// define failed callback
|
2022-10-18 19:17:36 +08:00
|
|
|
downloader->onTaskError = [this](const ax::network::DownloadTask& task, int errorCode,
|
2021-12-31 12:12:40 +08:00
|
|
|
int errorCodeInternal, std::string_view errorStr) {
|
|
|
|
log("Failed to download : %s, identifier(%s) error code(%d), internal error code(%d) desc(%s)",
|
|
|
|
task.requestURL.c_str(), task.identifier.c_str(), errorCode, errorCodeInternal, errorStr.data());
|
|
|
|
auto view = this->getChildByName(task.identifier);
|
2019-11-23 20:27:39 +08:00
|
|
|
auto status = (Label*)view->getChildByTag(TAG_STATUS);
|
|
|
|
status->setString(errorStr.length() ? errorStr : "Download failed.");
|
2021-12-31 12:12:40 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
auto btn = (ui::Button*)view->getChildByTag(TAG_BUTTON);
|
|
|
|
btn->setEnabled(true);
|
|
|
|
btn->setVisible(true);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct DownloaderMultiTask : public TestCase
|
|
|
|
{
|
|
|
|
CREATE_FUNC(DownloaderMultiTask);
|
|
|
|
|
|
|
|
virtual std::string title() const override { return "Downloader Multi Task"; }
|
|
|
|
virtual std::string subtitle() const override { return "see the console output"; }
|
|
|
|
|
|
|
|
std::unique_ptr<network::Downloader> downloader;
|
|
|
|
|
|
|
|
DownloaderMultiTask()
|
|
|
|
{
|
|
|
|
// countOfMaxProcessingTasks 32
|
|
|
|
network::DownloaderHints hints = {32, 60, ".going"};
|
|
|
|
downloader.reset(new network::Downloader(hints));
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void onEnter() override
|
|
|
|
{
|
|
|
|
TestCase::onEnter();
|
|
|
|
char path[256];
|
|
|
|
char name[64];
|
|
|
|
// add 64 download task at same time.
|
2021-12-31 12:12:40 +08:00
|
|
|
for (int i = 0; i < 64; i++)
|
|
|
|
{
|
2019-11-23 20:27:39 +08:00
|
|
|
sprintf(name, "%d_%s", i, sNameList[0]);
|
|
|
|
sprintf(path, "%sCppTests/DownloaderTest/%s", FileUtils::getInstance()->getWritablePath().c_str(), name);
|
|
|
|
log("downloader task create: %s", name);
|
|
|
|
this->downloader->createDownloadFileTask(sURLList[0], path, name);
|
|
|
|
}
|
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
downloader->onFileTaskSuccess =
|
|
|
|
([](const network::DownloadTask& task) { log("downloader task success: %s", task.identifier.c_str()); });
|
2019-11-23 20:27:39 +08:00
|
|
|
|
2021-12-31 12:12:40 +08:00
|
|
|
downloader->onTaskError =
|
|
|
|
([](const network::DownloadTask& task, int errorCode, int errorCodeInternal, std::string_view errorStr) {
|
|
|
|
log("downloader task failed : %s, identifier(%s) error code(%d), internal error code(%d) desc(%s)",
|
|
|
|
task.requestURL.c_str(), task.identifier.c_str(), errorCode, errorCodeInternal, errorStr.data());
|
|
|
|
});
|
2019-11-23 20:27:39 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
DownloaderTests::DownloaderTests()
|
|
|
|
{
|
|
|
|
ADD_TEST_CASE(DownloaderTest);
|
|
|
|
ADD_TEST_CASE(DownloaderMultiTask);
|
|
|
|
};
|