-
Notifications
You must be signed in to change notification settings - Fork 69
/
Copy pathtest_utils.cpp
261 lines (206 loc) · 8.73 KB
/
test_utils.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
#include "test_utils.h"
// Test configuration constants (to be loaded from an INI file)
bool FTP_TEST_ENABLED;
bool SFTP_TEST_ENABLED;
bool HTTP_PROXY_TEST_ENABLED;
std::string CURL_LOG_FOLDER;
std::string SSL_CERT_FILE;
std::string SSL_KEY_FILE;
std::string SSL_KEY_PWD;
std::string FTP_SERVER;
unsigned FTP_SERVER_PORT;
std::string FTP_USERNAME;
std::string FTP_PASSWORD;
std::string FTP_REMOTE_FILE;
std::string FTP_REMOTE_FILE_SHA1SUM;
std::string FTP_REMOTE_UPLOAD_FOLDER;
std::string FTP_REMOTE_DOWNLOAD_FOLDER;
std::string SFTP_SERVER;
unsigned SFTP_SERVER_PORT;
std::string SFTP_USERNAME;
std::string SFTP_PASSWORD;
std::string SFTP_REMOTE_FILE;
std::string SFTP_REMOTE_FILE_SHA1SUM;
std::string SFTP_REMOTE_UPLOAD_FOLDER;
std::string SFTP_REMOTE_DOWNLOAD_FOLDER;
std::string PROXY_SERVER;
std::string PROXY_SERVER_FAKE;
std::mutex g_mtxConsoleMutex;
bool GlobalTestInit(const std::string& strConfFile) {
CSimpleIniA ini;
if (ini.LoadFile(strConfFile.c_str()) != SI_Error::SI_OK) return false;
std::string strTmp;
strTmp = ini.GetValue("tests", "ftp", "");
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::toupper);
FTP_TEST_ENABLED = (strTmp == "YES") ? true : false;
strTmp = ini.GetValue("tests", "sftp", "");
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::toupper);
SFTP_TEST_ENABLED = (strTmp == "YES") ? true : false;
strTmp = ini.GetValue("tests", "http-proxy", "");
std::transform(strTmp.begin(), strTmp.end(), strTmp.begin(), ::toupper);
HTTP_PROXY_TEST_ENABLED = (strTmp == "YES") ? true : false;
// required when a build is generated with the macro DEBUG_CURL
CURL_LOG_FOLDER = ini.GetValue("local", "curl_logs_folder", "");
SSL_CERT_FILE = ini.GetValue("local", "ssl_cert_file", "");
SSL_KEY_FILE = ini.GetValue("local", "ssl_key_file", "");
SSL_KEY_PWD = ini.GetValue("local", "ssl_key_pwd", "");
PROXY_SERVER = ini.GetValue("http-proxy", "host", "");
PROXY_SERVER_FAKE = ini.GetValue("http-proxy", "host_invalid", "");
FTP_SERVER = ini.GetValue("ftp", "host", "");
FTP_SERVER_PORT = atoi(ini.GetValue("ftp", "port", "0"));
FTP_USERNAME = ini.GetValue("ftp", "username", "");
FTP_PASSWORD = ini.GetValue("ftp", "password", "");
FTP_REMOTE_FILE = ini.GetValue("ftp", "remote_file", "");
FTP_REMOTE_FILE_SHA1SUM = ini.GetValue("ftp", "remote_file_sha1sum", "");
std::transform(FTP_REMOTE_FILE_SHA1SUM.begin(), FTP_REMOTE_FILE_SHA1SUM.end(), FTP_REMOTE_FILE_SHA1SUM.begin(), ::tolower);
FTP_REMOTE_UPLOAD_FOLDER = ini.GetValue("ftp", "remote_upload_folder", "");
FTP_REMOTE_DOWNLOAD_FOLDER = ini.GetValue("ftp", "remote_download_folder", "");
SFTP_SERVER = ini.GetValue("sftp", "host", "");
SFTP_SERVER_PORT = atoi(ini.GetValue("sftp", "port", "0"));
SFTP_USERNAME = ini.GetValue("sftp", "username", "");
SFTP_PASSWORD = ini.GetValue("sftp", "password", "");
SFTP_REMOTE_FILE = ini.GetValue("sftp", "remote_file", "");
SFTP_REMOTE_FILE = ini.GetValue("sftp", "remote_file", "");
SFTP_REMOTE_FILE_SHA1SUM = ini.GetValue("sftp", "remote_file_sha1sum", "");
std::transform(SFTP_REMOTE_FILE_SHA1SUM.begin(), SFTP_REMOTE_FILE_SHA1SUM.end(), SFTP_REMOTE_FILE_SHA1SUM.begin(), ::tolower);
SFTP_REMOTE_UPLOAD_FOLDER = ini.GetValue("sftp", "remote_upload_folder", "");
SFTP_REMOTE_DOWNLOAD_FOLDER = ini.GetValue("sftp", "remote_download_folder", "");
if (!FTP_REMOTE_UPLOAD_FOLDER.empty() && FTP_REMOTE_UPLOAD_FOLDER.at(FTP_REMOTE_UPLOAD_FOLDER.length() - 1) != '/') {
FTP_REMOTE_UPLOAD_FOLDER += '/';
}
if (!FTP_REMOTE_DOWNLOAD_FOLDER.empty()) {
if (FTP_REMOTE_DOWNLOAD_FOLDER.at(FTP_REMOTE_DOWNLOAD_FOLDER.length() - 1) != '/')
FTP_REMOTE_DOWNLOAD_FOLDER += "/*";
else
FTP_REMOTE_DOWNLOAD_FOLDER += "*";
}
if (!SFTP_REMOTE_UPLOAD_FOLDER.empty() && SFTP_REMOTE_UPLOAD_FOLDER.at(SFTP_REMOTE_UPLOAD_FOLDER.length() - 1) != '/') {
SFTP_REMOTE_UPLOAD_FOLDER += '/';
}
if (!SFTP_REMOTE_DOWNLOAD_FOLDER.empty()) {
if (SFTP_REMOTE_DOWNLOAD_FOLDER.at(SFTP_REMOTE_DOWNLOAD_FOLDER.length() - 1) != '/')
SFTP_REMOTE_DOWNLOAD_FOLDER += "/*";
else
SFTP_REMOTE_DOWNLOAD_FOLDER += "*";
}
if ((FTP_TEST_ENABLED && (FTP_SERVER.empty() || FTP_SERVER_PORT == 0)) ||
(SFTP_TEST_ENABLED && (SFTP_SERVER.empty() || SFTP_SERVER_PORT == 0)) ||
(HTTP_PROXY_TEST_ENABLED && (PROXY_SERVER.empty() || PROXY_SERVER_FAKE.empty()))) {
std::clog << "[ERROR] Check your INI file parameters."
" Disable tests that don't have a server/port value."
<< std::endl;
return false;
}
return true;
}
void GlobalTestCleanUp(void) { return; }
void TimeStampTest(std::ostringstream& ssTimestamp) {
time_t tRawTime;
tm* tmTimeInfo;
time(&tRawTime);
tmTimeInfo = localtime(&tRawTime);
ssTimestamp << (tmTimeInfo->tm_year) + 1900 << "/" << tmTimeInfo->tm_mon + 1 << "/" << tmTimeInfo->tm_mday << " at "
<< tmTimeInfo->tm_hour << ":" << tmTimeInfo->tm_min << ":" << tmTimeInfo->tm_sec;
}
// for uplaod prog. callback, just use DL one and inverse download parameters with upload ones...
int TestUPProgressCallback(void* ptr, double dTotalToDownload, double dNowDownloaded, double dTotalToUpload, double dNowUploaded) {
return TestDLProgressCallback(ptr, dTotalToUpload, dNowUploaded, dTotalToDownload, dNowDownloaded);
}
int TestDLProgressCallback(void* ptr, double dTotalToDownload, double dNowDownloaded, double dTotalToUpload, double dNowUploaded) {
// ensure that the file to be downloaded is not empty
// because that would cause a division by zero error later on
if (dTotalToDownload <= 0.0) return 0;
// how wide you want the progress meter to be
const int iTotalDots = 20;
double dFractionDownloaded = dNowDownloaded / dTotalToDownload;
// part of the progressmeter that's already "full"
int iDots = static_cast<int>(round(dFractionDownloaded * iTotalDots));
// create the "meter"
int iDot = 0;
std::cout << static_cast<unsigned>(dFractionDownloaded * 100) << "% [";
// part that's full already
for (; iDot < iDots; iDot++) std::cout << "=";
// remaining part (spaces)
for (; iDot < iTotalDots; iDot++) std::cout << " ";
// and back to line begin - do not forget the fflush to avoid output buffering problems!
std::cout << "] \r" << std::flush;
// if you don't return 0, the transfer will be aborted - see the documentation
return 0;
}
long GetGMTOffset() {
time_t now = time(nullptr);
struct tm gm = *gmtime(&now);
time_t gmt = mktime(&gm);
struct tm loc = *localtime(&now);
time_t local = mktime(&loc);
return static_cast<long>(difftime(local, gmt));
}
bool GetFileTime(const char* const& pszFilePath, time_t& tLastModificationTime) {
FILE* pFile = fopen(pszFilePath, "rb");
if (pFile != nullptr) {
struct stat file_info;
#ifndef LINUX
if (fstat(_fileno(pFile), &file_info) == 0)
#else
if (fstat(fileno(pFile), &file_info) == 0)
#endif
{
tLastModificationTime = file_info.st_mtime;
return true;
}
}
return false;
}
long long GetFileSize(const std::string& filename) {
struct stat stat_buf;
int rc = stat(filename.c_str(), &stat_buf);
return rc == 0 ? stat_buf.st_size : -1;
}
long long FdGetFileSize(int fd) {
struct stat stat_buf;
int rc = fstat(fd, &stat_buf);
return rc == 0 ? stat_buf.st_size : -1;
}
std::string sha1sum(const std::vector<char>& memData) {
CSHA1 sha1;
sha1.Update(reinterpret_cast<const unsigned char*>(memData.data()), memData.size());
sha1.Final();
std::string strHash;
sha1.ReportHashStl(strHash, CSHA1::REPORT_HEX_SHORT);
return strHash;
}
std::string sha1sum(const std::string& filename) {
long long fileSize = GetFileSize(filename);
if (fileSize <= 0) {
return std::string();
}
std::ifstream file(filename, std::ios::binary);
if (!file) {
return std::string();
}
CSHA1 sha1;
char* pFileBuffer;
static const size_t s_bufferSize = 32 * 20 * 820;
try {
pFileBuffer = new char[s_bufferSize];
} catch (...) {
return std::string();
}
// size_t bytesProcessed = 0;
while (true) {
file.read(pFileBuffer, s_bufferSize);
const size_t readBytes = file.gcount();
if (readBytes > 0) {
sha1.Update(reinterpret_cast<const unsigned char*>(pFileBuffer), readBytes);
} else {
break;
}
// bytesProcessed += readBytes;
}
delete[] pFileBuffer;
// Finalize hash
sha1.Final();
std::string strHash;
sha1.ReportHashStl(strHash, CSHA1::REPORT_HEX_SHORT);
return strHash;
}