| Net-DBus documentation | Contained in the Net-DBus distribution. |
Net::DBus::Test::MockObject - Fake an object from the bus for unit testing
use Net::DBus;
use Net::DBus::Test::MockObject;
my $bus = Net::DBus->test
# Lets fake presence of HAL...
# First we need to define the service
my $service = $bus->export_service("org.freedesktop.Hal");
# Then create a mock object
my $object = Net::DBus::Test::MockObject->new($service,
"/org/freedesktop/Hal/Manager");
# Fake the 'GetAllDevices' method
$object->seed_action("org.freedesktop.Hal.Manager",
"GetAllDevices",
reply => {
return => [ "/org/freedesktop/Hal/devices/computer_i8042_Aux_Port",
"/org/freedesktop/Hal/devices/computer_i8042_Aux_Port_logicaldev_input",
"/org/freedesktop/Hal/devices/computer_i8042_Kbd_Port",
"/org/freedesktop/Hal/devices/computer_i8042_Kbd_Port_logicaldev_input"
],
});
# Now can test any class which calls out to 'GetAllDevices' in HAL
....test stuff....
This provides an alternate for Net::DBus::Object to enable bus objects to be quickly mocked up, thus facilitating creation of unit tests for services which may need to call out to objects provided by 3rd party services on the bus. It is typically used as a companion to the Net::DBus::MockBus object, to enable complex services to be tested without actually starting a real bus.
!!!!! WARNING !!!
This object & its APIs should be considered very experimental at this point in time, and no guarentees about future API compatability are provided what-so-ever. Comments & suggestions on how to evolve this framework are, however, welcome & encouraged.
Create a new mock object, attaching to the service defined by the $service
parameter. This would be an instance of the Net::DBus::Service object. The
$path parameter defines the object path at which to attach this mock object,
and $interface defines the interface it will support.
Retrieves the Net::DBus::Service object within which this object is exported.
Retrieves the path under which this object is exported
Retrieves the last message processed by this object. The returned object is an instance of Net::DBus::Binding::Message
Retrieves the type signature of the last processed message.
Returns the first value supplied as an argument to the last processed message.
Returns a list of all the values supplied as arguments to the last processed message.
Registers an action to be performed when a message corresponding
to the method $method within the interface $interface is
received. The %action parameter can have a number of possible
keys set:
Causes a signal to be emitted when the method is invoked. The value associated with this key should be an instance of the Net::DBus::Binding::Message::Signal class.
Causes an error to be generated when the method is invoked. The
value associated with this key should be a hash reference, with
two elements. The first, name, giving the error name, and the
second, description, providing the descriptive text.
Causes a normal method return to be generated. The value associated with this key should be an array reference, whose elements are the values to be returned by the method.
It doesn't completely replicate the API of Net::DBus::Binding::Object, merely enough to make the high level bindings work in a test scenario.
Copyright 2005 Daniel Berrange <dan@berrange.com>
| Net-DBus documentation | Contained in the Net-DBus distribution. |
# -*- perl -*- # # Copyright (C) 2004-2006 Daniel P. Berrange # # This program is free software; You can redistribute it and/or modify # it under the same terms as Perl itself. Either: # # a) the GNU General Public License as published by the Free # Software Foundation; either version 2, or (at your option) any # later version, # # or # # b) the "Artistic License" # # The file "COPYING" distributed along with this file provides full # details of the terms and conditions of the two licenses.
package Net::DBus::Test::MockObject; use strict; use warnings;
sub new { my $class = shift; my $self = {}; $self->{service} = shift; $self->{object_path} = shift; $self->{interface} = shift; $self->{actions} = {}; $self->{message} = shift; bless $self, $class; $self->get_service->_register_object($self); return $self; } sub _get_sub_nodes { my $self = shift; return []; }
sub get_service { my $self = shift; return $self->{service}; }
sub get_object_path { my $self = shift; return $self->{object_path}; }
sub get_last_message { my $self = shift; return $self->{message}; }
sub get_last_message_signature { my $self = shift; return $self->{message}->get_signature; }
sub get_last_message_param { my $self = shift; my @args = $self->{message}->get_args_list; return $args[0]; }
sub get_last_message_param_list { my $self = shift; my @args = $self->{message}->get_args_list; return \@args; }
sub seed_action { my $self = shift; my $interface = shift; my $method = shift; my %action = @_; $self->{actions}->{$method} = {} unless exists $self->{actions}->{$method}; $self->{actions}->{$method}->{$interface} = \%action; } sub _dispatch { my $self = shift; my $connection = shift; my $message = shift; my $interface = $message->get_interface; my $method = $message->get_member; my $con = $self->get_service->get_bus->get_connection; if (!exists $self->{actions}->{$method}) { my $error = $con->make_error_message($message, "org.freedesktop.DBus.Failed", "no action seeded for method " . $message->get_member); $con->send($error); return; } my $action; if ($interface) { if (!exists $self->{actions}->{$method}->{$interface}) { my $error = $con->make_error_message($message, "org.freedesktop.DBus.Failed", "no action with correct interface seeded for method " . $message->get_member); $con->send($error); return; } $action = $self->{actions}->{$method}->{$interface}; } else { my @interfaces = keys %{$self->{actions}->{$method}}; if ($#interfaces > 0) { my $error = $con->make_error_message($message, "org.freedesktop.DBus.Failed", "too many actions seeded for method " . $message->get_member); $con->send($error); return; } $action = $self->{actions}->{$method}->{$interfaces[0]}; } if (exists $action->{signals}) { my $sigs = $action->{signals}; if (ref($sigs) ne "ARRAY") { $sigs = [ $sigs ]; } foreach my $sig (@{$sigs}) { $self->get_service->get_bus->get_connection->send($sig); } } $self->{message} = $message; if (exists $action->{error}) { my $error = $con->make_error_message($message, $action->{error}->{name}, $action->{error}->{description}); $con->send($error); } elsif (exists $action->{reply}) { my $reply = $con->make_method_return_message($message); my $iter = $reply->iterator(1); foreach my $value (@{$action->{reply}->{return}}) { $iter->append($value); } $con->send($reply); } } 1;