mirror of
git://git.psyc.eu/libpsyc
synced 2024-08-15 03:19:02 +00:00
testServer is now testPsyc and it can handle file input as well
This commit is contained in:
parent
b3923fd4e2
commit
84056a6673
5 changed files with 70 additions and 40 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -9,7 +9,7 @@ src/match
|
||||||
test/testMatch
|
test/testMatch
|
||||||
test/testParser
|
test/testParser
|
||||||
test/testRender
|
test/testRender
|
||||||
test/testServerPsyc
|
test/testPsyc
|
||||||
test/testText
|
test/testText
|
||||||
test/isRoutingVar
|
test/isRoutingVar
|
||||||
test/getVarType
|
test/getVarType
|
||||||
|
|
|
@ -4,8 +4,8 @@ CFLAGS = -I../include -I../src -Wall -std=c99 ${OPT}
|
||||||
LDFLAGS = -L../lib
|
LDFLAGS = -L../lib
|
||||||
LOADLIBES = -lpsyc -lm
|
LOADLIBES = -lpsyc -lm
|
||||||
LOADLIBES_NET = ${LOADLIBES}
|
LOADLIBES_NET = ${LOADLIBES}
|
||||||
TARGETS = testServerPsyc testParser testMatch testRender testText isRoutingVar getVarType
|
TARGETS = testPsyc testParser testMatch testRender testText isRoutingVar getVarType
|
||||||
O = testServer.o
|
O = test.o
|
||||||
WRAPPER =
|
WRAPPER =
|
||||||
DIET = diet
|
DIET = diet
|
||||||
PORT = 4440
|
PORT = 4440
|
||||||
|
@ -20,8 +20,8 @@ endif
|
||||||
all: ${TARGETS}
|
all: ${TARGETS}
|
||||||
it: all
|
it: all
|
||||||
|
|
||||||
testServerPsyc: LOADLIBES := ${LOADLIBES_NET}
|
testPsyc: LOADLIBES := ${LOADLIBES_NET}
|
||||||
testServerPsyc: testServer.o
|
testPsyc: test.o
|
||||||
|
|
||||||
diet: WRAPPER = ${DIET}
|
diet: WRAPPER = ${DIET}
|
||||||
diet: all
|
diet: all
|
||||||
|
@ -39,8 +39,8 @@ test: ${TARGETS}
|
||||||
./testText
|
./testText
|
||||||
./isRoutingVar
|
./isRoutingVar
|
||||||
./getVarType
|
./getVarType
|
||||||
x=0; for f in packets/[0-9]*; do echo ">> $$f"; ./testParser $$f; x=$$((x+$$?)); done; exit $$x
|
x=0; for f in packets/[0-9]*; do echo ">> $$f"; ./testPsyc $$f -f | ${DIFF} -u $$f -; x=$$((x+$$?)); done; exit $$x
|
||||||
x=0; for f in packets/[0-9]*; do echo ">> $$f"; ./testParser $$f -r; x=$$((x+$$?)); done; exit $$x
|
x=0; for f in packets/[0-9]*; do echo ">> $$f"; ./testPsyc $$f -fr | ${DIFF} -u $$f -; x=$$((x+$$?)); done; exit $$x
|
||||||
|
|
||||||
.NOTPARALLEL: nettestrun
|
.NOTPARALLEL: nettestrun
|
||||||
|
|
||||||
|
@ -49,12 +49,12 @@ nettest: nettestfull nettestsplit
|
||||||
nettestrun: srvstart pkt srvkill
|
nettestrun: srvstart pkt srvkill
|
||||||
|
|
||||||
nettestfull:
|
nettestfull:
|
||||||
${MAKE} nettestrun; x=$$?; pkill -x testServerPsyc; exit $$x
|
${MAKE} nettestrun; x=$$?; pkill -x testPsyc; exit $$x
|
||||||
${MAKE} nettestrun srv_args=r; x=$$?; pkill -x testServerPsyc; exit $$x
|
${MAKE} nettestrun srv_args=r; x=$$?; pkill -x testPsyc; exit $$x
|
||||||
|
|
||||||
split_max = 10
|
split_max = 10
|
||||||
nettestsplit:
|
nettestsplit:
|
||||||
x=0; for n in `seq 1 ${split_max}`; do ${MAKE} nettestrun srv_recvbuf=$$n && ${MAKE} nettestrun srv_args=r srv_recvbuf=$$n || break; done; x=$$?; pkill -x testServerPsyc; exit $$x
|
x=0; for n in `seq 1 ${split_max}`; do ${MAKE} nettestrun srv_recvbuf=$$n && ${MAKE} nettestrun srv_args=r srv_recvbuf=$$n || break; done; x=$$?; pkill -x testPsyc; exit $$x
|
||||||
|
|
||||||
pkt:
|
pkt:
|
||||||
x=0; for f in packets/[0-9]*; do echo ">> $$f"; cat $$f | nc localhost ${PORT} | ${DIFF} -u $$f -; x=$$((x+$$?)); done; exit $$x
|
x=0; for f in packets/[0-9]*; do echo ">> $$f"; cat $$f | nc localhost ${PORT} | ${DIFF} -u $$f -; x=$$((x+$$?)); done; exit $$x
|
||||||
|
@ -66,8 +66,8 @@ pkterr:
|
||||||
for f in packets/err-*; do echo ">> $$f"; cat $$f | nc localhost ${PORT}; done
|
for f in packets/err-*; do echo ">> $$f"; cat $$f | nc localhost ${PORT}; done
|
||||||
|
|
||||||
srvstart:
|
srvstart:
|
||||||
pkill -x testServerPsyc; exit 0
|
pkill -x testPsyc; exit 0
|
||||||
./testServerPsyc ${PORT} -${srv_args} ${srv_recvbuf} &
|
./testPsyc ${PORT} -${srv_args} ${srv_recvbuf} &
|
||||||
|
|
||||||
srvkill:
|
srvkill:
|
||||||
pkill -x testServerPsyc
|
pkill -x testPsyc
|
||||||
|
|
|
@ -9,16 +9,19 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/select.h>
|
#include <sys/select.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#define __USE_POSIX
|
#define __USE_POSIX
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
|
|
||||||
#include "testServer.h"
|
#include "test.h"
|
||||||
|
|
||||||
// cmd line args
|
// cmd line args
|
||||||
extern uint8_t verbose, stats;
|
extern uint8_t verbose, stats;
|
||||||
|
@ -31,6 +34,22 @@ void *get_in_addr (struct sockaddr *sa) {
|
||||||
return &(((struct sockaddr_in6*)sa)->sin6_addr);
|
return &(((struct sockaddr_in6*)sa)->sin6_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void test_file(const char* filename) {
|
||||||
|
char buf[CONT_BUF_SIZE + RECV_BUF_SIZE]; // cont buf + recv buf: [ ccrrrr]
|
||||||
|
char *recvbuf = buf + CONT_BUF_SIZE; // recv buf: ^^^^
|
||||||
|
size_t nbytes;
|
||||||
|
|
||||||
|
int fd = open(filename, O_RDONLY);
|
||||||
|
if (fd < 0) {
|
||||||
|
perror("open");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
test_init(0);
|
||||||
|
while ((nbytes = read(fd, (void*)recvbuf, RECV_BUF_SIZE)))
|
||||||
|
test_input(0, recvbuf, nbytes);
|
||||||
|
}
|
||||||
|
|
||||||
void test_server(const char* port, size_t recv_buf_size) {
|
void test_server(const char* port, size_t recv_buf_size) {
|
||||||
char buf[CONT_BUF_SIZE + RECV_BUF_SIZE]; // cont buf + recv buf: [ ccrrrr]
|
char buf[CONT_BUF_SIZE + RECV_BUF_SIZE]; // cont buf + recv buf: [ ccrrrr]
|
||||||
char *recvbuf = buf + CONT_BUF_SIZE; // recv buf: ^^^^
|
char *recvbuf = buf + CONT_BUF_SIZE; // recv buf: ^^^^
|
||||||
|
@ -150,10 +169,12 @@ void test_server(const char* port, size_t recv_buf_size) {
|
||||||
printf("%ld ms\n", (end[i].tv_sec * 1000000 + end[i].tv_usec - start[i].tv_sec * 1000000 - start[i].tv_usec) / 1000);
|
printf("%ld ms\n", (end[i].tv_sec * 1000000 + end[i].tv_usec - start[i].tv_sec * 1000000 - start[i].tv_usec) / 1000);
|
||||||
|
|
||||||
// got error or connection closed by client
|
// got error or connection closed by client
|
||||||
if (nbytes == 0) // connection closed
|
if (nbytes == 0) { // connection closed
|
||||||
printf("# Socket %d hung up\n", i);
|
if (verbose)
|
||||||
else
|
printf("# Socket %d hung up\n", i);
|
||||||
|
} else {
|
||||||
perror("recv");
|
perror("recv");
|
||||||
|
}
|
||||||
|
|
||||||
close(i); // bye!
|
close(i); // bye!
|
||||||
FD_CLR(i, &master); // remove from master set
|
FD_CLR(i, &master); // remove from master set
|
|
@ -1,5 +1,5 @@
|
||||||
#ifndef TESTSERVER_H
|
#ifndef TEST_H
|
||||||
# define TESTSERVER_H
|
# define TEST_H
|
||||||
|
|
||||||
# define RECV_BUF_SIZE 8 * 1024
|
# define RECV_BUF_SIZE 8 * 1024
|
||||||
# define CONT_BUF_SIZE 8 * 1024
|
# define CONT_BUF_SIZE 8 * 1024
|
||||||
|
@ -8,6 +8,8 @@
|
||||||
|
|
||||||
void test_init(int i);
|
void test_init(int i);
|
||||||
int test_input(int i, char *recvbuf, size_t nbytes);
|
int test_input(int i, char *recvbuf, size_t nbytes);
|
||||||
|
|
||||||
|
void test_file(const char* filename);
|
||||||
void test_server(const char* port, size_t recv_buf_size);
|
void test_server(const char* port, size_t recv_buf_size);
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -9,30 +9,22 @@
|
||||||
#include <psyc/render.h>
|
#include <psyc/render.h>
|
||||||
#include <psyc/syntax.h>
|
#include <psyc/syntax.h>
|
||||||
|
|
||||||
#include "testServer.h"
|
#include "test.h"
|
||||||
//#include "testServer.c"
|
|
||||||
|
|
||||||
// max size for routing & entity header
|
// max size for routing & entity header
|
||||||
#define ROUTING_LINES 16
|
#define ROUTING_LINES 16
|
||||||
#define ENTITY_LINES 32
|
#define ENTITY_LINES 32
|
||||||
|
|
||||||
// cmd line args
|
// cmd line args
|
||||||
uint8_t verbose, stats;
|
uint8_t verbose, stats, file;
|
||||||
|
uint8_t routing_only, parse_multiple, no_render, progress;
|
||||||
|
|
||||||
psycParseState parsers[NUM_PARSERS];
|
psycParseState parsers[NUM_PARSERS];
|
||||||
psycPacket packets[NUM_PARSERS];
|
psycPacket packets[NUM_PARSERS];
|
||||||
psycModifier routing[NUM_PARSERS][ROUTING_LINES];
|
psycModifier routing[NUM_PARSERS][ROUTING_LINES];
|
||||||
psycModifier entity[NUM_PARSERS][ENTITY_LINES];
|
psycModifier entity[NUM_PARSERS][ENTITY_LINES];
|
||||||
psycModifier *mod = NULL;
|
|
||||||
|
|
||||||
uint8_t routing_only, parse_multiple, no_render, progress;
|
int contbytes = 0, last_ret = 0;
|
||||||
|
|
||||||
int ret, retl, contbytes = 0;
|
|
||||||
char oper;
|
|
||||||
psycString name, value, elem;
|
|
||||||
psycString *pname = NULL, *pvalue = NULL;
|
|
||||||
psycParseListState listState;
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
int main (int argc, char **argv) {
|
int main (int argc, char **argv) {
|
||||||
char *port = argc > 1 ? argv[1] : "4440";
|
char *port = argc > 1 ? argv[1] : "4440";
|
||||||
|
@ -47,10 +39,15 @@ int main (int argc, char **argv) {
|
||||||
parse_multiple = opts && memchr(opts, (int)'m', strlen(opts));
|
parse_multiple = opts && memchr(opts, (int)'m', strlen(opts));
|
||||||
no_render = opts && memchr(opts, (int)'n', strlen(opts));
|
no_render = opts && memchr(opts, (int)'n', strlen(opts));
|
||||||
progress = opts && memchr(opts, (int)'p', strlen(opts));
|
progress = opts && memchr(opts, (int)'p', strlen(opts));
|
||||||
|
file = opts && memchr(opts, (int)'f', strlen(opts));
|
||||||
size_t recv_buf_size = argc > 3 ? atoi(argv[3]) : 0;
|
size_t recv_buf_size = argc > 3 ? atoi(argv[3]) : 0;
|
||||||
|
|
||||||
test_server(port, recv_buf_size);
|
if (file)
|
||||||
return 0;
|
test_file(argv[1]);
|
||||||
|
else
|
||||||
|
test_server(port, recv_buf_size);
|
||||||
|
|
||||||
|
return last_ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline
|
static inline
|
||||||
|
@ -77,10 +74,17 @@ void test_init (int i) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int test_input (int i, char *recvbuf, size_t nbytes) {
|
int test_input (int i, char *recvbuf, size_t nbytes) {
|
||||||
int j;
|
int j, ret, retl, r;
|
||||||
char *parsebuf = recvbuf - contbytes;
|
char *parsebuf = recvbuf - contbytes;
|
||||||
char sendbuf[SEND_BUF_SIZE];
|
char sendbuf[SEND_BUF_SIZE];
|
||||||
|
|
||||||
|
char oper;
|
||||||
|
psycString name, value, elem;
|
||||||
|
psycString *pname = NULL, *pvalue = NULL;
|
||||||
|
psycModifier *mod = NULL;
|
||||||
|
psycParseListState listState;
|
||||||
|
size_t len;
|
||||||
|
|
||||||
psyc_setParseBuffer2(&parsers[i], parsebuf, contbytes + nbytes);
|
psyc_setParseBuffer2(&parsers[i], parsebuf, contbytes + nbytes);
|
||||||
contbytes = 0;
|
contbytes = 0;
|
||||||
oper = 0;
|
oper = 0;
|
||||||
|
@ -88,7 +92,7 @@ int test_input (int i, char *recvbuf, size_t nbytes) {
|
||||||
value.length = 0;
|
value.length = 0;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
ret = psyc_parse(&parsers[i], &oper, &name, &value);
|
ret = last_ret = psyc_parse(&parsers[i], &oper, &name, &value);
|
||||||
if (verbose >= 2)
|
if (verbose >= 2)
|
||||||
printf("# ret = %d\n", ret);
|
printf("# ret = %d\n", ret);
|
||||||
|
|
||||||
|
@ -130,7 +134,7 @@ int test_input (int i, char *recvbuf, size_t nbytes) {
|
||||||
if (verbose)
|
if (verbose)
|
||||||
printf("# Done parsing.\n");
|
printf("# Done parsing.\n");
|
||||||
else if (progress)
|
else if (progress)
|
||||||
write(1, ".", 1);
|
r = write(1, ".", 1);
|
||||||
if (!parse_multiple) // parse multiple packets?
|
if (!parse_multiple) // parse multiple packets?
|
||||||
ret = -1;
|
ret = -1;
|
||||||
|
|
||||||
|
@ -146,12 +150,15 @@ int test_input (int i, char *recvbuf, size_t nbytes) {
|
||||||
psyc_setPacketLength(&packets[i]);
|
psyc_setPacketLength(&packets[i]);
|
||||||
|
|
||||||
if (psyc_render(&packets[i], sendbuf, SEND_BUF_SIZE) == PSYC_RENDER_SUCCESS) {
|
if (psyc_render(&packets[i], sendbuf, SEND_BUF_SIZE) == PSYC_RENDER_SUCCESS) {
|
||||||
if (send(i, sendbuf, packets[i].length, 0) == -1) {
|
if (file && write(1, sendbuf, packets[i].length) == -1) {
|
||||||
perror("send error");
|
perror("write");
|
||||||
|
ret = -1;
|
||||||
|
} else if (!file && send(i, sendbuf, packets[i].length, 0) == -1) {
|
||||||
|
perror("send");
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
perror("render error");
|
printf("# Render error");
|
||||||
ret = -1;
|
ret = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -299,7 +306,7 @@ int test_input (int i, char *recvbuf, size_t nbytes) {
|
||||||
while (ret > 0);
|
while (ret > 0);
|
||||||
|
|
||||||
if (progress)
|
if (progress)
|
||||||
write(1, " ", 1);
|
r = write(1, " ", 1);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
Loading…
Reference in a new issue