mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-12-22 17:34:54 +01:00
test/hex-xcode: new test binary
This program is used both as a test-bed/unit-tester for ../util/hex-escape.c, and also as a utility in future tests of dump and restore.
This commit is contained in:
parent
902f2e19bd
commit
4216e830e9
4 changed files with 122 additions and 2 deletions
1
test/.gitignore
vendored
1
test/.gitignore
vendored
|
@ -3,4 +3,5 @@ corpus.mail
|
||||||
smtp-dummy
|
smtp-dummy
|
||||||
symbol-test
|
symbol-test
|
||||||
arg-test
|
arg-test
|
||||||
|
hex-xcode
|
||||||
tmp.*
|
tmp.*
|
||||||
|
|
|
@ -13,6 +13,9 @@ smtp_dummy_modules = $(smtp_dummy_srcs:.c=.o)
|
||||||
$(dir)/arg-test: $(dir)/arg-test.o command-line-arguments.o util/libutil.a
|
$(dir)/arg-test: $(dir)/arg-test.o command-line-arguments.o util/libutil.a
|
||||||
$(call quiet,CC) -I. $^ -o $@
|
$(call quiet,CC) -I. $^ -o $@
|
||||||
|
|
||||||
|
$(dir)/hex-xcode: $(dir)/hex-xcode.o command-line-arguments.o util/libutil.a
|
||||||
|
$(call quiet,CC) -I. $^ -o $@ -ltalloc
|
||||||
|
|
||||||
$(dir)/smtp-dummy: $(smtp_dummy_modules)
|
$(dir)/smtp-dummy: $(smtp_dummy_modules)
|
||||||
$(call quiet,CC) $^ -o $@
|
$(call quiet,CC) $^ -o $@
|
||||||
|
|
||||||
|
@ -24,8 +27,13 @@ $(dir)/parse-time: $(dir)/parse-time.o parse-time-string/parse-time-string.o
|
||||||
|
|
||||||
.PHONY: test check
|
.PHONY: test check
|
||||||
|
|
||||||
test-binaries: $(dir)/arg-test $(dir)/smtp-dummy $(dir)/symbol-test \
|
TEST_BINARIES=$(dir)/arg-test \
|
||||||
$(dir)/parse-time
|
$(dir)/hex-xcode \
|
||||||
|
$(dir)/parse-time \
|
||||||
|
$(dir)/smtp-dummy \
|
||||||
|
$(dir)/symbol-test
|
||||||
|
|
||||||
|
test-binaries: $(TEST_BINARIES)
|
||||||
|
|
||||||
test: all test-binaries
|
test: all test-binaries
|
||||||
@${dir}/notmuch-test $(OPTIONS)
|
@${dir}/notmuch-test $(OPTIONS)
|
||||||
|
@ -36,5 +44,6 @@ SRCS := $(SRCS) $(smtp_dummy_srcs)
|
||||||
CLEAN := $(CLEAN) $(dir)/smtp-dummy $(dir)/smtp-dummy.o \
|
CLEAN := $(CLEAN) $(dir)/smtp-dummy $(dir)/smtp-dummy.o \
|
||||||
$(dir)/symbol-test $(dir)/symbol-test.o \
|
$(dir)/symbol-test $(dir)/symbol-test.o \
|
||||||
$(dir)/arg-test $(dir)/arg-test.o \
|
$(dir)/arg-test $(dir)/arg-test.o \
|
||||||
|
$(dir)/hex-xcode $(dir)/hex-xcode.o \
|
||||||
$(dir)/parse-time $(dir)/parse-time.o \
|
$(dir)/parse-time $(dir)/parse-time.o \
|
||||||
$(dir)/corpus.mail $(dir)/test-results $(dir)/tmp.*
|
$(dir)/corpus.mail $(dir)/test-results $(dir)/tmp.*
|
||||||
|
|
|
@ -56,6 +56,7 @@ tests_in_suite=$(for i in $TESTS; do echo $i; done | sort)
|
||||||
available=$(find "$TEST_DIRECTORY" -maxdepth 1 -type f -perm +111 \
|
available=$(find "$TEST_DIRECTORY" -maxdepth 1 -type f -perm +111 \
|
||||||
! -name aggregate-results.sh \
|
! -name aggregate-results.sh \
|
||||||
! -name arg-test \
|
! -name arg-test \
|
||||||
|
! -name hex-xcode \
|
||||||
! -name notmuch-test \
|
! -name notmuch-test \
|
||||||
! -name parse-time \
|
! -name parse-time \
|
||||||
! -name smtp-dummy \
|
! -name smtp-dummy \
|
||||||
|
|
109
test/hex-xcode.c
Normal file
109
test/hex-xcode.c
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
/* No, nothing to to with IDE from Apple Inc.
|
||||||
|
* testbed for ../util/hex-escape.c.
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* hex-xcode [--direction=(encode|decode)] [--omit-newline] < file
|
||||||
|
* hex-xcode [--direction=(encode|decode)] [--omit-newline] [--in-place] arg1 arg2 arg3 ...
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "notmuch-client.h"
|
||||||
|
#include "hex-escape.h"
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
enum direction {
|
||||||
|
ENCODE,
|
||||||
|
DECODE
|
||||||
|
};
|
||||||
|
|
||||||
|
static int inplace = FALSE;
|
||||||
|
|
||||||
|
static int
|
||||||
|
xcode (void *ctx, enum direction dir, char *in, char **buf_p, size_t *size_p)
|
||||||
|
{
|
||||||
|
hex_status_t status;
|
||||||
|
|
||||||
|
if (dir == ENCODE)
|
||||||
|
status = hex_encode (ctx, in, buf_p, size_p);
|
||||||
|
else
|
||||||
|
if (inplace) {
|
||||||
|
status = hex_decode_inplace (in);
|
||||||
|
*buf_p = in;
|
||||||
|
*size_p = strlen(in);
|
||||||
|
} else {
|
||||||
|
status = hex_decode (ctx, in, buf_p, size_p);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status == HEX_SUCCESS)
|
||||||
|
fputs (*buf_p, stdout);
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main (int argc, char **argv)
|
||||||
|
{
|
||||||
|
|
||||||
|
enum direction dir = DECODE;
|
||||||
|
int omit_newline = FALSE;
|
||||||
|
|
||||||
|
notmuch_opt_desc_t options[] = {
|
||||||
|
{ NOTMUCH_OPT_KEYWORD, &dir, "direction", 'd',
|
||||||
|
(notmuch_keyword_t []){ { "encode", ENCODE },
|
||||||
|
{ "decode", DECODE },
|
||||||
|
{ 0, 0 } } },
|
||||||
|
{ NOTMUCH_OPT_BOOLEAN, &omit_newline, "omit-newline", 'n', 0 },
|
||||||
|
{ NOTMUCH_OPT_BOOLEAN, &inplace, "in-place", 'i', 0 },
|
||||||
|
{ 0, 0, 0, 0, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
int opt_index = parse_arguments (argc, argv, options, 1);
|
||||||
|
|
||||||
|
if (opt_index < 0)
|
||||||
|
exit (1);
|
||||||
|
|
||||||
|
void *ctx = talloc_new (NULL);
|
||||||
|
|
||||||
|
char *line = NULL;
|
||||||
|
size_t line_size;
|
||||||
|
ssize_t line_len;
|
||||||
|
|
||||||
|
char *buffer = NULL;
|
||||||
|
size_t buf_size = 0;
|
||||||
|
|
||||||
|
notmuch_bool_t read_stdin = TRUE;
|
||||||
|
|
||||||
|
for (; opt_index < argc; opt_index++) {
|
||||||
|
|
||||||
|
if (xcode (ctx, dir, argv[opt_index],
|
||||||
|
&buffer, &buf_size) != HEX_SUCCESS)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
if (! omit_newline)
|
||||||
|
putchar ('\n');
|
||||||
|
|
||||||
|
read_stdin = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! read_stdin)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
while ((line_len = getline (&line, &line_size, stdin)) != -1) {
|
||||||
|
|
||||||
|
chomp_newline (line);
|
||||||
|
|
||||||
|
if (xcode (ctx, dir, line, &buffer, &buf_size) != HEX_SUCCESS)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
if (! omit_newline)
|
||||||
|
putchar ('\n');
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (line)
|
||||||
|
free (line);
|
||||||
|
|
||||||
|
talloc_free (ctx);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in a new issue