e9ad3f
From e0bc051a52bccdbd17ada7ab974b1c32d25ac7c1 Mon Sep 17 00:00:00 2001
e9ad3f
From: Eric Garver <eric@garver.life>
e9ad3f
Date: Mon, 8 Feb 2021 14:53:38 -0500
e9ad3f
Subject: [PATCH 12/22] test(dbus): direct: add coverage for signatures
e9ad3f
e9ad3f
(cherry picked from commit 4673e0e55353c3f0243035f47d7c2832db9928e4)
e9ad3f
(cherry picked from commit 1b1b27ec0c19046ef041d465e44c81ad0f675fc9)
e9ad3f
---
e9ad3f
 src/tests/dbus/dbus.at   |   1 +
e9ad3f
 src/tests/dbus/direct.at | 348 +++++++++++++++++++++++++++++++++++++++
e9ad3f
 2 files changed, 349 insertions(+)
e9ad3f
 create mode 100644 src/tests/dbus/direct.at
e9ad3f
e9ad3f
diff --git a/src/tests/dbus/dbus.at b/src/tests/dbus/dbus.at
e9ad3f
index 5f7b6cbdc108..a9707f825041 100644
e9ad3f
--- a/src/tests/dbus/dbus.at
e9ad3f
+++ b/src/tests/dbus/dbus.at
e9ad3f
@@ -9,3 +9,4 @@ m4_include([dbus/policy_permanent_signatures.at])
e9ad3f
 m4_include([dbus/policy_runtime_signatures.at])
e9ad3f
 m4_include([dbus/policy_permanent_functional.at])
e9ad3f
 m4_include([dbus/policy_runtime_functional.at])
e9ad3f
+m4_include([dbus/direct.at])
e9ad3f
diff --git a/src/tests/dbus/direct.at b/src/tests/dbus/direct.at
e9ad3f
new file mode 100644
e9ad3f
index 000000000000..fe92db6bb510
e9ad3f
--- /dev/null
e9ad3f
+++ b/src/tests/dbus/direct.at
e9ad3f
@@ -0,0 +1,348 @@
e9ad3f
+FWD_START_TEST([dbus api - direct signatures])
e9ad3f
+AT_KEYWORDS(dbus direct)
e9ad3f
+
e9ad3f
+dnl ###############################
e9ad3f
+dnl ########## runtime ############
e9ad3f
+dnl ###############################
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="addChain"]]], 0, [dnl
e9ad3f
+    <method name="addChain">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="addPassthrough"]]], 0, [dnl
e9ad3f
+    <method name="addPassthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="addRule"]]], 0, [dnl
e9ad3f
+    <method name="addRule">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="in" name="priority" type="i"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="getAllChains"]]], 0, [dnl
e9ad3f
+    <method name="getAllChains">
e9ad3f
+        <arg direction="out" type="a(sss)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="getAllPassthroughs"]]], 0, [dnl
e9ad3f
+    <method name="getAllPassthroughs">
e9ad3f
+        <arg direction="out" type="a(sas)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="getAllRules"]]], 0, [dnl
e9ad3f
+    <method name="getAllRules">
e9ad3f
+        <arg direction="out" type="a(sssias)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="getChains"]]], 0, [dnl
e9ad3f
+    <method name="getChains">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="out" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="getPassthroughs"]]], 0, [dnl
e9ad3f
+    <method name="getPassthroughs">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="out" type="aas"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="getRules"]]], 0, [dnl
e9ad3f
+    <method name="getRules">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="out" type="a(ias)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="passthrough"]]], 0, [dnl
e9ad3f
+    <method name="passthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+        <arg direction="out" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="queryChain"]]], 0, [dnl
e9ad3f
+    <method name="queryChain">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="out" type="b"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="queryPassthrough"]]], 0, [dnl
e9ad3f
+    <method name="queryPassthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+        <arg direction="out" type="b"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="queryRule"]]], 0, [dnl
e9ad3f
+    <method name="queryRule">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="in" name="priority" type="i"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+        <arg direction="out" type="b"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="removeAllPassthroughs"]]], 0, [dnl
e9ad3f
+    <method name="removeAllPassthroughs">
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="removeChain"]]], 0, [dnl
e9ad3f
+    <method name="removeChain">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="removePassthrough"]]], 0, [dnl
e9ad3f
+    <method name="removePassthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="removeRule"]]], 0, [dnl
e9ad3f
+    <method name="removeRule">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="in" name="priority" type="i"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//method[@name="removeRules"]]], 0, [dnl
e9ad3f
+    <method name="removeRules">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//signal[@name="ChainAdded"]]], 0, [dnl
e9ad3f
+    <signal name="ChainAdded">
e9ad3f
+        <arg name="ipv" type="s"></arg>
e9ad3f
+        <arg name="table" type="s"></arg>
e9ad3f
+        <arg name="chain" type="s"></arg>
e9ad3f
+    </signal>  
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//signal[@name="ChainRemoved"]]], 0, [dnl
e9ad3f
+    <signal name="ChainRemoved">
e9ad3f
+        <arg name="ipv" type="s"></arg>
e9ad3f
+        <arg name="table" type="s"></arg>
e9ad3f
+        <arg name="chain" type="s"></arg>
e9ad3f
+    </signal>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//signal[@name="PassthroughAdded"]]], 0, [dnl
e9ad3f
+    <signal name="PassthroughAdded">
e9ad3f
+        <arg name="ipv" type="s"></arg>
e9ad3f
+        <arg name="args" type="as"></arg>
e9ad3f
+    </signal>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//signal[@name="PassthroughRemoved"]]], 0, [dnl
e9ad3f
+    <signal name="PassthroughRemoved">
e9ad3f
+        <arg name="ipv" type="s"></arg>
e9ad3f
+        <arg name="args" type="as"></arg>
e9ad3f
+    </signal>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//signal[@name="RuleAdded"]]], 0, [dnl
e9ad3f
+    <signal name="RuleAdded">
e9ad3f
+        <arg name="ipv" type="s"></arg>
e9ad3f
+        <arg name="table" type="s"></arg>
e9ad3f
+        <arg name="chain" type="s"></arg>
e9ad3f
+        <arg name="priority" type="i"></arg>
e9ad3f
+        <arg name="args" type="as"></arg>
e9ad3f
+    </signal>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([], [[//signal[@name="RuleRemoved"]]], 0, [dnl
e9ad3f
+    <signal name="RuleRemoved">
e9ad3f
+        <arg name="ipv" type="s"></arg>
e9ad3f
+        <arg name="table" type="s"></arg>
e9ad3f
+        <arg name="chain" type="s"></arg>
e9ad3f
+        <arg name="priority" type="i"></arg>
e9ad3f
+        <arg name="args" type="as"></arg>
e9ad3f
+    </signal>
e9ad3f
+])
e9ad3f
+
e9ad3f
+dnl ###############################
e9ad3f
+dnl ######### permanent ###########
e9ad3f
+dnl ###############################
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getSettings"]]], 0, [dnl
e9ad3f
+    <method name="getSettings">
e9ad3f
+        <arg direction="out" type="(a(sss)a(sssias)a(sas))"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="update"]]], 0, [dnl
e9ad3f
+    <method name="update">
e9ad3f
+        <arg direction="in" name="settings" type="(a(sss)a(sssias)a(sas))"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="addChain"]]], 0, [dnl
e9ad3f
+    <method name="addChain">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="addPassthrough"]]], 0, [dnl
e9ad3f
+    <method name="addPassthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="addRule"]]], 0, [dnl
e9ad3f
+    <method name="addRule">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="in" name="priority" type="i"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getAllChains"]]], 0, [dnl
e9ad3f
+    <method name="getAllChains">
e9ad3f
+        <arg direction="out" type="a(sss)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getAllPassthroughs"]]], 0, [dnl
e9ad3f
+    <method name="getAllPassthroughs">
e9ad3f
+        <arg direction="out" type="a(sas)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getAllRules"]]], 0, [dnl
e9ad3f
+    <method name="getAllRules">
e9ad3f
+        <arg direction="out" type="a(sssias)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getChains"]]], 0, [dnl
e9ad3f
+    <method name="getChains">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="out" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getPassthroughs"]]], 0, [dnl
e9ad3f
+    <method name="getPassthroughs">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="out" type="aas"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="getRules"]]], 0, [dnl
e9ad3f
+    <method name="getRules">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="out" type="a(ias)"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="queryChain"]]], 0, [dnl
e9ad3f
+    <method name="queryChain">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="out" type="b"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="queryPassthrough"]]], 0, [dnl
e9ad3f
+    <method name="queryPassthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+        <arg direction="out" type="b"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="queryRule"]]], 0, [dnl
e9ad3f
+    <method name="queryRule">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="in" name="priority" type="i"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+        <arg direction="out" type="b"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="removeChain"]]], 0, [dnl
e9ad3f
+    <method name="removeChain">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="removePassthrough"]]], 0, [dnl
e9ad3f
+    <method name="removePassthrough">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="removeRule"]]], 0, [dnl
e9ad3f
+    <method name="removeRule">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+        <arg direction="in" name="priority" type="i"></arg>
e9ad3f
+        <arg direction="in" name="args" type="as"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//method[@name="removeRules"]]], 0, [dnl
e9ad3f
+    <method name="removeRules">
e9ad3f
+        <arg direction="in" name="ipv" type="s"></arg>
e9ad3f
+        <arg direction="in" name="table" type="s"></arg>
e9ad3f
+        <arg direction="in" name="chain" type="s"></arg>
e9ad3f
+    </method>
e9ad3f
+])
e9ad3f
+
e9ad3f
+DBUS_INTROSPECT([config], [[//interface[@name="org.fedoraproject.FirewallD1.config.direct"]//signal[@name="Updated"]]], 0, [dnl
e9ad3f
+    <signal name="Updated">
e9ad3f
+    </signal>
e9ad3f
+])
e9ad3f
+
e9ad3f
+FWD_END_TEST
e9ad3f
-- 
e9ad3f
2.27.0
e9ad3f