Best Python code snippet using autotest_python
frontend.py
Source: frontend.py
...471 hostname = test_status.hostname472 if hostname not in job.test_status:473 job.test_status[hostname] = TestResults()474 job.test_status[hostname].add(test_status)475 def _job_results_platform_map(self, job, debug):476 # Figure out which hosts passed / failed / aborted in a job477 # Creates a 2-dimensional hash, stored as job.results_platform_map478 # 1st index - platform type (string)479 # 2nd index - Status (string)480 # 'Completed' / 'Failed' / 'Aborted'481 # Data indexed by this hash is a list of hostnames (text strings)482 job.results_platform_map = {}483 try:484 job_statuses = self.get_host_queue_entries(job=job.id)485 except Exception:486 print "Ignoring exception on poll job; RPC interface is flaky"487 traceback.print_exc()488 return None489 platform_map = {}490 job.job_status = {}491 job.metahost_index = {}492 for job_status in job_statuses:493 # This is basically "for each host / metahost in the job"494 if job_status.host:495 hostname = job_status.host.hostname496 else: # This is a metahost497 metahost = job_status.meta_host498 index = job.metahost_index.get(metahost, 1)499 job.metahost_index[metahost] = index + 1500 hostname = '%s.%s' % (metahost, index)501 job.job_status[hostname] = job_status.status502 status = job_status.status503 # Skip hosts that failed verify or repair:504 # that's a machine failure, not a job failure505 if hostname in job.test_status:506 verify_failed = False507 for failure in job.test_status[hostname].fail:508 if (failure.test_name == 'verify' or509 failure.test_name == 'repair'):510 verify_failed = True511 break512 if verify_failed:513 continue514 if hostname in job.test_status and job.test_status[hostname].fail:515 # If the any tests failed in the job, we want to mark the516 # job result as failed, overriding the default job status.517 if status != "Aborted": # except if it's an aborted job518 status = 'Failed'519 if job_status.host:520 platform = job_status.host.platform521 else: # This is a metahost522 platform = job_status.meta_host523 if platform not in platform_map:524 platform_map[platform] = {'Total': [hostname]}525 else:526 platform_map[platform]['Total'].append(hostname)527 new_host_list = platform_map[platform].get(status, []) + [hostname]528 platform_map[platform][status] = new_host_list529 job.results_platform_map = platform_map530 def set_platform_results(self, test_job, platform, result):531 """532 Result must be None, 'FAIL', 'WARN' or 'GOOD'533 """534 if test_job.platform_results[platform] is not None:535 # We're already done, and results recorded. This can't change later.536 return537 test_job.platform_results[platform] = result538 # Note that self.job refers to the metajob we're IN, not the job539 # that we're excuting from here.540 testname = '%s.%s' % (test_job.testname, platform)541 if self.job:542 self.job.record(result, None, testname, status='')543 def poll_job_results(self, tko, job, debug=False):544 """545 Analyse all job results by platform, return:546 False: if any platform has more than one failure547 None: if any platform has more than one machine not yet Good.548 True: if all platforms have at least all-but-one machines Good.549 """550 self._job_test_results(tko, job, debug)551 if job.test_status == {}:552 return None553 self._job_results_platform_map(job, debug)554 good_platforms = []555 failed_platforms = []556 aborted_platforms = []557 unknown_platforms = []558 platform_map = job.results_platform_map559 for platform in platform_map:560 if not job.platform_results.has_key(platform):561 # record test start, but there's no way to do this right now562 job.platform_results[platform] = None563 total = len(platform_map[platform]['Total'])564 completed = len(platform_map[platform].get('Completed', []))565 failed = len(platform_map[platform].get('Failed', []))566 aborted = len(platform_map[platform].get('Aborted', []))567 # We set up what we want to record here, but don't actually do...
Check out the latest blogs from LambdaTest on this topic:
Companies are using DevOps to quickly respond to changing market dynamics and customer requirements.
Unit testing is typically software testing within the developer domain. As the QA role expands in DevOps, QAOps, DesignOps, or within an Agile team, QA testers often find themselves creating unit tests. QA testers may create unit tests within the code using a specified unit testing tool, or independently using a variety of methods.
Websites and web apps are growing in number day by day, and so are the expectations of people for a pleasant web experience. Even though the World Wide Web (WWW) was invented only in 1989 (32 years back), this technology has revolutionized the world we know back then. The best part is that it has made life easier for us. You no longer have to stand in long queues to pay your bills. You can get that done within a few minutes by visiting their website, web app, or mobile app.
JavaScript is one of the most widely used programming languages. This popularity invites a lot of JavaScript development and testing frameworks to ease the process of working with it. As a result, numerous JavaScript testing frameworks can be used to perform unit testing.
Automating testing is a crucial step in the development pipeline of a software product. In an agile development environment, where there is continuous development, deployment, and maintenance of software products, automation testing ensures that the end software products delivered are error-free.
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!!