From caf557a2ba666ad87a1ebd5b40750feaf1bd631f Mon Sep 17 00:00:00 2001 From: Lukas Fleischer Date: Tue, 14 Jan 2014 22:25:45 +0100 Subject: [PATCH] t0111: Add basic tests for Lua filters * Validate the email filter by manipulating stdin. Additional checks for all the arguments can be added in a later patch. * Add the exec prefix to all informational messages. * Rename the filter repository to filter-exec. The Git repository itself is not renamed since it can be shared amongst all filter types. * In the filter checks, check whether all arguments are passed properly instead of validating the buffer/stdin only. Signed-off-by: Lukas Fleischer --- tests/filters/capitalize-argv1.sh | 3 -- tests/filters/capitalize-buffer.lua | 17 ++++++++++ tests/filters/capitalize-stdin.sh | 1 + tests/setup.sh | 13 ++++++-- tests/t0111-filter.sh | 51 +++++++++++++++-------------- 5 files changed, 56 insertions(+), 29 deletions(-) delete mode 100755 tests/filters/capitalize-argv1.sh create mode 100644 tests/filters/capitalize-buffer.lua diff --git a/tests/filters/capitalize-argv1.sh b/tests/filters/capitalize-argv1.sh deleted file mode 100755 index 2ea0098..0000000 --- a/tests/filters/capitalize-argv1.sh +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/sh - -echo "$1" | tr '[:lower:]' '[:upper:]' diff --git a/tests/filters/capitalize-buffer.lua b/tests/filters/capitalize-buffer.lua new file mode 100644 index 0000000..1f15c93 --- /dev/null +++ b/tests/filters/capitalize-buffer.lua @@ -0,0 +1,17 @@ +function filter_open(...) + buffer = "" + for i = 1, select("#", ...) do + buffer = buffer .. select(i, ...) .. " " + end +end + +function filter_close() + html(buffer) + return 0 +end + +function filter_write(str) + buffer = buffer .. string.upper(str) +end + + diff --git a/tests/filters/capitalize-stdin.sh b/tests/filters/capitalize-stdin.sh index c9f4719..da6f7a1 100755 --- a/tests/filters/capitalize-stdin.sh +++ b/tests/filters/capitalize-stdin.sh @@ -1,3 +1,4 @@ #!/bin/sh +[ "$#" -gt 0 ] && printf "%s " "$*" tr '[:lower:]' '[:upper:]' diff --git a/tests/setup.sh b/tests/setup.sh index 861f48a..12c97f5 100755 --- a/tests/setup.sh +++ b/tests/setup.sh @@ -125,14 +125,23 @@ repo.url=with space repo.path=$PWD/repos/with space/.git repo.desc=spaced repo -repo.url=filter +repo.url=filter-exec repo.path=$PWD/repos/filter/.git repo.desc=filtered repo repo.about-filter=exec:$FILTER_DIRECTORY/capitalize-stdin.sh repo.commit-filter=exec:$FILTER_DIRECTORY/capitalize-stdin.sh -repo.email-filter=exec:$FILTER_DIRECTORY/capitalize-argv1.sh +repo.email-filter=exec:$FILTER_DIRECTORY/capitalize-stdin.sh repo.source-filter=exec:$FILTER_DIRECTORY/capitalize-stdin.sh repo.readme=master:a+b + +repo.url=filter-lua +repo.path=$PWD/repos/filter/.git +repo.desc=filtered repo +repo.about-filter=lua:$FILTER_DIRECTORY/capitalize-buffer.lua +repo.commit-filter=lua:$FILTER_DIRECTORY/capitalize-buffer.lua +repo.email-filter=lua:$FILTER_DIRECTORY/capitalize-buffer.lua +repo.source-filter=lua:$FILTER_DIRECTORY/capitalize-buffer.lua +repo.readme=master:a+b EOF } diff --git a/tests/t0111-filter.sh b/tests/t0111-filter.sh index 2f99880..c89020a 100755 --- a/tests/t0111-filter.sh +++ b/tests/t0111-filter.sh @@ -3,36 +3,39 @@ test_description='Check filtered content' . ./setup.sh -test_expect_success 'generate filter/tree/a%2bb' ' - cgit_url "filter/tree/a%2bb" >tmp -' +for prefix in exec lua +do + test_expect_success "generate filter-$prefix/tree/a%2bb" " + cgit_url 'filter-$prefix/tree/a%2bb' >tmp + " -test_expect_success 'check whether the source filter works' ' - grep "HELLO$" tmp -' + test_expect_success "check whether the $prefix source filter works" ' + grep "a+b HELLO$" tmp + ' -test_expect_success 'generate filter/about/' ' - cgit_url "filter/about/" >tmp -' + test_expect_success "generate filter-$prefix/about/" " + cgit_url 'filter-$prefix/about/' >tmp + " -test_expect_success 'check whether the about filter works' ' - grep "
HELLO$" tmp -' + test_expect_success "check whether the $prefix about filter works" ' + grep "
a+b HELLO$" tmp + ' -test_expect_success 'generate filter/commit/' ' - cgit_url "filter/commit/" >tmp -' + test_expect_success "generate filter-$prefix/commit/" " + cgit_url 'filter-$prefix/commit/' >tmp + " -test_expect_success 'check whether the commit filter works' ' - grep "
ADD A+B" tmp -' + test_expect_success "check whether the $prefix commit filter works" ' + grep "
ADD A+B" tmp + ' -test_expect_success 'check whether the email filter works for authors' ' - grep "" tmp -' + test_expect_success "check whether the $prefix email filter works for authors" ' + grep "A U THOR <AUTHOR@EXAMPLE.COM>" tmp + ' -test_expect_success 'check whether the email filter works for committers' ' - grep "" tmp -' + test_expect_success "check whether the $prefix email filter works for committers" ' + grep "C O MITTER <COMMITTER@EXAMPLE.COM>" tmp + ' +done test_done