#include "config.h"
#include <sys/types.h>
#ifdef HAVE_STDLIB_H
#include <stdlib.h>
#endif
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
#include "ne_request.h"
#include "ne_socket.h"
#include "ne_compress.h"
#include "tests.h"
#include "child.h"
#include "utils.h"
#if defined(NE_HAVE_ZLIB) && defined(NE_HAVE_SSL)
#define NO_TESTS 1
#endif
#define EOL "\r\n"
#ifndef NE_HAVE_ZLIB
static int sd_result = OK;
static int sd_reader(void *ud, const char *block, size_t len)
{
const char *expect = ud;
if (strncmp(expect, block, len) != 0) {
sd_result = FAIL;
t_context("decompress reader got bad data");
}
return 0;
}
static int stub_decompress(void)
{
ne_session *sess;
ne_decompress *dc;
ne_request *req;
int ret;
CALL(make_session(&sess, single_serve_string,
"HTTP/1.1 200 OK" EOL
"Connection: close" EOL EOL
"abcde"));
req = ne_request_create(sess, "GET", "/foo");
dc = ne_decompress_reader(req, ne_accept_2xx, sd_reader, "abcde");
ret = ne_request_dispatch(req);
CALL(await_server());
ONREQ(ret);
ne_decompress_destroy(dc);
ne_request_destroy(req);
ne_session_destroy(sess);
return sd_result;
}
#endif
#ifndef NE_HAVE_SSL
static int stub_ssl(void)
{
ne_session *sess = ne_session_create("https", "localhost", 7777);
ne_ssl_certificate *cert;
ne_ssl_client_cert *cc;
cert = ne_ssl_cert_read("Makefile");
if (cert) {
char *dn, digest[60], date[NE_SSL_VDATELEN];
const ne_ssl_certificate *issuer;
dn = ne_ssl_readable_dname(ne_ssl_cert_subject(cert));
ONN("this code shouldn't run", dn != NULL);
dn = ne_ssl_readable_dname(ne_ssl_cert_issuer(cert));
ONN("this code shouldn't run", dn != NULL);
issuer = ne_ssl_cert_signedby(cert);
ONN("this code shouldn't run", issuer != NULL);
ONN("this code shouldn't run", ne_ssl_cert_digest(cert, digest));
ne_ssl_cert_validity(cert, date, date);
ONN("this code shouldn't run",
ne_ssl_dname_cmp(ne_ssl_cert_subject(cert),
ne_ssl_cert_issuer(cert)));
ONN("this code shouldn't run", ne_ssl_cert_identity(issuer) != NULL);
ONN("this code shouldn't run", ne_ssl_cert_export(cert) != NULL);
}
ONN("this code shouldn't run", ne_ssl_cert_import("foo") != NULL);
ONN("this code shouldn't run", ne_ssl_cert_read("Makefile") != NULL);
ONN("this code shouldn't succeed", ne_ssl_cert_cmp(NULL, NULL) == 0);
ONN("certificate load succeeded", cert != NULL);
ne_ssl_cert_free(cert);
cc = ne_ssl_clicert_read("Makefile");
if (cc) {
const char *name;
cert = (void *)ne_ssl_clicert_owner(cc);
ONN("this code shouldn't run", cert != NULL);
name = ne_ssl_clicert_name(cc);
ONN("this code shouldn't run", name != NULL);
ONN("this code shouldn't run", ne_ssl_clicert_decrypt(cc, "fubar"));
ne_ssl_set_clicert(sess, cc);
}
ONN("client certificate load succeeded", cc != NULL);
ne_ssl_clicert_free(cc);
ne_ssl_trust_default_ca(sess);
ne_session_destroy(sess);
return OK;
}
#endif
#ifdef NO_TESTS
static int null_test(void) { return OK; }
#endif
ne_test tests[] = {
#ifndef NE_HAVE_ZLIB
T(stub_decompress),
#endif
#ifndef NE_HAVE_SSL
T(stub_ssl),
#endif
#ifdef NO_TESTS
T(null_test),
#endif
T(NULL)
};