Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
M
mongoose
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
mongoose
Commits
5a3b1123
Commit
5a3b1123
authored
Dec 07, 2013
by
Sergey Lyubka
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
tests moved under build
parent
6a9494b6
Hide whitespace changes
Inline
Side-by-side
Showing
29 changed files
with
145 additions
and
431 deletions
+145
-431
Makefile
build/Makefile
+6
-6
.leading.dot.txt
build/test/.leading.dot.txt
+0
-0
all_build_flags.pl
build/test/all_build_flags.pl
+0
-0
bad.cgi
build/test/bad.cgi
+0
-0
bad2.cgi
build/test/bad2.cgi
+0
-0
hello.cgi
build/test/dir with spaces/hello.cgi
+0
-0
index.html
build/test/dir with spaces/桌面/index.html
+0
-0
embed.c
build/test/embed.c
+0
-0
env.cgi
build/test/env.cgi
+0
-0
exploit.pl
build/test/exploit.pl
+0
-0
hello.cgi
build/test/hello.cgi
+0
-0
hello.txt
build/test/hello.txt
+0
-0
page.lp
build/test/page.lp
+0
-0
passfile
build/test/passfile
+0
-0
sh.cgi
build/test/sh.cgi
+0
-0
ssi1.shtml
build/test/ssi1.shtml
+5
-0
ssi2.shtml
build/test/ssi2.shtml
+0
-0
ssi3.shtml
build/test/ssi3.shtml
+0
-0
ssi4.shtml
build/test/ssi4.shtml
+0
-0
ssi5.shtml
build/test/ssi5.shtml
+0
-0
ssi6.shtml
build/test/ssi6.shtml
+0
-0
ssi7.shtml
build/test/ssi7.shtml
+0
-0
ssi8.shtml
build/test/ssi8.shtml
+0
-0
ssi9.shtml
build/test/ssi9.shtml
+1
-1
test.pl
build/test/test.pl
+2
-2
timeout.cgi
build/test/timeout.cgi
+0
-0
unit_test.c
build/test/unit_test.c
+131
-417
x.php
build/test/x.php
+0
-0
ssi1.shtml
test/ssi1.shtml
+0
-5
No files found.
build/Makefile
View file @
5a3b1123
...
...
@@ -67,11 +67,11 @@ all:
../mongoose.c
:
../mongoose.h Makefile $(SOURCES)
cat
$(SOURCES)
|
sed
'/#include "internal.h"/d'
>
$@
unix_unit_test
:
$(LUA_SOURCES) Makefile .
.
/test/unit_test.c
$(CC)
.
.
/test/unit_test.c lua_5.2.1.c
$(CFLAGS)
-g
-O0
-o
t
&&
./t
unix_unit_test
:
$(LUA_SOURCES) Makefile ./test/unit_test.c
$(CC)
./test/unit_test.c lua_5.2.1.c
$(CFLAGS)
-g
-O0
-o
t
&&
./t
core_unit_test
:
Makefile .
.
/test/unit_test.c
$(CC)
.
.
/test/unit_test.c
$(CFLAGS)
-g
-O0
-o
t
&&
./t
core_unit_test
:
Makefile ./test/unit_test.c
$(CC)
./test/unit_test.c
$(CFLAGS)
-g
-O0
-o
t
&&
./t
# Make sure that the compiler flags come last in the compilation string.
# If not so, this can break some on some Linux distros which use
...
...
@@ -102,7 +102,7 @@ $(PROG).dll: $(TINY_SOURCES) Makefile
# This is broken now due to SSL exclusion
windows_unit_test.exe
:
$(LUA_SOURCES) Makefile
$(CL)
.
.
/test/unit_test.c lua_5.2.1.c
-DLUA_COMPAT_ALL
\
$(CL)
./test/unit_test.c lua_5.2.1.c
-DLUA_COMPAT_ALL
\
/link /libpath:
$(MSVC)
/lib advapi32.lib /out:
$@
./
$@
...
...
@@ -128,7 +128,7 @@ macos: $(LUA_SOURCES)
#rm -rf dmg
tests
:
perl .
.
/test/test.pl
$(TEST)
perl ./test/test.pl
$(TEST)
tarball
:
clean
rm
-rf
mongoose-
$(VERSION)
...
...
test/.leading.dot.txt
→
build/
test/.leading.dot.txt
View file @
5a3b1123
File moved
test/all_build_flags.pl
→
build/
test/all_build_flags.pl
View file @
5a3b1123
File moved
test/bad.cgi
→
build/
test/bad.cgi
View file @
5a3b1123
File moved
test/bad2.cgi
→
build/
test/bad2.cgi
View file @
5a3b1123
File moved
test/dir with spaces/hello.cgi
→
build/
test/dir with spaces/hello.cgi
View file @
5a3b1123
File moved
test/dir with spaces/桌面/index.html
→
build/
test/dir with spaces/桌面/index.html
View file @
5a3b1123
File moved
test/embed.c
→
build/
test/embed.c
View file @
5a3b1123
File moved
test/env.cgi
→
build/
test/env.cgi
View file @
5a3b1123
File moved
test/exploit.pl
→
build/
test/exploit.pl
View file @
5a3b1123
File moved
test/hello.cgi
→
build/
test/hello.cgi
View file @
5a3b1123
File moved
test/hello.txt
→
build/
test/hello.txt
View file @
5a3b1123
File moved
test/page.lp
→
build/
test/page.lp
View file @
5a3b1123
File moved
test/passfile
→
build/
test/passfile
View file @
5a3b1123
File moved
test/sh.cgi
→
build/
test/sh.cgi
View file @
5a3b1123
File moved
build/test/ssi1.shtml
0 → 100644
View file @
5a3b1123
<html><pre>
ssi_begin
<!--#include file="../Makefile" -->
ssi_end
</pre></html>
test/ssi2.shtml
→
build/
test/ssi2.shtml
View file @
5a3b1123
File moved
test/ssi3.shtml
→
build/
test/ssi3.shtml
View file @
5a3b1123
File moved
test/ssi4.shtml
→
build/
test/ssi4.shtml
View file @
5a3b1123
File moved
test/ssi5.shtml
→
build/
test/ssi5.shtml
View file @
5a3b1123
File moved
test/ssi6.shtml
→
build/
test/ssi6.shtml
View file @
5a3b1123
File moved
test/ssi7.shtml
→
build/
test/ssi7.shtml
View file @
5a3b1123
File moved
test/ssi8.shtml
→
build/
test/ssi8.shtml
View file @
5a3b1123
File moved
test/ssi9.shtml
→
build/
test/ssi9.shtml
View file @
5a3b1123
ssi_begin
<!--#include file="../
build/
Makefile" -->
<!--#include file="../Makefile" -->
ssi_end
test/test.pl
→
build/
test/test.pl
View file @
5a3b1123
...
...
@@ -18,8 +18,8 @@ my $num_requests;
my
$dir_separator
=
on_windows
()
?
'\\'
:
'/'
;
my
$copy_cmd
=
on_windows
()
?
'copy'
:
'cp'
;
my
$test_dir_uri
=
"test_dir"
;
my
$root
=
'.
.
/test'
;
my
$abs_root
=
Cwd::
abs_path
(
dirname
(
$0
)
.
$dir_separator
.
$root
);
my
$root
=
'./test'
;
my
$abs_root
=
Cwd::
abs_path
(
dirname
(
$0
)
.
$dir_separator
);
my
$test_dir
=
$abs_root
.
$dir_separator
.
$test_dir_uri
;
#print "$test_dir\n"; exit 0;
my
$config
=
'mongoose.conf'
;
...
...
test/timeout.cgi
→
build/
test/timeout.cgi
View file @
5a3b1123
File moved
test/unit_test.c
→
build/
test/unit_test.c
View file @
5a3b1123
// Unit test for the mongoose web server.
#define USE_WEBSOCKET
#define USE_LUA
#ifndef _WIN32
#define USE_IPV6
#include <netdb.h> // For gethostbyname()
#endif
// USE_* definitions must be made before #include "mongoose.c" !
...
...
@@ -27,8 +27,66 @@
#define LISTENING_ADDR "127.0.0.1:" HTTP_PORT
static
int
static_num_tests
=
0
;
//static const char *fetch_data = "hello world!\n";
//static const char *upload_ok_message = "upload successful";
// Connects to host:port, and sends formatted request to it. Returns
// malloc-ed reply and reply length, or NULL on error. Reply contains
// everything including headers, not just the message body.
static
char
*
wget
(
const
char
*
host
,
int
port
,
int
*
len
,
const
char
*
fmt
,
...)
{
char
buf
[
2000
],
*
reply
=
NULL
;
int
request_len
,
reply_size
=
0
,
n
,
sock
=
-
1
;
struct
sockaddr_in
sin
;
struct
hostent
*
he
=
NULL
;
va_list
ap
;
if
(
host
!=
NULL
||
(
he
=
gethostbyname
(
host
))
!=
NULL
||
(
sock
=
socket
(
PF_INET
,
SOCK_STREAM
,
0
))
!=
-
1
)
{
sin
.
sin_family
=
AF_INET
;
sin
.
sin_port
=
htons
((
uint16_t
)
port
);
sin
.
sin_addr
=
*
(
struct
in_addr
*
)
he
->
h_addr_list
[
0
];
if
(
connect
(
sock
,
(
struct
sockaddr
*
)
&
sin
,
sizeof
(
sin
))
==
0
)
{
// Format and send the request.
va_start
(
ap
,
fmt
);
request_len
=
vsnprintf
(
buf
,
sizeof
(
buf
),
fmt
,
ap
);
va_end
(
ap
);
while
(
request_len
>
0
&&
(
n
=
send
(
sock
,
buf
,
request_len
,
0
))
>
0
)
{
request_len
-=
n
;
}
if
(
request_len
==
0
)
{
*
len
=
0
;
while
((
n
=
recv
(
sock
,
buf
,
sizeof
(
buf
),
0
))
>
0
)
{
if
(
*
len
+
n
<
reply_size
)
{
reply
=
realloc
(
reply
,
reply_size
+
sizeof
(
buf
));
// Leak possible
reply_size
+=
sizeof
(
buf
);
}
if
(
reply
!=
NULL
)
{
memcpy
(
reply
+
*
len
,
buf
,
n
);
*
len
+=
n
;
}
}
}
closesocket
(
sock
);
}
}
return
reply
;
}
static
char
*
read_file
(
const
char
*
path
,
int
*
size
)
{
FILE
*
fp
;
struct
stat
st
;
char
*
data
=
NULL
;
if
((
fp
=
fopen
(
path
,
"rb"
))
!=
NULL
&&
!
fstat
(
fileno
(
fp
),
&
st
))
{
*
size
=
(
int
)
st
.
st_size
;
assert
((
data
=
malloc
(
*
size
))
!=
NULL
);
assert
(
fread
(
data
,
1
,
*
size
,
fp
)
==
(
size_t
)
*
size
);
fclose
(
fp
);
}
return
data
;
}
static
const
char
*
test_parse_http_message
()
{
struct
mg_connection
ri
;
...
...
@@ -160,208 +218,7 @@ static const char *test_remove_double_dots() {
return
NULL
;
}
#if 0
static char *read_file(const char *path, int *size) {
FILE *fp;
struct stat st;
char *data = NULL;
if ((fp = fopen(path, "rb")) != NULL && !fstat(fileno(fp), &st)) {
*size = (int) st.st_size;
ASSERT((data = malloc(*size)) != NULL);
ASSERT(fread(data, 1, *size, fp) == (size_t) *size);
fclose(fp);
}
return data;
}
static void test_upload(struct mg_connection *conn, const char *orig_path,
const char *uploaded_path) {
int len1, len2;
char path[500], *p1, *p2;
FILE *fp;
ASSERT((fp = mg_upload(conn, ".", path, sizeof(path))) != NULL);
fclose(fp);
ASSERT(!strcmp(path, uploaded_path));
ASSERT((p1 = read_file(orig_path, &len1)) != NULL);
ASSERT((p2 = read_file(path, &len2)) != NULL);
ASSERT(len1 == len2);
ASSERT(memcmp(p1, p2, len1) == 0);
free(p1), free(p2);
remove(path);
}
static int event_handler(struct mg_event *event) {
struct mg_request_info *ri = event->request_info;
if (event->type == MG_REQUEST_BEGIN) {
if (!strcmp(ri->uri, "/data")) {
mg_printf(event->conn, "HTTP/1.1 200 OK\r\n"
"Content-Type: text/plain\r\n\r\n"
"%s", fetch_data);
close_connection(event->conn);
return 1;
}
if (!strcmp(ri->uri, "/zerolen")) {
char buf[100];
mg_printf(event->conn, "%s",
"HTTP/1.0 200 OK\r\nContent-Length: 2\r\n\r\nok");
printf("[%d]\n", mg_read(event->conn, buf, sizeof(buf)));
ASSERT(mg_read(event->conn, buf, sizeof(buf)) == 0);
return 1;
}
if (!strcmp(ri->uri, "/upload")) {
test_upload(event->conn, "lua_5.2.1.h", "./f1.txt");
test_upload(event->conn, "lsqlite3.c", "./f2.txt");
ASSERT(mg_upload(event->conn, ".", NULL, 0) == NULL);
mg_printf(event->conn, "HTTP/1.0 200 OK\r\n"
"Content-Type: text/plain\r\n\r\n"
"%s", upload_ok_message);
close_connection(event->conn);
return 1;
}
} else if (event->type == MG_EVENT_LOG) {
printf("%s\n", (const char *) event->event_param);
}
return 0;
}
static const char *OPTIONS[] = {
"document_root", ".",
"listening_ports", LISTENING_ADDR,
"enable_keep_alive", "yes",
"ssl_certificate", "ssl_cert.pem",
NULL,
};
static char *read_conn(struct mg_connection *conn, int *size) {
char buf[MG_BUF_LEN], *data = NULL;
int len;
*size = 0;
while ((len = mg_read(conn, buf, sizeof(buf))) > 0) {
*size += len;
ASSERT((data = realloc(data, *size)) != NULL);
memcpy(data + *size - len, buf, len);
}
return data;
}
static void test_mg_download(void) {
char *p1, *p2, ebuf[100];
int len1, len2, port = atoi(HTTPS_PORT);
struct mg_connection *conn;
struct mg_context *ctx;
ASSERT((ctx = mg_start(OPTIONS, event_handler, NULL)) != NULL);
ASSERT(mg_download(NULL, port, 0, ebuf, sizeof(ebuf), "%s", "") == NULL);
ASSERT(mg_download("localhost", 0, 0, ebuf, sizeof(ebuf), "%s", "") == NULL);
ASSERT(mg_download("localhost", port, 1, ebuf, sizeof(ebuf),
"%s", "") == NULL);
// Fetch nonexistent file, should see 404
ASSERT((conn = mg_download("localhost", port, 1, ebuf, sizeof(ebuf), "%s",
"GET /gimbec HTTP/1.0\r\n\r\n")) != NULL);
ASSERT(strcmp(conn->request_info.uri, "404") == 0);
mg_close_connection(conn);
ASSERT((conn = mg_download("google.com", 443, 1, ebuf, sizeof(ebuf), "%s",
"GET / HTTP/1.0\r\n\r\n")) != NULL);
mg_close_connection(conn);
// POST with "Content-Length: 0", must not block
ASSERT((conn = mg_download("localhost", atoi(HTTPS_PORT), 1,
ebuf, sizeof(ebuf), "%s",
"POST /zerolen HTTP/1.1\r\n"
"Content-Lengh: 0\r\n\r\n ")) != NULL);
ASSERT((p1 = read_conn(conn, &len1)) != NULL);
ASSERT(len1 = 2);
ASSERT(memcmp(p1, "ok", 2) == 0);
mg_close_connection(conn);
// Fetch main.c, should succeed
ASSERT((conn = mg_download("localhost", port, 1, ebuf, sizeof(ebuf), "%s",
"GET /main.c HTTP/1.0\r\n\r\n")) != NULL);
ASSERT(!strcmp(conn->request_info.uri, "200"));
ASSERT((p1 = read_conn(conn, &len1)) != NULL);
ASSERT((p2 = read_file("main.c", &len2)) != NULL);
ASSERT(len1 == len2);
ASSERT(memcmp(p1, p2, len1) == 0);
free(p1), free(p2);
mg_close_connection(conn);
// Test SSL redirect, IP address
ASSERT((conn = mg_download("localhost", atoi(HTTP_PORT), 0,
ebuf, sizeof(ebuf), "%s",
"GET /foo HTTP/1.1\r\n\r\n")) != NULL);
ASSERT(strcmp(conn->request_info.uri, "302") == 0);
ASSERT(strcmp(mg_get_header(conn, "Location"),
"https://127.0.0.1:" HTTPS_PORT "/foo") == 0);
mg_close_connection(conn);
// Test SSL redirect, Host:
ASSERT((conn = mg_download("localhost", atoi(HTTP_PORT), 0,
ebuf, sizeof(ebuf), "%s",
"GET /foo HTTP/1.1\r\nHost: a.b:77\n\n")) != NULL);
ASSERT(strcmp(conn->request_info.uri, "302") == 0);
ASSERT(strcmp(mg_get_header(conn, "Location"),
"https://a.b:" HTTPS_PORT "/foo") == 0);
mg_close_connection(conn);
mg_stop(ctx);
}
static int alloc_printf(char **buf, size_t size, char *fmt, ...) {
va_list ap;
va_start(ap, fmt);
return alloc_vprintf(buf, size, fmt, ap);
}
static void test_mg_upload(void) {
static const char *boundary = "OOO___MY_BOUNDARY___OOO";
struct mg_context *ctx;
struct mg_connection *conn;
char ebuf[100], buf[20], *file_data, *file2_data, *post_data;
int file_len, file2_len, post_data_len;
ASSERT((ctx = mg_start(OPTIONS, event_handler, NULL)) != NULL);
// Upload two files
ASSERT((file_data = read_file("lua_5.2.1.h", &file_len)) != NULL);
ASSERT((file2_data = read_file("lsqlite3.c", &file2_len)) != NULL);
post_data = NULL;
post_data_len = alloc_printf(&post_data, 0,
// First file
"--%s\r\n" "Content-Disposition: form-data; " "name=\"file\"; "
"filename=\"%s\"\r\n\r\n" "%.*s\r\n"
// Second file
"--%s\r\n" "Content-Disposition: form-data; " "name=\"file\"; "
"filename=\"%s\"\r\n\r\n" "%.*s\r\n"
// Final boundary
"--%s--\r\n",
boundary, "f1.txt", file_len, file_data, boundary, "f2.txt",
file2_len, file2_data, boundary);
ASSERT(post_data_len > 0);
ASSERT((conn = mg_download("localhost", atoi(HTTPS_PORT), 1,
ebuf, sizeof(ebuf),
"POST /upload HTTP/1.1\r\n"
"Content-Length: %d\r\n"
"Content-Type: multipart/form-data; "
"boundary=%s\r\n\r\n"
"%.*s", post_data_len, boundary,
post_data_len, post_data)) != NULL);
ASSERT(mg_read(conn, buf, sizeof(buf)) == (int) strlen(upload_ok_message));
ASSERT(memcmp(buf, upload_ok_message, strlen(upload_ok_message)) == 0);
mg_close_connection(conn);
mg_stop(ctx);
}
static void test_mg_get_var(void) {
static
const
char
*
test_get_var
(
void
)
{
static
const
char
*
post
[]
=
{
"a=1&&b=2&d&=&c=3%20&e="
,
"q=&st=2012%2F11%2F13+17%3A05&et=&team_id="
,
...
...
@@ -369,211 +226,25 @@ static void test_mg_get_var(void) {
};
char
buf
[
20
];
ASSERT(
mg_
get_var(post[0], strlen(post[0]), "a", buf, sizeof(buf)) == 1);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"a"
,
buf
,
sizeof
(
buf
))
==
1
);
ASSERT
(
buf
[
0
]
==
'1'
&&
buf
[
1
]
==
'\0'
);
ASSERT(
mg_
get_var(post[0], strlen(post[0]), "b", buf, sizeof(buf)) == 1);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"b"
,
buf
,
sizeof
(
buf
))
==
1
);
ASSERT
(
buf
[
0
]
==
'2'
&&
buf
[
1
]
==
'\0'
);
ASSERT(
mg_
get_var(post[0], strlen(post[0]), "c", buf, sizeof(buf)) == 2);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"c"
,
buf
,
sizeof
(
buf
))
==
2
);
ASSERT
(
buf
[
0
]
==
'3'
&&
buf
[
1
]
==
' '
&&
buf
[
2
]
==
'\0'
);
ASSERT(
mg_
get_var(post[0], strlen(post[0]), "e", buf, sizeof(buf)) == 0);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"e"
,
buf
,
sizeof
(
buf
))
==
0
);
ASSERT
(
buf
[
0
]
==
'\0'
);
ASSERT(mg_get_var(post[0], strlen(post[0]), "d", buf, sizeof(buf)) == -1);
ASSERT(mg_get_var(post[0], strlen(post[0]), "c", buf, 2) == -2);
ASSERT(mg_get_var(post[0], strlen(post[0]), "x", NULL, 10) == -2);
ASSERT(mg_get_var(post[0], strlen(post[0]), "x", buf, 0) == -2);
ASSERT(mg_get_var(post[1], strlen(post[1]), "st", buf, 16) == -2);
ASSERT(mg_get_var(post[1], strlen(post[1]), "st", buf, 17) == 16);
}
static void test_next_option(void) {
const char *p, *list = "x/8,/y**=1;2k,z";
struct vec a, b;
int i;
ASSERT(next_option(NULL, &a, &b) == NULL);
for (i = 0, p = list; (p = next_option(p, &a, &b)) != NULL; i++) {
ASSERT(i != 0 || (a.ptr == list && a.len == 3 && b.len == 0));
ASSERT(i != 1 || (a.ptr == list + 4 && a.len == 4 && b.ptr == list + 9 &&
b.len == 4));
ASSERT(i != 2 || (a.ptr == list + 14 && a.len == 1 && b.len == 0));
}
}
#ifdef USE_LUA
static void check_lua_expr(lua_State *L, const char *expr, const char *value) {
const char *v, *var_name = "myVar";
char buf[100];
snprintf(buf, sizeof(buf), "%s = %s", var_name, expr);
(void) luaL_dostring(L, buf);
lua_getglobal(L, var_name);
v = lua_tostring(L, -1);
ASSERT((value == NULL && v == NULL) ||
(value != NULL && v != NULL && !strcmp(value, v)));
}
static void test_lua(void) {
static struct mg_connection conn;
static struct mg_context ctx;
char http_request[] = "POST /foo/bar HTTP/1.1\r\n"
"Content-Length: 12\r\n"
"Connection: close\r\n\r\nhello world!";
lua_State *L = luaL_newstate();
conn.ctx = &ctx;
conn.buf = http_request;
conn.buf_size = conn.data_len = conn.num_bytes_read = strlen(http_request);
conn.request_len = parse_http_message(conn.buf, conn.data_len,
&conn.request_info);
conn.content_len = conn.data_len - conn.request_len;
prepare_lua_environment(&conn, L);
ASSERT(lua_gettop(L) == 0);
check_lua_expr(L, "'hi'", "hi");
check_lua_expr(L, "mg.request_info.request_method", "POST");
check_lua_expr(L, "mg.request_info.uri", "/foo/bar");
check_lua_expr(L, "mg.request_info.num_headers", "2");
check_lua_expr(L, "mg.request_info.remote_ip", "0");
check_lua_expr(L, "mg.request_info.http_headers['Content-Length']", "12");
check_lua_expr(L, "mg.request_info.http_headers['Connection']", "close");
(void) luaL_dostring(L, "post = mg.read()");
check_lua_expr(L, "# post", "12");
check_lua_expr(L, "post", "hello world!");
lua_close(L);
}
#endif
static void test_mg_stat(void) {
struct file file = STRUCT_FILE_INITIALIZER;
ASSERT(!mg_stat(" does not exist ", &file));
}
static void test_skip_quoted(void) {
char x[] = "a=1, b=2 c='hi \' there'", *s = x, *p;
p = skip_quoted(&s, ", ", ", ", 0);
ASSERT(p != NULL && !strcmp(p, "a=1"));
p = skip_quoted(&s, ", ", ", ", 0);
ASSERT(p != NULL && !strcmp(p, "b=2"));
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"d"
,
buf
,
sizeof
(
buf
))
==
-
1
);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"c"
,
buf
,
2
)
==
-
2
);
// TODO(lsm): fix this
#if 0
p = skip_quoted(&s, "'", ", ", '\\');
p = skip_quoted(&s, "'", ", ", '\\');
printf("[%s]\n", p);
ASSERT(p != NULL && !strcmp(p, "hi ' there"));
#endif
}
static void test_alloc_vprintf(void) {
char buf[MG_BUF_LEN], *p = buf;
ASSERT(alloc_printf(&p, sizeof(buf), "%s", "hi") == 2);
ASSERT(p == buf);
ASSERT(alloc_printf(&p, sizeof(buf), "%s", "") == 0);
ASSERT(alloc_printf(&p, sizeof(buf), "") == 0);
// Pass small buffer, make sure alloc_printf allocates
ASSERT(alloc_printf(&p, 1, "%s", "hello") == 5);
ASSERT(p != buf);
free(p);
}
static void test_request_replies(void) {
char ebuf[100];
int i, port = atoi(HTTPS_PORT);
struct mg_connection *conn;
struct mg_context *ctx;
static struct { const char *request, *reply_regex; } tests[] = {
{
"GET test/hello.txt HTTP/1.0\r\nRange: bytes=3-5\r\n\r\n",
"^HTTP/1.1 206 Partial Content"
},
{NULL, NULL},
};
ASSERT((ctx = mg_start(OPTIONS, event_handler, NULL)) != NULL);
for (i = 0; tests[i].request != NULL; i++) {
ASSERT((conn = mg_download("localhost", port, 1, ebuf, sizeof(ebuf), "%s",
tests[i].request)) != NULL);
mg_close_connection(conn);
}
mg_stop(ctx);
}
static const char *api_uri = "/?a=%20&b=&c=xx";
static int api_cb(struct mg_event *event) {
struct mg_request_info *ri = event->request_info;
char post_data[100] = "";
if (event->type == MG_REQUEST_BEGIN) {
ASSERT(event->user_data == (void *) 123);
ASSERT(ri->num_headers == 2);
ASSERT(strcmp(mg_get_header(event->conn, "host"), "blah.com") == 0);
ASSERT(mg_read(event->conn, post_data, sizeof(post_data)) == 3);
ASSERT(memcmp(post_data, "b=1", 3) == 0);
ASSERT(ri->query_string != NULL);
ASSERT(strcmp(ri->query_string, api_uri + 2) == 0);
ASSERT(ri->remote_ip > 0);
ASSERT(ri->remote_port > 0);
ASSERT(strcmp(ri->http_version, "1.0") == 0);
mg_printf(event->conn, "HTTP/1.0 200 OK\r\n\r\n");
return 1;
}
return 0;
}
static const char *test_mg_strcasestr(void) {
static const char *big1 = "abcdef";
ASSERT(mg_strcasestr("Y", "X") == NULL);
ASSERT(mg_strcasestr("Y", "y") != NULL);
ASSERT(mg_strcasestr(big1, "X") == NULL);
ASSERT(mg_strcasestr(big1, "CD") == big1 + 2);
ASSERT(mg_strcasestr("aa", "AAB") == NULL);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"x"
,
NULL
,
10
)
==
-
2
);
ASSERT
(
get_var
(
post
[
0
],
strlen
(
post
[
0
]),
"x"
,
buf
,
0
)
==
-
2
);
ASSERT
(
get_var
(
post
[
1
],
strlen
(
post
[
1
]),
"st"
,
buf
,
16
)
==
-
2
);
ASSERT
(
get_var
(
post
[
1
],
strlen
(
post
[
1
]),
"st"
,
buf
,
17
)
==
16
);
return
NULL
;
}
static void test_api_calls(void) {
char ebuf[100];
struct mg_connection *conn;
struct mg_context *ctx;
static const char *fmt = "POST %s HTTP/1.0\r\n"
"Host: blah.com\n" // More spaces before
"content-length: 3\r\n" // Lower case header name
"\r\nb=123456"; // Content size > content-length, test for mg_read()
ASSERT((ctx = mg_start(OPTIONS, api_cb, (void *) 123)) != NULL);
ASSERT((conn = mg_download("localhost", atoi(HTTPS_PORT), 1,
ebuf, sizeof(ebuf), fmt, api_uri)) != NULL);
mg_close_connection(conn);
mg_stop(ctx);
}
static void test_mg_get_cookie(void) {
char buf[20];
ASSERT(mg_get_cookie("", "foo", NULL, sizeof(buf)) == -2);
ASSERT(mg_get_cookie("", "foo", buf, 0) == -2);
ASSERT(mg_get_cookie("", "foo", buf, sizeof(buf)) == -1);
ASSERT(mg_get_cookie("", NULL, buf, sizeof(buf)) == -1);
ASSERT(mg_get_cookie("a=1; b=2; c; d", "a", buf, sizeof(buf)) == 1);
ASSERT(strcmp(buf, "1") == 0);
ASSERT(mg_get_cookie("a=1; b=2; c; d", "b", buf, sizeof(buf)) == 1);
ASSERT(strcmp(buf, "2") == 0);
ASSERT(mg_get_cookie("a=1; b=123", "b", buf, sizeof(buf)) == 3);
ASSERT(strcmp(buf, "123") == 0);
ASSERT(mg_get_cookie("a=1; b=2; c; d", "c", buf, sizeof(buf)) == -1);
}
#endif
static
const
char
*
test_url_decode
(
void
)
{
char
buf
[
100
];
...
...
@@ -645,7 +316,7 @@ static const char *test_base64_encode(void) {
return
NULL
;
}
static
const
char
*
test_mg_parse_header
()
{
static
const
char
*
test_mg_parse_header
(
void
)
{
const
char
*
str
=
"xx yy, ert=234 ii zz='aa bb', gf=
\"
xx d=1234"
;
char
buf
[
10
];
ASSERT
(
mg_parse_header
(
str
,
"yy"
,
buf
,
sizeof
(
buf
))
==
0
);
...
...
@@ -662,6 +333,61 @@ static const char *test_mg_parse_header() {
return
NULL
;
}
static
const
char
*
test_next_option
(
void
)
{
const
char
*
p
,
*
list
=
"x/8,/y**=1;2k,z"
;
struct
vec
a
,
b
;
int
i
;
ASSERT
(
next_option
(
NULL
,
&
a
,
&
b
)
==
NULL
);
for
(
i
=
0
,
p
=
list
;
(
p
=
next_option
(
p
,
&
a
,
&
b
))
!=
NULL
;
i
++
)
{
ASSERT
(
i
!=
0
||
(
a
.
ptr
==
list
&&
a
.
len
==
3
&&
b
.
len
==
0
));
ASSERT
(
i
!=
1
||
(
a
.
ptr
==
list
+
4
&&
a
.
len
==
4
&&
b
.
ptr
==
list
+
9
&&
b
.
len
==
4
));
ASSERT
(
i
!=
2
||
(
a
.
ptr
==
list
+
14
&&
a
.
len
==
1
&&
b
.
len
==
0
));
}
return
NULL
;
}
static
int
cb1
(
struct
mg_connection
*
conn
)
{
assert
(
conn
!=
NULL
);
assert
(
conn
->
server_param
!=
NULL
);
assert
(
conn
->
connection_param
==
NULL
);
assert
(
strcmp
((
char
*
)
conn
->
server_param
,
"foo"
)
==
0
);
return
1
;
}
static
const
char
*
test_requests
(
struct
mg_server
*
server
)
{
static
const
char
*
fname
=
"mongoose.c"
;
int
reply_len
,
file_len
;
char
*
reply
,
*
file_data
;
file_stat_t
st
;
ASSERT
(
stat
(
fname
,
&
st
)
==
0
);
ASSERT
(
st
.
st_size
>
0
);
ASSERT
((
file_data
=
read_file
(
fname
,
&
file_len
))
!=
NULL
);
ASSERT
(
file_len
==
st
.
st_size
);
mg_poll_server
(
server
,
0
);
return
NULL
;
}
static
const
char
*
test_server
(
void
)
{
struct
mg_server
*
server
=
mg_create_server
(
"foo"
);
ASSERT
(
server
!=
NULL
);
ASSERT
(
mg_set_option
(
server
,
"listening_port"
,
LISTENING_ADDR
)
==
NULL
);
ASSERT
(
mg_set_option
(
server
,
"document_root"
,
".."
)
==
NULL
);
mg_add_uri_handler
(
server
,
"/cb1"
,
cb1
);
do
{
const
char
*
msg
=
test_requests
(
server
);
if
(
msg
)
return
msg
;
}
while
(
0
);
mg_destroy_server
(
&
server
);
ASSERT
(
server
==
NULL
);
return
NULL
;
}
static
const
char
*
run_all_tests
(
void
)
{
RUN_TEST
(
test_should_keep_alive
);
RUN_TEST
(
test_match_prefix
);
...
...
@@ -672,21 +398,9 @@ static const char *run_all_tests(void) {
RUN_TEST
(
test_url_decode
);
RUN_TEST
(
test_base64_encode
);
RUN_TEST
(
test_mg_parse_header
);
#if 0
test_mg_strcasestr();
test_mg_download();
test_mg_get_var();
test_next_option();
test_mg_stat();
test_skip_quoted();
test_mg_upload();
test_request_replies();
test_api_calls();
test_mg_get_cookie();
#ifdef USE_LUA
test_lua();
#endif
#endif
RUN_TEST
(
test_get_var
);
RUN_TEST
(
test_next_option
);
RUN_TEST
(
test_server
);
return
NULL
;
}
...
...
test/x.php
→
build/
test/x.php
View file @
5a3b1123
File moved
test/ssi1.shtml
deleted
100644 → 0
View file @
6a9494b6
<html><pre>
ssi_begin
<!--#include file="../build/Makefile" -->
ssi_end
</pre></html>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment