X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Ftest%2Ftest-ring.c;fp=src%2Ftest%2Ftest-ring.c;h=880815811cad056dc17e3044f51057a26504fb10;hb=e0dd92729e68e0005866a890d8209ddcf3568805;hp=0000000000000000000000000000000000000000;hpb=625e870b4fb7ff4caf4d8a4614e9bda7c174b291;p=elogind.git diff --git a/src/test/test-ring.c b/src/test/test-ring.c new file mode 100644 index 000000000..880815811 --- /dev/null +++ b/src/test/test-ring.c @@ -0,0 +1,135 @@ +/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ + +/*** + This file is part of systemd. + + Copyright 2014 David Herrmann + + systemd is free software; you can redistribute it and/or modify it + under the terms of the GNU Lesser General Public License as published by + the Free Software Foundation; either version 2.1 of the License, or + (at your option) any later version. + + systemd 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 + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public License + along with systemd; If not, see . +***/ + +#include +#include +#include +#include +#include + +#include "def.h" +#include "ring.h" +#include "util.h" + +static void test_ring(void) { + static const char buf[8192]; + struct ring r; + size_t l; + struct iovec vec[2]; + int s; + + memset(&r, 0, sizeof(r)); + + l = ring_peek(&r, vec); + assert_se(l == 0); + + s = ring_push(&r, buf, 2048); + assert_se(!s); + assert_se(ring_get_size(&r) == 2048); + + l = ring_peek(&r, vec); + assert_se(l == 1); + assert_se(vec[0].iov_len == 2048); + assert_se(!memcmp(vec[0].iov_base, buf, vec[0].iov_len)); + assert_se(ring_get_size(&r) == 2048); + + ring_pull(&r, 2048); + assert_se(ring_get_size(&r) == 0); + + l = ring_peek(&r, vec); + assert_se(l == 0); + assert_se(ring_get_size(&r) == 0); + + s = ring_push(&r, buf, 2048); + assert_se(!s); + assert_se(ring_get_size(&r) == 2048); + + l = ring_peek(&r, vec); + assert_se(l == 1); + assert_se(vec[0].iov_len == 2048); + assert_se(!memcmp(vec[0].iov_base, buf, vec[0].iov_len)); + assert_se(ring_get_size(&r) == 2048); + + s = ring_push(&r, buf, 1); + assert_se(!s); + assert_se(ring_get_size(&r) == 2049); + + l = ring_peek(&r, vec); + assert_se(l == 2); + assert_se(vec[0].iov_len == 2048); + assert_se(vec[1].iov_len == 1); + assert_se(!memcmp(vec[0].iov_base, buf, vec[0].iov_len)); + assert_se(!memcmp(vec[1].iov_base, buf, vec[1].iov_len)); + assert_se(ring_get_size(&r) == 2049); + + ring_pull(&r, 2048); + assert_se(ring_get_size(&r) == 1); + + l = ring_peek(&r, vec); + assert_se(l == 1); + assert_se(vec[0].iov_len == 1); + assert_se(!memcmp(vec[0].iov_base, buf, vec[0].iov_len)); + assert_se(ring_get_size(&r) == 1); + + ring_pull(&r, 1); + assert_se(ring_get_size(&r) == 0); + + s = ring_push(&r, buf, 2048); + assert_se(!s); + assert_se(ring_get_size(&r) == 2048); + + s = ring_push(&r, buf, 2049); + assert_se(!s); + assert_se(ring_get_size(&r) == 4097); + + l = ring_peek(&r, vec); + assert_se(l == 1); + assert_se(vec[0].iov_len == 4097); + assert_se(!memcmp(vec[0].iov_base, buf, vec[0].iov_len)); + assert_se(ring_get_size(&r) == 4097); + + ring_pull(&r, 1); + assert_se(ring_get_size(&r) == 4096); + + s = ring_push(&r, buf, 4096); + assert_se(!s); + assert_se(ring_get_size(&r) == 8192); + + l = ring_peek(&r, vec); + assert_se(l == 2); + assert_se(vec[0].iov_len == 8191); + assert_se(vec[1].iov_len == 1); + assert_se(!memcmp(vec[0].iov_base, buf, vec[0].iov_len)); + assert_se(!memcmp(vec[1].iov_base, buf, vec[1].iov_len)); + assert_se(ring_get_size(&r) == 8192); + + ring_clear(&r); + assert_se(ring_get_size(&r) == 0); +} + +int main(int argc, char *argv[]) { + log_parse_environment(); + log_open(); + + test_ring(); + + return 0; +}