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
|
/*
* Copyright(c) 2013 Tim Ruehsen
* Copyright(c) 2015-2018 Free Software Foundation, Inc.
*
* This file is part of libwget.
*
* Libwget is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Libwget 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 libwget. If not, see <https://www.gnu.org/licenses/>.
*
*
* Testing Wget
*
* Changelog
* 15.07.2013 Tim Ruehsen created
*
*/
#include <config.h>
#include <stdlib.h> // exit()
#include "libtest.h"
int main(void)
{
wget_test_url_t urls[]={
{ .name = "/index.html",
.code = "200 Dontcare",
.body =
"<html><head><title>Main Page</title>" \
"<style> html { background: url(htTp://localhost:{{port}}/second.html); }</style>" \
"<style> div { background: url(htTp://localhost:{{port}}/second.html); }</style>" \
"</head><body><p>A link to a" \
" <a href=\"second.html\">second page</a>." \
" <a href=\"htTp://localhost:{{port}}/second.html\">second page</a>." \
" <a href=\"subdir/third.html\">third page</a>." \
" <a href=\"htTp://localhost:{{port}}/subdir/third.html\">third page</a>." \
" <SCRIPT LANGUAGE=\"JavaScript\">document.write(\"<img src=\\\"rw1\\\"\");</SCRIPT>" \
"</p></body></html>",
.headers = {
"Content-Type: text/html",
}
},
{ .name = "/second.html",
.code = "200 Dontcare",
.body = "<html><head><title>Site</title></head><body>Some Text</body></html>",
.headers = {
"Content-Type: text/html",
}
},
{ .name = "/subdir/third.html",
.code = "200 Dontcare",
.body = "<html><head><title>Site</title></head><body>Some Text</body></html>",
.headers = {
"Content-Type: text/html",
}
},
};
const char *converted =
"<html><head><title>Main Page</title>" \
"<style> html { background: url(second.html); }</style>" \
"<style> div { background: url(second.html); }</style>" \
"</head><body><p>A link to a" \
" <a href=\"second.html\">second page</a>." \
" <a href=\"second.html\">second page</a>." \
" <a href=\"subdir/third.html\">third page</a>." \
" <a href=\"subdir/third.html\">third page</a>." \
" <SCRIPT LANGUAGE=\"JavaScript\">document.write(\"<img src=\\\"rw1\\\"\");</SCRIPT>" \
"</p></body></html>";
// functions won't come back if an error occurs
wget_test_start_server(
WGET_TEST_RESPONSE_URLS, &urls, countof(urls),
WGET_TEST_FEATURE_MHD,
0);
// test-k, links in <script> shouldn't be converted
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "-k -r -nH",
WGET_TEST_REQUEST_URL, "index.html",
WGET_TEST_EXPECTED_ERROR_CODE, 0,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ urls[0].name + 1, converted },
{ urls[1].name + 1, urls[1].body },
{ urls[2].name + 1, urls[2].body },
{ NULL } },
0);
exit(0);
}
|