Files
wget2/tests/test-auth-digest.c
2018-04-30 20:52:11 +02:00

170 lines
4.5 KiB
C

/*
* Copyright(c) 2017-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 authentication using digest scheme
*
* Changelog
* 17.08.2017 Didik Setiawan created
*
*/
#include <config.h>
#include <stdlib.h> // exit()
#include <string.h> // strlen()
#include "libtest.h"
#define username "my_username"
#define password "my_password"
int main(void)
{
wget_test_url_t urls[] = {
{ .name = "/needs-auth.txt",
.auth_method = "Digest",
.auth_username = username,
.auth_password = password,
.code = "200 Dontcare",
.body = "You are authenticated.",
.headers = {
"Content-Type: text/plain",
}
}
};
wget_test_file_t netrc = {
.name = ".netrc",
.content = "default\r\nlogin " username "\r\npassword " password "\r\n"
};
// 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-auth-digest
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=" username " --password=" password,
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 0,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ urls[0].name + 1, urls[0].body },
{ NULL } },
0);
// test-auth-digest with .netrc
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--netrc-file=.netrc",
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 0,
WGET_TEST_EXISTING_FILES, &(wget_test_file_t []) {
{ netrc.name, netrc.content },
{ NULL } },
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ urls[0].name + 1, urls[0].body },
{ netrc.name, netrc.content },
{ NULL } },
0);
// wrong credentials
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--password=" password,
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=\"\" --password=" password,
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=\"whatever\" --password=" password,
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=" username,
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=" username " --password=\"\"",
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=" username " --password=\"whatever\"",
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=\"\" --password=\"\"",
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
wget_test(
// WGET_TEST_KEEP_TMPFILES, 1,
WGET_TEST_OPTIONS, "--user=\"whatever\" --password=\"whatever\"",
WGET_TEST_REQUEST_URL, urls[0].name + 1,
WGET_TEST_EXPECTED_ERROR_CODE, 6,
WGET_TEST_EXPECTED_FILES, &(wget_test_file_t []) {
{ NULL } },
0);
exit(0);
}