[libgpiod PATCH 6/7] gpio-tools-test: Add gpioset --by-name tests
Joel Stanley
joel at jms.id.au
Thu Feb 3 15:21:33 AEDT 2022
Signed-off-by: Joel Stanley <joel at jms.id.au>
---
tools/gpio-tools-test.bats | 111 +++++++++++++++++++++++++++++++++++++
1 file changed, 111 insertions(+)
diff --git a/tools/gpio-tools-test.bats b/tools/gpio-tools-test.bats
index a5b97e1f98ee..a90c695fbc0f 100755
--- a/tools/gpio-tools-test.bats
+++ b/tools/gpio-tools-test.bats
@@ -670,6 +670,117 @@ teardown() {
output_regex_match ".*unable to request lines.*"
}
+ at test "gpioset: invalid value (by name)" {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name gpio-mockup-A-0=foobar
+
+ test "$status" -eq "1"
+ output_regex_match ".*invalid offset<->value mapping: gpio-mockup-A-0=foobar.*"
+}
+
+ at test "gpioset: invalid line syntax by name, missing =" {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name gpio-mockup-A-0foobar
+
+ test "$status" -eq "1"
+ output_regex_match ".*invalid name/value 'gpio-mockup-A-0foobar'*"
+}
+
+ at test "gpioset: invalid line syntax by name, leading =" {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name =gpio-mockup-A-0foobar
+
+ test "$status" -eq "1"
+ output_regex_match ".*unable to find '' on a gpiochip*"
+}
+
+ at test "gpioset: missing value (by name)" {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name gpio-mockup-A-0=
+
+ test "$status" -eq "1"
+ output_regex_match ".*invalid offset<->value mapping: gpio-mockup-A-0=*"
+}
+
+ at test "gpioset: invalid line name (from different gpiochip) " {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name \
+ gpio-mockup-A-0=1 \
+ gpio-mockup-A-2=0 \
+ gpio-mockup-B-3=1
+
+ test "$status" -eq "1"
+ output_regex_match ".*does not contain line 'gpio-mockup-B-3'.*"
+}
+
+ at test "gpiogst: invalid line name (non existant line on a chip) " {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name \
+ gpio-mockup-A-0=1 \
+ missing=0
+
+ test "$status" -eq "1"
+ output_regex_match ".*does not contain line 'missing'.*"
+}
+
+ at test "gpioset: invalid line name (non existant line, no chip) " {
+ gpio_mockup_probe named-lines 8 8 8
+
+ run_tool gpioset --by-name missing=1
+
+ test "$status" -eq "1"
+ output_regex_match ".*unable to find 'missing' on a gpiochip*"
+}
+
+ at test "gpioset: set lines by name and wait for SIGTERM" {
+ gpio_mockup_probe named-lines 2 2 8
+
+ coproc_run_tool gpioset --mode=signal --by-name \
+ gpio-mockup-C-3=1 \
+ gpio-mockup-C-6=1 \
+ gpio-mockup-C-7=0
+
+ gpio_mockup_check_value 2 3 1
+ gpio_mockup_check_value 2 6 1
+ gpio_mockup_check_value 2 7 0
+
+ coproc_tool_kill
+ coproc_tool_wait
+
+ test "$status" -eq "0"
+}
+
+ at test "gpioset: set lines by name using short option and wait for SIGTERM" {
+ gpio_mockup_probe named-lines 2 2 8
+
+ coproc_run_tool gpioset --mode=signal -N \
+ gpio-mockup-C-3=1 \
+ gpio-mockup-C-6=1 \
+ gpio-mockup-C-7=0
+
+ gpio_mockup_check_value 2 3 1
+ gpio_mockup_check_value 2 6 1
+ gpio_mockup_check_value 2 7 0
+
+ coproc_tool_kill
+ coproc_tool_wait
+
+ test "$status" -eq "0"
+}
+
+ at test "gpioset: no arguments (by name)" {
+ run_tool gpioset --by-name
+
+ test "$status" -eq "1"
+ output_regex_match ".*at least one line name must be specified"
+}
+
#
# gpiomon test cases
#
--
2.34.1
More information about the openbmc
mailing list