| 1 |  |  | import os | 
                            
                    |  |  |  | 
                                                                                        
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 2 |  |  | import sys | 
            
                                                                                                            
                            
            
                                    
            
            
                | 3 |  |  |  | 
            
                                                                                                            
                                                                
            
                                    
            
            
                | 4 |  |  |  | 
            
                                                                        
                            
            
                                    
            
            
                | 5 |  |  | def _gw_logging_cfg(log_file): | 
            
                                                                        
                            
            
                                    
            
            
                | 6 |  |  |     return { | 
            
                                                                        
                            
            
                                    
            
            
                | 7 |  |  |         'version': 1, | 
            
                                                                        
                            
            
                                    
            
            
                | 8 |  |  |         'disable_existing_loggers': False, | 
            
                                                                        
                            
            
                                    
            
            
                | 9 |  |  |         'formatters': { | 
            
                                                                        
                            
            
                                    
            
            
                | 10 |  |  |             'standard': { | 
            
                                                                        
                            
            
                                    
            
            
                | 11 |  |  |                 'format': "%(asctime)s - %(levelname)-5s - %(message)s" | 
            
                                                                        
                            
            
                                    
            
            
                | 12 |  |  |             }, | 
            
                                                                        
                            
            
                                    
            
            
                | 13 |  |  |             'debug': { | 
            
                                                                        
                            
            
                                    
            
            
                | 14 |  |  |                 'format': "%(asctime)s - %(levelname)-5s - %(name)-40s - %(message)-80s - %(module)s:%(" | 
                            
                    |  |  |  | 
                                                                                        
                                                                                     | 
            
                                                                        
                            
            
                                    
            
            
                | 15 |  |  |                           "funcName)s(%(lineno)s)" | 
            
                                                                        
                            
            
                                    
            
            
                | 16 |  |  |             }, | 
            
                                                                        
                            
            
                                    
            
            
                | 17 |  |  |         }, | 
            
                                                                        
                            
            
                                    
            
            
                | 18 |  |  |         'handlers': { | 
            
                                                                        
                            
            
                                    
            
            
                | 19 |  |  |             'console_stdout': { | 
            
                                                                        
                            
            
                                    
            
            
                | 20 |  |  |                 'formatter': 'standard', | 
            
                                                                        
                            
            
                                    
            
            
                | 21 |  |  |                 'class': 'logging.StreamHandler', | 
            
                                                                        
                            
            
                                    
            
            
                | 22 |  |  |                 'stream': sys.stdout, | 
            
                                                                        
                            
            
                                    
            
            
                | 23 |  |  |                 'level': 'INFO' | 
            
                                                                        
                            
            
                                    
            
            
                | 24 |  |  |             }, | 
            
                                                                        
                            
            
                                    
            
            
                | 25 |  |  |             'file': { | 
            
                                                                        
                            
            
                                    
            
            
                | 26 |  |  |                 "class": "logging.handlers.RotatingFileHandler", | 
            
                                                                        
                            
            
                                    
            
            
                | 27 |  |  |                 "formatter": "debug", | 
            
                                                                        
                            
            
                                    
            
            
                | 28 |  |  |                 "filename": log_file, | 
            
                                                                        
                            
            
                                    
            
            
                | 29 |  |  |                 "maxBytes": 1024000, | 
            
                                                                        
                            
            
                                    
            
            
                | 30 |  |  |                 "backupCount": 3, | 
            
                                                                        
                            
            
                                    
            
            
                | 31 |  |  |                 'level': 'INFO' | 
            
                                                                        
                            
            
                                    
            
            
                | 32 |  |  |             }, | 
            
                                                                        
                            
            
                                    
            
            
                | 33 |  |  |         }, | 
            
                                                                        
                            
            
                                    
            
            
                | 34 |  |  |         'loggers': { | 
            
                                                                        
                            
            
                                    
            
            
                | 35 |  |  |             '': { | 
            
                                                                        
                            
            
                                    
            
            
                | 36 |  |  |                 'handlers': ['console_stdout'], | 
            
                                                                        
                            
            
                                    
            
            
                | 37 |  |  |                 'level': 'INFO', | 
            
                                                                        
                            
            
                                    
            
            
                | 38 |  |  |                 'propagate': False | 
            
                                                                        
                            
            
                                    
            
            
                | 39 |  |  |             }, | 
            
                                                                        
                            
            
                                    
            
            
                | 40 |  |  |             'groundwork': { | 
            
                                                                        
                            
            
                                    
            
            
                | 41 |  |  |                 'handlers': ['console_stdout', 'file'], | 
            
                                                                        
                            
            
                                    
            
            
                | 42 |  |  |                 'level': 'INFO', | 
            
                                                                        
                            
            
                                    
            
            
                | 43 |  |  |                 'propagate': False | 
            
                                                                                                            
                            
            
                                    
            
            
                | 44 |  |  |             }, | 
            
                                                                                                            
                            
            
                                    
            
            
                | 45 |  |  |         } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 46 |  |  |     } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 47 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 48 |  |  |  | 
            
                                                                                                            
                            
            
                                                                    
                                                                                                        
            
            
                | 49 |  | View Code Duplication | def test_logging_file(basicApp, tmpdir): | 
                            
                    |  |  |  | 
                                                                                        
                                                                                            
                                                                                            
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 50 |  |  |     log_file = os.path.join(tmpdir, "test.log") | 
            
                                                                                                            
                            
            
                                    
            
            
                | 51 |  |  |     app = basicApp | 
            
                                                                                                            
                            
            
                                    
            
            
                | 52 |  |  |     # set up logging in the config, with log level INFO | 
            
                                                                                                            
                            
            
                                    
            
            
                | 53 |  |  |     app.config.set('GROUNDWORK_LOGGING', _gw_logging_cfg(log_file)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 54 |  |  |     app._configure_logging(app.config.get("GROUNDWORK_LOGGING")) | 
                            
                    |  |  |  | 
                                                                                        
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 55 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 56 |  |  |     debug_message = "This is a test debug message." | 
            
                                                                                                            
                            
            
                                    
            
            
                | 57 |  |  |     info_message = "This is a test info message." | 
            
                                                                                                            
                            
            
                                    
            
            
                | 58 |  |  |     app.log.debug(debug_message) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 59 |  |  |     app.log.info(info_message) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 60 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 61 |  |  |     # verify the contents of the log file | 
            
                                                                                                            
                            
            
                                    
            
            
                | 62 |  |  |     with open(log_file) as lf: | 
                            
                    |  |  |  | 
                                                                                        
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 63 |  |  |         log = lf.read() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 64 |  |  |     # at log level INFO, the DEBUG message should not be there | 
            
                                                                                                            
                            
            
                                    
            
            
                | 65 |  |  |     assert log.find(debug_message) == -1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 66 |  |  |     # the INFO message should be there | 
            
                                                                                                            
                            
            
                                    
            
            
                | 67 |  |  |     assert log.find(info_message) > 0 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 68 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 69 |  |  |  | 
            
                                                                                                            
                            
            
                                                                    
                                                                                                        
            
            
                | 70 |  | View Code Duplication | def test_logging_console(basicApp, tmpdir, capsys): | 
                            
                    |  |  |  | 
                                                                                        
                                                                                            
                                                                                            
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 71 |  |  |     log_file = os.path.join(tmpdir, "test.log") | 
            
                                                                                                            
                            
            
                                    
            
            
                | 72 |  |  |     app = basicApp | 
            
                                                                                                            
                            
            
                                    
            
            
                | 73 |  |  |     # set up logging in the config, with log level INFO | 
            
                                                                                                            
                            
            
                                    
            
            
                | 74 |  |  |     app.config.set('GROUNDWORK_LOGGING', _gw_logging_cfg(log_file)) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 75 |  |  |     app._configure_logging(app.config.get("GROUNDWORK_LOGGING")) | 
                            
                    |  |  |  | 
                                                                                        
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 76 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 77 |  |  |     debug_message = "This is a test debug message." | 
            
                                                                                                            
                            
            
                                    
            
            
                | 78 |  |  |     info_message = "This is a test info message." | 
            
                                                                                                            
                            
            
                                    
            
            
                | 79 |  |  |     app.log.debug(debug_message) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 80 |  |  |     app.log.info(info_message) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 81 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 82 |  |  |     out, err = capsys.readouterr() | 
                            
                    |  |  |  | 
                                                                                        
                                                                                     | 
            
                                                                                                            
                            
            
                                    
            
            
                | 83 |  |  |     # at log level INFO, the DEBUG message should not be there | 
            
                                                                                                            
                            
            
                                    
            
            
                | 84 |  |  |     assert out.find(debug_message) == -1 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 85 |  |  |     # the INFO message should be there | 
            
                                                                                                            
                                                                
            
                                    
            
            
                | 86 |  |  |     assert out.find(info_message) > 0 | 
            
                                                        
            
                                    
            
            
                | 87 |  |  |  | 
            
                        
The coding style of this project requires that you add a docstring to this code element. Below, you find an example for methods:
If you would like to know more about docstrings, we recommend to read PEP-257: Docstring Conventions.