Best Python code snippet using autotest_python
logging_manager_unittest.py
Source: logging_manager_unittest.py
...147 command = 'ls -l /proc/%s/fd' % os.getpid()148 proc = subprocess.Popen(command.split(), shell=True,149 stdout=subprocess.PIPE)150 return proc.communicate()[0]151 def _compare_logs(self, log_buffer, expected_text):152 actual_lines = log_buffer.getvalue().splitlines()153 expected_lines = expected_text.splitlines()154 if self._real_system_calls:155 # because of the many interacting processes, we can't ensure perfect156 # interleaving. so compare sets of lines rather than ordered lines.157 actual_lines = set(actual_lines)158 expected_lines = set(expected_lines)159 self.assertEquals(actual_lines, expected_lines)160 def _check_results(self):161 # ensure our stdout was restored162 self.assertEquals(self.stdout, self._original_stdout)163 if self._real_system_calls:164 # ensure FDs were left in their original state165 self.assertEquals(self._grab_fd_info(), self._fd_info)166 self._compare_logs(self.stdout, _EXPECTED_STDOUT)167 self._compare_logs(self._log1, _EXPECTED_LOG1)168 self._compare_logs(self._log2, _EXPECTED_LOG2)169 @unittest.skip("logging manager does not behave well under nosetests")170 def test_logging_manager(self):171 self._run_test(logging_manager.LoggingManager)172 self._check_results()173 @unittest.skip("logging manager does not behave well under nosetests")174 def test_fd_redirection_logging_manager(self):175 self._real_system_calls = True176 self._fd_info = self._grab_fd_info()177 self._run_test(logging_manager.FdRedirectionLoggingManager)178 self._check_results()179 @unittest.skip("logging manager does not behave well under nosetests")180 def test_tee_redirect_debug_dir(self):181 manager = self._setup_manager()182 manager.start_logging()183 manager.tee_redirect_debug_dir('/fake/dir', tag='mytag')184 print >>self.stdout, 'hello'185 manager.undo_redirect()186 print >>self.stdout, 'goodbye'187 manager.stop_logging()188 self._compare_logs(self.stdout,189 'INFO: mytag : hello\nINFO: goodbye')190 self._compare_logs(self._config_object.log, 'hello\n')191class MonkeyPatchTestCase(unittest.TestCase):192 def setUp(self):193 filename = os.path.split(__file__)[1]194 if filename.endswith('.pyc'):195 filename = filename[:-1]196 self.expected_filename = filename197 def check_filename(self, filename, expected=None):198 if expected is None:199 expected = [self.expected_filename]200 self.assertTrue(os.path.split(filename)[1] in expected)201 def _0_test_find_caller(self):202 finder = logging_manager._logging_manager_aware_logger__find_caller203 filename, lineno, caller_name = finder(logging_manager.logger)204 self.check_filename(filename)...
logging_manager_test.py
Source: logging_manager_test.py
...139 command = 'ls -l /proc/%s/fd' % os.getpid()140 proc = subprocess.Popen(command.split(), shell=True,141 stdout=subprocess.PIPE)142 return proc.communicate()[0]143 def _compare_logs(self, log_buffer, expected_text):144 actual_lines = log_buffer.getvalue().splitlines()145 expected_lines = expected_text.splitlines()146 if self._real_system_calls:147 # because of the many interacting processes, we can't ensure perfect148 # interleaving. so compare sets of lines rather than ordered lines.149 actual_lines = set(actual_lines)150 expected_lines = set(expected_lines)151 self.assertEquals(actual_lines, expected_lines)152 def _check_results(self):153 # ensure our stdout was restored154 self.assertEquals(self.stdout, self._original_stdout)155 if self._real_system_calls:156 # ensure FDs were left in their original state157 self.assertEquals(self._grab_fd_info(), self._fd_info)158 self._compare_logs(self.stdout, _EXPECTED_STDOUT)159 self._compare_logs(self._log1, _EXPECTED_LOG1)160 self._compare_logs(self._log2, _EXPECTED_LOG2)161 def test_logging_manager(self):162 self._run_test(logging_manager.LoggingManager)163 self._check_results()164 def test_fd_redirection_logging_manager(self):165 self._real_system_calls = True166 self._fd_info = self._grab_fd_info()167 self._run_test(logging_manager.FdRedirectionLoggingManager)168 self._check_results()169 def test_tee_redirect_debug_dir(self):170 manager = self._setup_manager()171 manager.start_logging()172 manager.tee_redirect_debug_dir('/fake/dir', tag='mytag')173 print >>self.stdout, 'hello'174 manager.undo_redirect()175 print >>self.stdout, 'goodbye'176 manager.stop_logging()177 self._compare_logs(self.stdout,178 'INFO: mytag : hello\nINFO: goodbye')179 self._compare_logs(self._config_object.log, 'hello\n')180class MonkeyPatchTestCase(unittest.TestCase):181 def setUp(self):182 filename = os.path.split(__file__)[1]183 if filename.endswith('.pyc'):184 filename = filename[:-1]185 self.expected_filename = filename186 def check_filename(self, filename, expected=None):187 if expected is None:188 expected = [self.expected_filename]189 self.assertIn(os.path.split(filename)[1], expected)190 def _0_test_find_caller(self):191 finder = logging_manager._logging_manager_aware_logger__find_caller192 filename, lineno, caller_name = finder(logging_manager.logger)193 self.check_filename(filename)...
Check out the latest blogs from LambdaTest on this topic:
With the change in technology trends, there has been a drastic change in the way we build and develop applications. It is essential to simplify your programming requirements to achieve the desired outcomes in the long run. Visual Studio Code is regarded as one of the best IDEs for web development used by developers.
In recent times, many web applications have been ported to mobile platforms, and mobile applications are also created to support businesses. However, Android and iOS are the major platforms because many people use smartphones compared to desktops for accessing web applications.
With the rising demand for new services and technologies in the IT, manufacturing, healthcare, and financial sector, QA/ DevOps engineering has become the most important part of software companies. Below is a list of some characteristics to look for when interviewing a potential candidate.
Building a website is all about keeping the user experience in mind. Ultimately, it’s about providing visitors with a mind-blowing experience so they’ll keep coming back. One way to ensure visitors have a great time on your site is to add some eye-catching text or image animations.
So you are at the beginning of 2020 and probably have committed a new year resolution as a tester to take a leap from Manual Testing To Automation . However, to automate your test scripts you need to get your hands dirty on a programming language and that is where you are stuck! Or you are already proficient in automation testing through a single programming language and are thinking about venturing into new programming languages for automation testing, along with their respective frameworks. You are bound to be confused about picking your next milestone. After all, there are numerous programming languages to choose from.
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!