summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorThomas Haller <thaller@redhat.com>2015-11-17 13:56:52 +0100
committerThomas Haller <thaller@redhat.com>2015-12-04 12:16:41 +0100
commite84587183bfa86d92f24deffeba23a4e928cbee7 (patch)
tree70114c9bc9d1c11d83da509056d414dd970c62cd /tools
parent5da37a129c25350e6f5041726a23d4d9f8318762 (diff)
downloadNetworkManager-e84587183bfa86d92f24deffeba23a4e928cbee7.tar.gz
test: some refactoring of test-networkmanager-service.py
Diffstat (limited to 'tools')
-rwxr-xr-xtools/test-networkmanager-service.py89
1 files changed, 43 insertions, 46 deletions
diff --git a/tools/test-networkmanager-service.py b/tools/test-networkmanager-service.py
index 260810019c..94f8b28439 100755
--- a/tools/test-networkmanager-service.py
+++ b/tools/test-networkmanager-service.py
@@ -9,6 +9,7 @@ import dbus
import dbus.service
import dbus.mainloop.glib
import random
+import collections
mainloop = GLib.MainLoop()
@@ -83,32 +84,42 @@ def to_path(src):
return dbus.ObjectPath("/")
class ExportedObj(dbus.service.Object):
+
+ DBusInterface = collections.namedtuple('DBusInterface', ['dbus_iface', 'get_props_func', 'prop_changed_func'])
+
def __init__(self, bus, object_path):
dbus.service.Object.__init__(self, bus, object_path)
self._bus = bus
self.path = object_path
self.__dbus_ifaces = {}
- def add_dbus_interface(self, dbus_iface, get_props_func):
- self.__dbus_ifaces[dbus_iface] = get_props_func
+ def add_dbus_interface(self, dbus_iface, get_props_func, prop_changed_func):
+ self.__dbus_ifaces[dbus_iface] = ExportedObj.DBusInterface(dbus_iface, get_props_func, prop_changed_func)
+
+ def __dbus_interface_get(self, dbus_iface):
+ if dbus_iface not in self.__dbus_ifaces:
+ raise UnknownInterfaceException()
+ return self.__dbus_ifaces[dbus_iface]
+
+ def _dbus_property_get(self, dbus_iface, propname = None):
+ props = self.__dbus_interface_get(dbus_iface).get_props_func()
+ if propname is None:
+ return props
+ if propname not in props:
+ raise UnknownPropertyException()
+ return props[propname]
- def _get_dbus_properties(self, iface):
- return self.__dbus_ifaces[iface]()
+ def _dbus_property_notify(self, dbus_iface, propname):
+ prop = self._dbus_property_get(dbus_iface, propname)
+ self.__dbus_interface_get(dbus_iface).prop_changed_func(self, { propname: prop })
@dbus.service.method(dbus_interface=dbus.PROPERTIES_IFACE, in_signature='s', out_signature='a{sv}')
- def GetAll(self, iface):
- if iface not in self.__dbus_ifaces.keys():
- raise UnknownInterfaceException()
- return self._get_dbus_properties(iface)
+ def GetAll(self, dbus_iface):
+ return self._dbus_property_get(dbus_iface)
@dbus.service.method(dbus_interface=dbus.PROPERTIES_IFACE, in_signature='ss', out_signature='v')
- def Get(self, iface, name):
- if iface not in self.__dbus_ifaces.keys():
- raise UnknownInterfaceException()
- props = self._get_dbus_properties(iface)
- if not name in props.keys():
- raise UnknownPropertyException()
- return props[name]
+ def Get(self, dbus_iface, name):
+ return self._dbus_property_get(dbus_iface, name)
###################################################################
IFACE_DEVICE = 'org.freedesktop.NetworkManager.Device'
@@ -137,7 +148,7 @@ class Device(ExportedObj):
object_path = "/org/freedesktop/NetworkManager/Devices/%d" % Device.counter
Device.counter = Device.counter + 1
ExportedObj.__init__(self, bus, object_path)
- self.add_dbus_interface(IFACE_DEVICE, self.__get_props)
+ self.add_dbus_interface(IFACE_DEVICE, self.__get_props, Device.PropertiesChanged)
self.iface = iface
self.udi = "/sys/devices/virtual/%s" % iface
@@ -180,9 +191,7 @@ class Device(ExportedObj):
pass
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_DEVICE)
- changed = { propname: props[propname] }
- Device.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_DEVICE, propname)
@dbus.service.signal(IFACE_DEVICE, signature='a{sv}')
def PropertiesChanged(self, changed):
@@ -212,7 +221,7 @@ PE_S390_SUBCHANNELS = "S390Subchannels"
class WiredDevice(Device):
def __init__(self, bus, iface, mac, subchannels):
Device.__init__(self, bus, iface, NM_DEVICE_TYPE_ETHERNET)
- self.add_dbus_interface(IFACE_WIRED, self.__get_props)
+ self.add_dbus_interface(IFACE_WIRED, self.__get_props, WiredDevice.PropertiesChanged)
if mac is None:
self.mac = random_mac()
@@ -232,9 +241,7 @@ class WiredDevice(Device):
return props
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_WIRED)
- changed = { propname: props[propname] }
- WiredDevice.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_WIRED, propname)
@dbus.service.signal(IFACE_WIRED, signature='a{sv}')
def PropertiesChanged(self, changed):
@@ -250,7 +257,7 @@ PV_VLAN_ID = "VlanId"
class VlanDevice(Device):
def __init__(self, bus, iface):
Device.__init__(self, bus, iface, NM_DEVICE_TYPE_VLAN)
- self.add_dbus_interface(IFACE_VLAN, self.__get_props)
+ self.add_dbus_interface(IFACE_VLAN, self.__get_props, VlanDevice.PropertiesChanged)
self.mac = random_mac()
self.carrier = False
@@ -288,7 +295,7 @@ class WifiAp(ExportedObj):
path = "/org/freedesktop/NetworkManager/AccessPoint/%d" % WifiAp.counter
WifiAp.counter = WifiAp.counter + 1
ExportedObj.__init__(self, bus, path)
- self.add_dbus_interface(IFACE_WIFI_AP, self.__get_props)
+ self.add_dbus_interface(IFACE_WIFI_AP, self.__get_props, WifiAp.PropertiesChanged)
self.ssid = ssid
if mac:
@@ -327,9 +334,7 @@ class WifiAp(ExportedObj):
return props
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_WIFI_AP)
- changed = { propname: props[propname] }
- WifiAp.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_WIFI_AP, propname)
@dbus.service.signal(IFACE_WIFI_AP, signature='a{sv}')
def PropertiesChanged(self, changed):
@@ -352,7 +357,7 @@ PW_WIRELESS_CAPABILITIES = "WirelessCapabilities"
class WifiDevice(Device):
def __init__(self, bus, iface):
Device.__init__(self, bus, iface, NM_DEVICE_TYPE_WIFI)
- self.add_dbus_interface(IFACE_WIFI, self.__get_props)
+ self.add_dbus_interface(IFACE_WIFI, self.__get_props, WifiDevice.PropertiesChanged)
self.mac = random_mac()
self.aps = []
@@ -404,9 +409,7 @@ class WifiDevice(Device):
return props
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_WIFI)
- changed = { propname: props[propname] }
- WifiDevice.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_WIFI, propname)
@dbus.service.signal(IFACE_WIFI, signature='a{sv}')
def PropertiesChanged(self, changed):
@@ -440,7 +443,7 @@ class WimaxNsp(ExportedObj):
path = "/org/freedesktop/NetworkManager/Nsp/%d" % WimaxNsp.counter
WimaxNsp.counter = WimaxNsp.counter + 1
ExportedObj.__init__(self, bus, path)
- self.add_dbus_interface(IFACE_WIMAX_NSP, self.__get_props)
+ self.add_dbus_interface(IFACE_WIMAX_NSP, self.__get_props, WimaxNsp.PropertiesChanged)
self.name = name
self.strength = random.randint(0, 100)
@@ -465,9 +468,7 @@ class WimaxNsp(ExportedObj):
return props
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_WIMAX_NSP)
- changed = { propname: props[propname] }
- WimaxNsp.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_WIMAX_NSP, propname)
@dbus.service.signal(IFACE_WIMAX_NSP, signature='a{sv}')
def PropertiesChanged(self, changed):
@@ -491,7 +492,7 @@ PX_ACTIVE_NSP = "ActiveNsp"
class WimaxDevice(Device):
def __init__(self, bus, iface):
Device.__init__(self, bus, iface, NM_DEVICE_TYPE_WIMAX)
- self.add_dbus_interface(IFACE_WIMAX, self.__get_props)
+ self.add_dbus_interface(IFACE_WIMAX, self.__get_props, WimaxDevice.PropertiesChanged)
self.mac = random_mac()
self.bsid = random_mac()
@@ -536,9 +537,7 @@ class WimaxDevice(Device):
return props
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_WIMAX)
- changed = { propname: props[propname] }
- WimaxDevice.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_WIMAX, propname)
@dbus.service.signal(IFACE_WIMAX, signature='a{sv}')
def PropertiesChanged(self, changed):
@@ -583,7 +582,7 @@ class ActiveConnection(ExportedObj):
object_path = "/org/freedesktop/NetworkManager/ActiveConnection/%d" % ActiveConnection.counter
ActiveConnection.counter = ActiveConnection.counter + 1
ExportedObj.__init__(self, bus, object_path)
- self.add_dbus_interface(IFACE_ACTIVE_CONNECTION, self.__get_props)
+ self.add_dbus_interface(IFACE_ACTIVE_CONNECTION, self.__get_props, ActiveConnection.PropertiesChanged)
self.device = device
self.conn = connection
@@ -659,7 +658,7 @@ def set_device_ac_cb(device, ac):
class NetworkManager(ExportedObj):
def __init__(self, bus, object_path):
ExportedObj.__init__(self, bus, object_path)
- self.add_dbus_interface(IFACE_NM, self.__get_props)
+ self.add_dbus_interface(IFACE_NM, self.__get_props, NetworkManager.PropertiesChanged)
self._bus = bus;
self.devices = []
@@ -680,7 +679,7 @@ class NetworkManager(ExportedObj):
@dbus.service.method(dbus_interface=IFACE_NM, in_signature='', out_signature='ao')
def GetDevices(self):
- return self._get_dbus_properties(IFACE_NM)[PM_DEVICES]
+ return to_path_array(self.devices)
@dbus.service.method(dbus_interface=IFACE_NM, in_signature='s', out_signature='o')
def GetDeviceByIpIface(self, ip_iface):
@@ -831,9 +830,7 @@ class NetworkManager(ExportedObj):
return props
def __notify(self, propname):
- props = self._get_dbus_properties(IFACE_NM)
- changed = { propname: props[propname] }
- NetworkManager.PropertiesChanged(self, changed)
+ self._dbus_property_notify(IFACE_NM, propname)
@dbus.service.signal(IFACE_NM, signature='a{sv}')
def PropertiesChanged(self, changed):