Opened 11 years ago
Last modified 11 years ago
#23930 closed New feature
Context manager for capturing output — at Initial Version
| Reported by: | Wojtek Ruszczewski | Owned by: | nobody | 
|---|---|---|---|
| Component: | Testing framework | Version: | dev | 
| Severity: | Normal | Keywords: | |
| Cc: | Triage Stage: | Accepted | |
| Has patch: | yes | Needs documentation: | no | 
| Needs tests: | no | Patch needs improvement: | no | 
| Easy pickings: | no | UI/UX: | no | 
Description
I've recently something like this (for #23929, where the output is generated by a signal handler):
@contextmanager def capture_stdout(): """ Captures the ``sys.stdout`` stream, making anything written to it available in the stream returned as the manager's context. For example: with capture_stdout() as out: # Print something. self.assertIn("something", out.getvalue()) """ old_stdout = sys.stdout sys.stdout = out = StringIO() try: yield out finally: sys.stdout = old_stdout
Would it be better to make it public, leave it buried for the test only or don't mind testing the output it such cases at all?
  Note:
 See   TracTickets
 for help on using tickets.