From 5692f32bcfa049fc2b5555b5a883045b217349b9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C5=99emysl=20Janouch?= Date: Thu, 9 Oct 2014 23:47:24 +0200 Subject: CMake-ify, rename to termkey2 for the time being --- tests/05read.c | 85 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 tests/05read.c (limited to 'tests/05read.c') diff --git a/tests/05read.c b/tests/05read.c new file mode 100644 index 0000000..2a5530a --- /dev/null +++ b/tests/05read.c @@ -0,0 +1,85 @@ +#include +#include +#include "../termkey.h" +#include "taplib.h" + +int +main (int argc, char *argv[]) +{ + int fd[2]; + termkey_t *tk; + termkey_key_t key; + + plan_tests (21); + + /* We'll need a real filehandle we can write/read. + * pipe () can make us one */ + pipe (fd); + + /* Sanitise this just in case */ + putenv ("TERM=vt100"); + + tk = termkey_new (fd[0], NULL, TERMKEY_FLAG_NOTERMIOS); + + is_int (termkey_get_buffer_remaining (tk), 256, + "buffer free initially 256"); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE, + "getkey yields RES_NONE when empty"); + + write (fd[1], "h", 1); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE, + "getkey yields RES_NONE before advisereadable"); + + is_int (termkey_advisereadable (tk), TERMKEY_RES_AGAIN, + "advisereadable yields RES_AGAIN after h"); + + is_int (termkey_get_buffer_remaining (tk), 255, + "buffer free 255 after advisereadable"); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY, + "getkey yields RES_KEY after h"); + + is_int (key.type, TERMKEY_TYPE_KEY, "key.type after h"); + is_int (key.code.codepoint, 'h', "key.code.codepoint after h"); + is_int (key.modifiers, 0, "key.modifiers after h"); + is_str (key.multibyte, "h", "key.multibyte after h"); + + is_int (termkey_get_buffer_remaining (tk), 256, + "buffer free 256 after getkey"); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE, + "getkey yields RES_NONE a second time"); + + write (fd[1], "\033O", 2); + termkey_advisereadable (tk); + + is_int (termkey_get_buffer_remaining (tk), 254, + "buffer free 254 after partial write"); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN, + "getkey yields RES_AGAIN after partial write"); + + write (fd[1], "C", 1); + termkey_advisereadable (tk); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY, + "getkey yields RES_KEY after Right completion"); + + is_int (key.type, TERMKEY_TYPE_KEYSYM, "key.type after Right"); + is_int (key.code.sym, TERMKEY_SYM_RIGHT, "key.code.sym after Right"); + is_int (key.modifiers, 0, "key.modifiers after Right"); + + is_int (termkey_get_buffer_remaining (tk), 256, + "buffer free 256 after completion"); + + termkey_stop (tk); + + is_int (termkey_getkey (tk, &key), TERMKEY_RES_ERROR, + "getkey yields RES_ERROR after termkey_stop ()"); + is_int (errno, EINVAL, "getkey error is EINVAL"); + + termkey_destroy (tk); + return exit_status (); +} -- cgit v1.2.3