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
b7adf9b5
Commit
b7adf9b5
authored
Dec 20, 2013
by
Sergey Lyubka
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Passing server_param to the URI callback
parent
28f7d83a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
56 additions
and
19 deletions
+56
-19
unit_test.c
build/test/unit_test.c
+52
-19
mongoose.c
mongoose.c
+4
-0
No files found.
build/test/unit_test.c
View file @
b7adf9b5
...
@@ -28,7 +28,6 @@
...
@@ -28,7 +28,6 @@
static
int
static_num_tests
=
0
;
static
int
static_num_tests
=
0
;
#if 0
// Connects to host:port, and sends formatted request to it. Returns
// Connects to host:port, and sends formatted request to it. Returns
// malloc-ed reply and reply length, or NULL on error. Reply contains
// malloc-ed reply and reply length, or NULL on error. Reply contains
// everything including headers, not just the message body.
// everything including headers, not just the message body.
...
@@ -39,8 +38,8 @@ static char *wget(const char *host, int port, int *len, const char *fmt, ...) {
...
@@ -39,8 +38,8 @@ static char *wget(const char *host, int port, int *len, const char *fmt, ...) {
struct
hostent
*
he
=
NULL
;
struct
hostent
*
he
=
NULL
;
va_list
ap
;
va_list
ap
;
if (host != NULL
||
if
(
host
!=
NULL
&&
(he = gethostbyname(host)) != NULL
||
(
he
=
gethostbyname
(
host
))
!=
NULL
&&
(
sock
=
socket
(
PF_INET
,
SOCK_STREAM
,
0
))
!=
-
1
)
{
(
sock
=
socket
(
PF_INET
,
SOCK_STREAM
,
0
))
!=
-
1
)
{
sin
.
sin_family
=
AF_INET
;
sin
.
sin_family
=
AF_INET
;
sin
.
sin_port
=
htons
((
uint16_t
)
port
);
sin
.
sin_port
=
htons
((
uint16_t
)
port
);
...
@@ -57,7 +56,7 @@ static char *wget(const char *host, int port, int *len, const char *fmt, ...) {
...
@@ -57,7 +56,7 @@ static char *wget(const char *host, int port, int *len, const char *fmt, ...) {
if
(
request_len
==
0
)
{
if
(
request_len
==
0
)
{
*
len
=
0
;
*
len
=
0
;
while
((
n
=
recv
(
sock
,
buf
,
sizeof
(
buf
),
0
))
>
0
)
{
while
((
n
=
recv
(
sock
,
buf
,
sizeof
(
buf
),
0
))
>
0
)
{
if (*len + n
<
reply_size) {
if
(
*
len
+
n
>
reply_size
)
{
reply
=
realloc
(
reply
,
reply_size
+
sizeof
(
buf
));
// Leak possible
reply
=
realloc
(
reply
,
reply_size
+
sizeof
(
buf
));
// Leak possible
reply_size
+=
sizeof
(
buf
);
reply_size
+=
sizeof
(
buf
);
}
}
...
@@ -86,7 +85,6 @@ static char *read_file(const char *path, int *size) {
...
@@ -86,7 +85,6 @@ static char *read_file(const char *path, int *size) {
}
}
return
data
;
return
data
;
}
}
#endif
static
const
char
*
test_parse_http_message
()
{
static
const
char
*
test_parse_http_message
()
{
struct
mg_connection
ri
;
struct
mg_connection
ri
;
...
@@ -360,16 +358,19 @@ static const char *test_next_option(void) {
...
@@ -360,16 +358,19 @@ static const char *test_next_option(void) {
return
NULL
;
return
NULL
;
}
}
#if 0
static
int
cb1
(
struct
mg_connection
*
conn
)
{
static
int
cb1
(
struct
mg_connection
*
conn
)
{
assert(conn != NULL);
char
buf
[
100
];
assert(conn->server_param != NULL);
assert(conn->connection_param == NULL);
// We're not sending HTTP headers here, to make testing easier
assert(strcmp((char *) conn->server_param, "foo") == 0);
snprintf
(
buf
,
sizeof
(
buf
),
"%s %s"
,
conn
->
server_param
==
NULL
?
"?"
:
(
char
*
)
conn
->
server_param
,
conn
->
connection_param
==
NULL
?
"?"
:
"!"
);
mg_write
(
conn
,
buf
,
strlen
(
buf
));
return
1
;
return
1
;
}
}
static const char *test_re
quests(struct mg_server *server
) {
static
const
char
*
test_re
gular_file
(
void
)
{
static
const
char
*
fname
=
"main.c"
;
static
const
char
*
fname
=
"main.c"
;
int
reply_len
,
file_len
;
int
reply_len
,
file_len
;
char
*
reply
,
*
file_data
;
char
*
reply
,
*
file_data
;
...
@@ -381,25 +382,57 @@ static const char *test_requests(struct mg_server *server) {
...
@@ -381,25 +382,57 @@ static const char *test_requests(struct mg_server *server) {
ASSERT
((
file_data
=
read_file
(
fname
,
&
file_len
))
!=
NULL
);
ASSERT
((
file_data
=
read_file
(
fname
,
&
file_len
))
!=
NULL
);
ASSERT
(
file_len
==
st
.
st_size
);
ASSERT
(
file_len
==
st
.
st_size
);
mg_poll_server(server, 0);
reply
=
wget
(
"127.0.0.1"
,
atoi
(
HTTP_PORT
),
&
reply_len
,
"GET /%s.c HTTP/1.0
\r\n\r\n
"
,
fname
);
ASSERT
(
reply
!=
NULL
);
ASSERT
(
reply_len
>
0
);
// TODO(lsm): test headers and content
free
(
reply
);
free
(
file_data
);
return
NULL
;
}
static
const
char
*
test_server_param
(
void
)
{
int
reply_len
;
char
*
reply
;
reply
=
wget
(
"127.0.0.1"
,
atoi
(
HTTP_PORT
),
&
reply_len
,
"%s"
,
"GET /cb1 HTTP/1.0
\r\n\r\n
"
);
ASSERT
(
reply
!=
NULL
);
ASSERT
(
reply_len
==
5
);
ASSERT
(
memcmp
(
reply
,
"foo ?"
,
5
)
==
0
);
// cb1() does not send HTTP headers
printf
(
"%d [%.*s]
\n
"
,
reply_len
,
reply_len
,
reply
);
free
(
reply
);
return
NULL
;
}
static
void
*
server_thread
(
void
*
param
)
{
int
i
;
for
(
i
=
0
;
i
<
10
;
i
++
)
mg_poll_server
((
struct
mg_server
*
)
param
,
1
);
return
NULL
;
return
NULL
;
}
}
static
const
char
*
test_server
(
void
)
{
static
const
char
*
test_server
(
void
)
{
struct
mg_server
*
server
=
mg_create_server
(
"foo"
);
struct
mg_server
*
server
=
mg_create_server
(
"foo"
);
ASSERT
(
server
!=
NULL
);
ASSERT
(
server
!=
NULL
);
ASSERT
(
mg_set_option
(
server
,
"listening_port"
,
LISTENING_ADDR
)
==
NULL
);
ASSERT
(
mg_set_option
(
server
,
"listening_port"
,
LISTENING_ADDR
)
==
NULL
);
ASSERT(mg_set_option(server, "document_root", ".
.
") == NULL);
ASSERT
(
mg_set_option
(
server
,
"document_root"
,
"."
)
==
NULL
);
mg_add_uri_handler
(
server
,
"/cb1"
,
cb1
);
mg_add_uri_handler
(
server
,
"/cb1"
,
cb1
);
do {
mg_start_thread
(
server_thread
,
server
);
const char *msg = test_requests(server);
RUN_TEST
(
test_regular_file
);
if (msg) return msg;
RUN_TEST
(
test_server_param
);
} while (0);
// TODO(lsm): come up with a better way of thread sync
sleep
(
1
);
mg_destroy_server
(
&
server
);
mg_destroy_server
(
&
server
);
ASSERT
(
server
==
NULL
);
ASSERT
(
server
==
NULL
);
return
NULL
;
return
NULL
;
}
}
#endif
static
const
char
*
run_all_tests
(
void
)
{
static
const
char
*
run_all_tests
(
void
)
{
RUN_TEST
(
test_should_keep_alive
);
RUN_TEST
(
test_should_keep_alive
);
...
@@ -413,7 +446,7 @@ static const char *run_all_tests(void) {
...
@@ -413,7 +446,7 @@ static const char *run_all_tests(void) {
RUN_TEST
(
test_mg_parse_header
);
RUN_TEST
(
test_mg_parse_header
);
RUN_TEST
(
test_get_var
);
RUN_TEST
(
test_get_var
);
RUN_TEST
(
test_next_option
);
RUN_TEST
(
test_next_option
);
//
RUN_TEST(test_server);
RUN_TEST
(
test_server
);
return
NULL
;
return
NULL
;
}
}
...
...
mongoose.c
View file @
b7adf9b5
...
@@ -1746,6 +1746,10 @@ static void call_uri_handler_if_data_is_buffered(struct connection *conn) {
...
@@ -1746,6 +1746,10 @@ static void call_uri_handler_if_data_is_buffered(struct connection *conn) {
struct
iobuf
*
loc
=
&
conn
->
local_iobuf
;
struct
iobuf
*
loc
=
&
conn
->
local_iobuf
;
struct
mg_connection
*
c
=
&
conn
->
mg_conn
;
struct
mg_connection
*
c
=
&
conn
->
mg_conn
;
// Header parsing does memset() on the whole mg_connection, nullifying
// connection_param and server_param. Set them just before calling back.
c
->
server_param
=
conn
->
server
->
server_data
;
c
->
content
=
loc
->
buf
;
c
->
content
=
loc
->
buf
;
#ifndef NO_WEBSOCKET
#ifndef NO_WEBSOCKET
if
(
conn
->
mg_conn
.
is_websocket
)
{
if
(
conn
->
mg_conn
.
is_websocket
)
{
...
...
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