From 6862128151fb78f63685a8da5575783c426d64a7 Mon Sep 17 00:00:00 2001 From: Martin Willi Date: Wed, 5 Apr 2006 12:10:50 +0000 Subject: ../svn-commit.tmp --- Source/testing/socket_test.c | 73 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 Source/testing/socket_test.c (limited to 'Source/testing/socket_test.c') diff --git a/Source/testing/socket_test.c b/Source/testing/socket_test.c new file mode 100644 index 000000000..360bf697c --- /dev/null +++ b/Source/testing/socket_test.c @@ -0,0 +1,73 @@ +/** + * @file socket_test.c + * + * @brief Tests for the socket_t class. + * + */ + +/* + * Copyright (C) 2005 Jan Hutter, Martin Willi + * Hochschule fuer Technik Rapperswil + * + * This program is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License as published by the + * Free Software Foundation; either version 2 of the License, or (at your + * option) any later version. See . + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * for more details. + */ + +#include +#include + +#include "socket_test.h" + +#include +#include + +/* + * Description in header file + */ +void test_socket(protected_tester_t *tester) +{ + int packet_count = 5; + int current; + socket_t *skt = socket_create(4500); + packet_t *pkt = packet_create(AF_INET); + char *test_string = "Testing functionality of socket_t"; + chunk_t data; + + + data.ptr = allocator_alloc(strlen(test_string) + 1); + memcpy(data.ptr,test_string,strlen(test_string) + 1); + data.len = strlen(test_string) + 1; + + /* send to previously bound socket */ + pkt->set_destination(pkt, host_create(AF_INET, "127.0.0.1", 4500)); + pkt->set_data(pkt, data); + + /* send packet_count packets */ + for (current = 0; current < packet_count; current++) + { + if (skt->send(skt, pkt) == FAILED) + { + tester->assert_true(tester, 0, "packet send"); + } + } + pkt->destroy(pkt); + + /* receive packet_count packets */ + for (current = 0; current < packet_count; current++) + { + skt->receive(skt, &pkt); + data = pkt->get_data(pkt); + tester->assert_false(tester, strcmp(test_string, data.ptr), "packet exchange"); + pkt->destroy(pkt); + } + + skt->destroy(skt); + +} -- cgit v1.2.3