From 46d535027b5247a9f1b242b4944e2ee8d65b4fad Mon Sep 17 00:00:00 2001 From: David Medina Date: Fri, 10 Feb 2012 00:59:01 +0100 Subject: Resources tests resources.core * Also detected and fixed memory bug --- pygithub3/resources/base.py | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) (limited to 'pygithub3/resources/base.py') diff --git a/pygithub3/resources/base.py b/pygithub3/resources/base.py index ae038bd..dfa285f 100644 --- a/pygithub3/resources/base.py +++ b/pygithub3/resources/base.py @@ -22,6 +22,9 @@ class Resource(object): for attr in self._attrs: setattr(self, attr, self._attrs[attr]) + def __str__(self): + return "<%s>" % self.__class__.__name__ + def __repr__(self): return self.__str__() @@ -59,19 +62,21 @@ class Resource(object): elif hasattr(raw_resources, '__iter__'): return [resource.__load(raw_resource) for raw_resource in raw_resources] - raw_resource.update( + + new_resource = raw_resource.copy() + new_resource.update( {attr: parse_date(raw_resource[attr]) for attr in self._dates if attr in raw_resource}) - raw_resource.update( + new_resource.update( {attr: parse_map(resource, raw_resource[attr]) for attr, resource in self._maps.items() if attr in raw_resource}) - raw_resource.update( + new_resource.update( {attr: parse_collection_map(resource, raw_resource[attr]) for attr, resource in self._collection_maps.items() if attr in raw_resource}) - return self(raw_resource) + return self(new_resource) class Raw(Resource): -- cgit v1.2.3-59-g8ed1b