libevdev/test/test-int-queue.c
Peter Hutterer 60d4f1b2ae Change to the (always intended) MIT license
Due to what must've been a copy/paste error many years ago, the license text
for libevdev wasn't actually the MIT license. Let's rectify this, it was
always MIT intended anyway.

To make this more obvious and reduce the chance of copy/paste mistakes, use
the SPDX license identifier in the various source files. The two installed
public header files have the full license text.

All contributors with copyrightable contributions have ACKed the license
change to MIT, either in the MR directly [1] or privately in reply to an
email.

[1] https://gitlab.freedesktop.org/libevdev/libevdev/-/merge_requests/69

Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Acked-by: Alexander Dahl <ada@thorsis.com>
Acked-by: Andreas Pokorny <andreas.pokorny@canonical.com>
Acked-by: Armin K <krejzi@email.com>
Acked-by: Benjamin Tissoires <btissoir@redhat.com>
Acked-by: David Herrmann <dh.herrmann@gmail.com>
Acked-by: Deepa Dinamani <deepa.kernel@gmail.com>
Acked-by: Emmanuele Bassi <ebassi@gnome.org>
Acked-by: Gaetan Nadon <memsize@videotron.ca>
Acked-by: George Thomas <georgefsthomas@gmail.com>
Acked-by: Michael Forney <mforney@mforney.org>
Acked-by: Nayan Deshmukh <nayan26deshmukh@gmail.com>
Acked-by: Niclas Zeising <zeising@daemonic.se>
Acked-by: Owen W. Taylor <otaylor@fishsoup.net>
Acked-by: Peter Seiderer <ps.report@gmx.net>
Acked-by: Ran Benita <ran234@gmail.com>
Acked-by: Rosen Penev <rosenp@gmail.com>
Acked-by: Scott Jann <sjann@knight-rider.org>
Acked-by: Thilo Schulz <thilo@tjps.eu>
Acked-by: polyphemus <rolfmorel@gmail.com>
2021-01-25 13:46:55 +10:00

338 lines
7.4 KiB
C

// SPDX-License-Identifier: MIT
/*
* Copyright © 2013 Red Hat, Inc.
*/
#include "config.h"
#include <limits.h>
#include <libevdev/libevdev-int.h>
#include "test-common.h"
START_TEST(test_queue_alloc)
{
struct libevdev dev;
int rc;
rc = queue_alloc(&dev, 0);
ck_assert_int_eq(rc, -ENOMEM);
rc = queue_alloc(&dev, 100);
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(dev.queue_size, 100);
ck_assert_int_eq(dev.queue_next, 0);
queue_free(&dev);
ck_assert_int_eq(dev.queue_size, 0);
ck_assert_int_eq(dev.queue_next, 0);
}
END_TEST
START_TEST(test_queue_sizes)
{
struct libevdev dev = {0};
queue_alloc(&dev, 0);
ck_assert_int_eq(queue_num_elements(&dev), 0);
ck_assert_int_eq(queue_num_free_elements(&dev), 0);
ck_assert_int_eq(queue_size(&dev), 0);
queue_alloc(&dev, 100);
ck_assert_int_eq(queue_num_elements(&dev), 0);
ck_assert_int_eq(queue_num_free_elements(&dev), 100);
ck_assert_int_eq(queue_size(&dev), 100);
queue_free(&dev);
ck_assert_int_eq(queue_num_elements(&dev), 0);
ck_assert_int_eq(queue_num_free_elements(&dev), 0);
ck_assert_int_eq(queue_size(&dev), 0);
}
END_TEST
START_TEST(test_queue_push)
{
struct libevdev dev = {0};
struct input_event *ev;
queue_alloc(&dev, 0);
ev = queue_push(&dev);
ck_assert(ev == NULL);
queue_alloc(&dev, 2);
ev = queue_push(&dev);
ck_assert(ev == dev.queue);
ck_assert_int_eq(queue_num_elements(&dev), 1);
ck_assert_int_eq(queue_num_free_elements(&dev), 1);
ev = queue_push(&dev);
ck_assert(ev == dev.queue + 1);
ev = queue_push(&dev);
ck_assert(ev == NULL);
queue_free(&dev);
ev = queue_push(&dev);
ck_assert(ev == NULL);
}
END_TEST
START_TEST(test_queue_pop)
{
struct libevdev dev = {0};
struct input_event ev, *e, tmp;
int rc;
queue_alloc(&dev, 0);
rc = queue_pop(&dev, &ev);
ck_assert_int_eq(rc, 1);
queue_alloc(&dev, 2);
e = queue_push(&dev);
memset(e, 0xab, sizeof(*e));
ck_assert_int_eq(queue_num_elements(&dev), 1);
ck_assert_int_eq(queue_num_free_elements(&dev), 1);
rc = queue_pop(&dev, &ev);
ck_assert_int_eq(rc, 0);
memset(&tmp, 0xab, sizeof(tmp));
rc = memcmp(&tmp, &ev, sizeof(tmp));
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(queue_num_elements(&dev), 0);
ck_assert_int_eq(queue_num_free_elements(&dev), 2);
rc = queue_pop(&dev, &ev);
ck_assert_int_eq(rc, 1);
queue_free(&dev);
}
END_TEST
START_TEST(test_queue_peek)
{
struct libevdev dev = {0};
struct input_event ev, *e, tmp;
int rc;
queue_alloc(&dev, 0);
rc = queue_peek(&dev, 0, &ev);
ck_assert_int_eq(rc, 1);
queue_alloc(&dev, 2);
e = queue_push(&dev);
memset(e, 0xab, sizeof(*e));
rc = queue_peek(&dev, 0, &ev);
ck_assert_int_eq(rc, 0);
memset(&tmp, 0xab, sizeof(tmp));
rc = memcmp(&tmp, &ev, sizeof(tmp));
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(queue_num_elements(&dev), 1);
e = queue_push(&dev);
memset(e, 0xbc, sizeof(*e));
rc = queue_peek(&dev, 1, &ev);
ck_assert_int_eq(rc, 0);
memset(&tmp, 0xbc, sizeof(tmp));
rc = memcmp(&tmp, &ev, sizeof(tmp));
ck_assert_int_eq(rc, 0);
rc = queue_peek(&dev, 0, &ev);
ck_assert_int_eq(rc, 0);
memset(&tmp, 0xab, sizeof(tmp));
rc = memcmp(&tmp, &ev, sizeof(tmp));
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(queue_num_elements(&dev), 2);
queue_free(&dev);
}
END_TEST
START_TEST(test_queue_shift)
{
struct libevdev dev = {0};
struct input_event ev, *first, *second, e1, e2;
int rc;
ck_assert_int_eq(queue_shift(&dev, &ev), 1);
queue_alloc(&dev, 10);
ck_assert_int_eq(queue_shift(&dev, &ev), 1);
first = queue_push(&dev);
ck_assert(first != NULL);
memset(first, 0xab, sizeof(*first));
e1 = *first;
second = queue_push(&dev);
ck_assert(second != NULL);
memset(second, 0x12, sizeof(*second));
e2 = *second;
rc = queue_shift(&dev, &ev);
ck_assert_int_eq(rc, 0);
rc = memcmp(&ev, &e1, sizeof(ev));
ck_assert_int_eq(rc, 0);
rc = queue_shift(&dev, &ev);
ck_assert_int_eq(rc, 0);
rc = memcmp(&ev, &e2, sizeof(ev));
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(queue_shift(&dev, &ev), 1);
queue_free(&dev);
}
END_TEST
START_TEST(test_queue_shift_multiple)
{
struct libevdev dev = {0};
struct input_event ev, *first, *second, e1, e2;
struct input_event events[5];
int rc;
ck_assert_int_eq(queue_shift_multiple(&dev, 1, &ev), 0);
ck_assert_int_eq(queue_shift_multiple(&dev, 0, &ev), 0);
queue_alloc(&dev, 10);
ck_assert_int_eq(queue_shift_multiple(&dev, 1, &ev), 0);
ck_assert_int_eq(queue_shift_multiple(&dev, 0, &ev), 0);
first = queue_push(&dev);
ck_assert(first != NULL);
memset(first, 0xab, sizeof(*first));
e1 = *first;
second = queue_push(&dev);
ck_assert(second != NULL);
memset(second, 0x12, sizeof(*second));
e2 = *second;
rc = queue_shift_multiple(&dev, 5, events);
ck_assert_int_eq(rc, 2);
rc = memcmp(&events[0], &e1, sizeof(ev));
ck_assert_int_eq(rc, 0);
rc = memcmp(&events[1], &e2, sizeof(ev));
ck_assert_int_eq(rc, 0);
first = queue_push(&dev);
ck_assert(first != NULL);
memset(first, 0xab, sizeof(*first));
e1 = *first;
second = queue_push(&dev);
ck_assert(second != NULL);
memset(second, 0x12, sizeof(*second));
e2 = *second;
rc = queue_shift_multiple(&dev, 1, events);
ck_assert_int_eq(rc, 1);
rc = memcmp(&events[0], &e1, sizeof(ev));
ck_assert_int_eq(rc, 0);
rc = queue_shift_multiple(&dev, 1, events);
ck_assert_int_eq(rc, 1);
rc = memcmp(&events[0], &e2, sizeof(ev));
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(queue_shift_multiple(&dev, 1, events), 0);
queue_free(&dev);
}
END_TEST
START_TEST(test_queue_next_element)
{
struct libevdev dev = {0};
struct input_event ev, *first, *second;
int rc;
queue_alloc(&dev, 0);
first = queue_next_element(&dev);
ck_assert(first == NULL);
queue_alloc(&dev, 2);
first = queue_next_element(&dev);
ck_assert(first != NULL);
memset(first, 0xab, sizeof(*first));
second = queue_next_element(&dev);
ck_assert(second != NULL);
memset(second, 0xbc, sizeof(*second));
/* queue_next_element does not advance, so we overwrite */
memset(&ev, 0xbc, sizeof(ev));
rc = memcmp(&ev, first, sizeof(ev));
ck_assert_int_eq(rc, 0);
ck_assert_int_eq(queue_num_elements(&dev), 0);
first = queue_next_element(&dev);
ck_assert(first != NULL);
memset(first, 0xab, sizeof(*first));
queue_set_num_elements(&dev, 1);
ck_assert_int_eq(queue_num_elements(&dev), 1);
second = queue_next_element(&dev);
ck_assert(second != NULL);
memset(second, 0xbc, sizeof(*second));
memset(&ev, 0xab, sizeof(ev));
rc = memcmp(&ev, first, sizeof(ev));
ck_assert_int_eq(rc, 0);
queue_free(&dev);
}
END_TEST
START_TEST(test_queue_set_num_elements)
{
struct libevdev dev = {0};
queue_alloc(&dev, 0);
ck_assert_int_eq(queue_set_num_elements(&dev, 1), 1);
queue_alloc(&dev, 2);
ck_assert_int_eq(queue_set_num_elements(&dev, 3), 1);
ck_assert_int_eq(queue_set_num_elements(&dev, 2), 0);
queue_free(&dev);
}
END_TEST
TEST_SUITE(queue_suite)
{
Suite *s = suite_create("Event queue");
TCase *tc = tcase_create("Queue allocation");
tcase_add_test(tc, test_queue_alloc);
tcase_add_test(tc, test_queue_sizes);
suite_add_tcase(s, tc);
tc = tcase_create("Queue push/pop/peek");
tcase_add_test(tc, test_queue_push);
tcase_add_test(tc, test_queue_pop);
tcase_add_test(tc, test_queue_peek);
suite_add_tcase(s, tc);
tc = tcase_create("Queue shift");
tcase_add_test(tc, test_queue_shift);
tcase_add_test(tc, test_queue_shift_multiple);
suite_add_tcase(s, tc);
tc = tcase_create("Queue next elem");
tcase_add_test(tc, test_queue_next_element);
tcase_add_test(tc, test_queue_set_num_elements);
suite_add_tcase(s, tc);
return s;
}