Commits

Robert Brewer committed 2dd8487

Forward port to trunk of 3.0.x [1709]. Added code to print unreachable object typecounts. See #718.

Comments (0)

Files changed (1)

cherrypy/test/test_refleaks.py

             
             return "\n".join(output)
         gc_stats.exposed = True
+        
+        def gc_objtypes(self):
+           data = {}
+           for x in gc.get_objects():
+               data[type(x)] = data.get(type(x), 0) + 1
+            
+           data = [(v, k) for k, v in data.iteritems()]
+           data.sort()
+           return "\n".join([repr(pair) for pair in data])
+        gc_objtypes.exposed = True 
     
     cherrypy.tree.mount(Root())
     cherrypy.config.update({'environment': 'test_suite'})
             t.join()
         
         self.getPage("/gc_stats")
-        self.assertBody("")
-
-
+        self.assertBody("")
+        
+        if self.body != "":
+            # If gc_stats fails, choose "ignore" to see the type counts for
+            # all the unreachable objects in this body.
+            self.getPage("/gc_objtypes")
+            print self.body
+
+
 if __name__ == '__main__':
     setup_server()
     helper.testmain()
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.