How to use _job_test_results method in autotest

Best Python code snippet using autotest_python

frontend.py

Source:frontend.py Github

copy

Full Screen

...447 if pairing.testname:448 new_job.testname = pairing.testname449 print 'Invoked test %s : %s' % (new_job.id, job_name)450 return new_job451 def _job_test_results(self, tko, job, debug, tests=[]):452 """453 Retrieve test results for a job454 """455 job.test_status = {}456 try:457 test_statuses = tko.get_status_counts(job=job.id)458 except Exception:459 print "Ignoring exception on poll job; RPC interface is flaky"460 traceback.print_exc()461 return462 for test_status in test_statuses:463 # SERVER_JOB is buggy, and often gives false failures. Ignore it.464 if test_status.test_name == 'SERVER_JOB':465 continue466 # if tests is not empty, restrict list of test_statuses to tests467 if tests and test_status.test_name not in tests:468 continue469 if debug:470 print test_status471 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', []))...

Full Screen

Full Screen

Blogs

Check out the latest blogs from LambdaTest on this topic:

A Step-By-Step Guide To Cypress API Testing

API (Application Programming Interface) is a set of definitions and protocols for building and integrating applications. It’s occasionally referred to as a contract between an information provider and an information user establishing the content required from the consumer and the content needed by the producer.

The Art of Testing the Untestable

It’s strange to hear someone declare, “This can’t be tested.” In reply, I contend that everything can be tested. However, one must be pleased with the outcome of testing, which might include failure, financial loss, or personal injury. Could anything be tested when a claim is made with this understanding?

June ‘21 Updates: Live With Cypress Testing, LT Browser Made Free Forever, YouTrack Integration & More!

Howdy testers! June has ended, and it’s time to give you a refresher on everything that happened at LambdaTest over the last month. We are thrilled to share that we are live with Cypress testing and that our very own LT Browser is free for all LambdaTest users. That’s not all, folks! We have also added a whole new range of browsers, devices & features to make testing more effortless than ever.

How To Write End-To-End Tests Using Cypress App Actions

When I started writing tests with Cypress, I was always going to use the user interface to interact and change the application’s state when running tests.

Considering Agile Principles from a different angle

In addition to the four values, the Agile Manifesto contains twelve principles that are used as guides for all methodologies included under the Agile movement, such as XP, Scrum, and Kanban.

Automation Testing Tutorials

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.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Run autotest automation tests on LambdaTest cloud grid

Perform automation testing on 3000+ real desktop and mobile devices online.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful