diff options
| author | Paul LeoNerd Evans <leonerd@leonerd.org.uk> | 2011-03-31 12:47:09 +0100 | 
|---|---|---|
| committer | Paul LeoNerd Evans <leonerd@leonerd.org.uk> | 2011-03-31 12:47:09 +0100 | 
| commit | be153dc5ee8c9f016c1a1014329dcd44450f78a1 (patch) | |
| tree | e1228a5404bd070d025e287334bb98b427cbd142 /t/02getkey.c | |
| parent | 0ea0fb331b62a6239090f8d840fc0821d157a67c (diff) | |
| download | termo-be153dc5ee8c9f016c1a1014329dcd44450f78a1.tar.gz termo-be153dc5ee8c9f016c1a1014329dcd44450f78a1.tar.xz termo-be153dc5ee8c9f016c1a1014329dcd44450f78a1.zip  | |
Added some unit testing for termkey_getkey(3) and friends
Diffstat (limited to 't/02getkey.c')
| -rw-r--r-- | t/02getkey.c | 60 | 
1 files changed, 60 insertions, 0 deletions
diff --git a/t/02getkey.c b/t/02getkey.c new file mode 100644 index 0000000..7561a1a --- /dev/null +++ b/t/02getkey.c @@ -0,0 +1,60 @@ +#include <stdio.h> +#include "termkey.h" +#include "taplib.h" + +int main(int argc, char *argv[]) +{ +  int        fd[2]; +  TermKey   *tk; +  TermKeyKey key; + +  plan_tests(19); + +  pipe(fd); + +  /* Sanitise this just in case */ +  putenv("TERM=vt100"); + +  tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS); + +  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_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after h"); + +  is_int(key.type,        TERMKEY_TYPE_UNICODE, "key.type after h"); +  is_int(key.code.number, 'h',                  "key.code.number after h"); +  is_int(key.modifiers,   0,                    "key.modifiers after h"); +  is_str(key.utf8,        "h",                  "key.utf8 after h"); + +  is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE a second time"); + +  write(fd[1], "\x01", 1); + +  is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after C-a"); + +  is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after C-a"); + +  is_int(key.type,        TERMKEY_TYPE_UNICODE, "key.type after C-a"); +  is_int(key.code.number, 'a',                  "key.code.number after C-a"); +  is_int(key.modifiers,   TERMKEY_KEYMOD_CTRL,  "key.modifiers after C-a"); + +  write(fd[1], "\eOA", 3); + +  is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after Up"); + +  is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Up"); + +  is_int(key.type,        TERMKEY_TYPE_KEYSYM,  "key.type after Up"); +  is_int(key.code.sym,    TERMKEY_SYM_UP,       "key.code.sym after Up"); +  is_int(key.modifiers,   0,                    "key.modifiers after Up"); + +  termkey_destroy(tk); + +  return exit_status(); +}  | 
