How do I check if two instances of a
class FooBar(object):
__init__(self, param):
self.param = param
self.param_2 = self.function_2(param)
self.param_3 = self.function_3()
are identical? By identical I mean they have the same values in all of their variables.
a = FooBar(param)
b = FooBar(param)
I thought of
if a == b:
print "a and b are identical"!
Will this do it without side effects?
The background for my question is unit testing. I want to achieve something like:
self.failUnlessEqual(self.my_object.a_function(), another_object)
To avoid the possibility of adding or removing attributes to the model and forgetting to do the appropriate changes to your
__eq__
function, you can define it as follows.In this way, all the object attributes are compared. Now you can check for attribute equality either with
object.__eq__(other)
orobject == other
.If you want the
==
to work, then implement the__eq__
method in your class to perform the rich comparison.If all you want to do is compare the equality of all attributes, you can do that succinctly by comparison of
__dict__
in each object:For an arbitrary object, the
==
operator will only return true if the two objects are the same object (i.e. if they refer to the same address in memory).To get more 'bespoke' behaviour, you'll want to override the rich comparison operators, in this case specifically
__eq__
. Try adding this to your class:(the comparison of all params could be neatened up here, but I've left them in for clarity).
Note that if the parameters are themselves objects you've defined, those objects will have to define
__eq__
in a similar way for this to work.Another point to note is that if you try to compare a FooBar object with another type of object in the way I've done above, python will try to access the param, param_2 and param_3 attributes of the other type of object which will throw an AttributeError. You'll probably want to check the object you're comparing with is an instance of FooBar with isinstance(other, FooBar) first. This is not done by default as there may be situations where you would like to return True for comparison between different types.
See AJ's answer for a tidier way to simply compare all parameters that also shouldn't throw an attribute error.
For more information on the rich comparison see the python docs.