aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorWolfgang Draxinger <Wolfgang.Draxinger@physik.uni-muenchen.de>2013-06-18 21:24:59 +0200
committerWolfgang Draxinger <Wolfgang.Draxinger@physik.uni-muenchen.de>2013-06-18 21:24:59 +0200
commitc50c12e6206772273f62752c1c0091ac78698665 (patch)
tree25474d052aa1f199a43a7b730b13d9e2777ca22b /test
parent3293d9eeed04c67669c06bc745ea9ee05012cb7f (diff)
downloadlitheweb-c50c12e6206772273f62752c1c0091ac78698665.tar.gz
litheweb-c50c12e6206772273f62752c1c0091ac78698665.tar.bz2
added header processing for content type and transfer encoding - chunked
Diffstat (limited to 'test')
-rw-r--r--test/bsdsocket.c35
-rw-r--r--test/bufbsdsocket.c22
2 files changed, 39 insertions, 18 deletions
diff --git a/test/bsdsocket.c b/test/bsdsocket.c
index d4bd5a2..cb6cde2 100644
--- a/test/bsdsocket.c
+++ b/test/bsdsocket.c
@@ -80,6 +80,11 @@ int bsdsock_putch(char ch, void *data)
return bsdsock_write(1, &ch, data);
}
+int bsdsock_flush(void* data)
+{
+ return 0;
+}
+
int sockfd = -1;
void bye(void)
@@ -97,13 +102,18 @@ void rhRoot(struct picohttpRequest *req)
{
fprintf(stderr, "handling request /%s\n", req->urltail);
- char http_header[] = "HTTP/x.x 200 OK\r\nServer: picoweb\r\nContent-Type: text/html\r\n\r\n";
- http_header[5] = '0'+req->httpversion.major;
- http_header[7] = '0'+req->httpversion.minor;
- picohttpIoWrite(req->ioops, sizeof(http_header)-1, http_header);
- char http_test[] = "<html><head><title>handling request /</title></head>\n<body><a href=\"/test\">/test</a></body></html>\n";
+ req->response.contenttype = "text/html";
- picohttpIoWrite(req->ioops, sizeof(http_test)-1, http_test);
+ char http_test[] =
+"<html><head><title>handling request /</title></head><body>\n"
+"<a href=\"/test\">/test</a>"
+"<form action=\"/upload\" enctype=\"multipart/form-data\" method=\"post\">"
+"<label for=\"file\">File: </label><input type=\"file\" name=\"file\"></input>"
+"<input type=\"submit\" value=\"Upload\"></input>"
+"</form>"
+"</body></html>\n";
+
+ picohttpResponseWrite(req, sizeof(http_test)-1, http_test);
}
void rhTest(struct picohttpRequest *req)
@@ -120,6 +130,17 @@ void rhTest(struct picohttpRequest *req)
}
}
+void rhUpload(struct picohttpRequest *req)
+{
+ fprintf(stderr, "handling request /upload%s\n", req->urltail);
+
+ char http_test[] = "handling request /upload";
+ picohttpResponseWrite(req, sizeof(http_test)-1, http_test);
+ if(req->urltail) {
+ picohttpResponseWrite(req, strlen(req->urltail), req->urltail);
+ }
+}
+
int main(int argc, char *argv[])
{
sockfd = socket(AF_INET, SOCK_STREAM, 0);
@@ -170,11 +191,13 @@ int main(int argc, char *argv[])
.write = bsdsock_write,
.getch = bsdsock_getch,
.putch = bsdsock_putch,
+ .flush = bsdsock_flush,
.data = &confd
};
struct picohttpURLRoute routes[] = {
{ "/test", 0, rhTest, 16, PICOHTTP_METHOD_GET },
+ { "/upload|", 0, rhUpload, 0, PICOHTTP_METHOD_GET },
{ "/|", 0, rhRoot, 0, PICOHTTP_METHOD_GET },
{ NULL, 0, 0, 0, 0 }
};
diff --git a/test/bufbsdsocket.c b/test/bufbsdsocket.c
index 596bc3d..22a4a99 100644
--- a/test/bufbsdsocket.c
+++ b/test/bufbsdsocket.c
@@ -6,12 +6,15 @@
#include <stdio.h>
#include <errno.h>
#include <string.h>
+#include <assert.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
+#include <sys/ioctl.h>
#include <netinet/ip.h>
+#include <poll.h>
#include "../picohttp.h"
@@ -57,7 +60,7 @@ int bufbsdsock_read(size_t count, char *buf, void *data_)
assert(pfd.revents & (POLLIN | POLLPRI));
- if( -1 == ioctl(fd, FIONREAD, &avail) ) {
+ if( -1 == ioctl(data->fd, FIONREAD, &avail) ) {
perror("ioctl(FIONREAD)");
return -1;
}
@@ -66,7 +69,7 @@ int bufbsdsock_read(size_t count, char *buf, void *data_)
data->recvbuf = malloc( avail);
int r;
- while( 0 > (r = read(data->fd, data->recvbuf, avail)) )
+ while( 0 > (r = read(data->fd, data->recvbuf, avail)) ) {
if( EINTR == errno )
continue;
@@ -119,11 +122,6 @@ int bufbsdsock_flush(void *data)
return 0;
}
-int bsdsock_flush(void* data)
-{
- return 0;
-}
-
int sockfd = -1;
void bye(void)
@@ -255,11 +253,11 @@ int main(int argc, char *argv[])
}
struct picohttpIoOps ioops = {
- .read = bsdsock_read,
- .write = bsdsock_write,
- .getch = bsdsock_getch,
- .putch = bsdsock_putch,
- .flush = bsdsock_flush,
+ .read = bufbsdsock_read,
+ .write = bufbsdsock_write,
+ .getch = bufbsdsock_getch,
+ .putch = bufbsdsock_putch,
+ .flush = bufbsdsock_flush,
.data = &confd
};