# Copyright 2014 The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. import its.image import its.caps import its.device import its.objects import its.error import its.target import sys import os import os.path # Change this to True, to have the test break at the first failure. stop_at_first_failure = False def main(): """Test different combinations of output formats. """ NAME = os.path.basename(__file__).split(".")[0] with its.device.ItsSession() as cam: props = cam.get_camera_properties() its.caps.skip_unless(its.caps.compute_target_exposure(props) and its.caps.raw16(props)) successes = [] failures = [] debug = its.caps.debug_mode() # Two different requests: auto, and manual. e, s = its.target.get_target_exposure_combos(cam)["midExposureTime"] req_aut = its.objects.auto_capture_request() req_man = its.objects.manual_capture_request(s, e) reqs = [req_aut, # R0 req_man] # R1 # 10 different combos of output formats; some are single surfaces, and # some are multiple surfaces. wyuv,hyuv = its.objects.get_available_output_sizes("yuv", props)[-1] wjpg,hjpg = its.objects.get_available_output_sizes("jpg", props)[-1] fmt_yuv_prev = {"format":"yuv", "width":wyuv, "height":hyuv} fmt_yuv_full = {"format":"yuv"} fmt_jpg_prev = {"format":"jpeg","width":wjpg, "height":hjpg} fmt_jpg_full = {"format":"jpeg"} fmt_raw_full = {"format":"raw"} fmt_combos =[ [fmt_yuv_prev], # F0 [fmt_yuv_full], # F1 [fmt_jpg_prev], # F2 [fmt_jpg_full], # F3 [fmt_raw_full], # F4 [fmt_yuv_prev, fmt_jpg_prev], # F5 [fmt_yuv_prev, fmt_jpg_full], # F6 [fmt_yuv_prev, fmt_raw_full], # F7 [fmt_yuv_prev, fmt_jpg_prev, fmt_raw_full], # F8 [fmt_yuv_prev, fmt_jpg_full, fmt_raw_full]] # F9 # Two different burst lengths: single frame, and 3 frames. burst_lens = [1, # B0 3] # B1 # There are 2x10x2=40 different combinations. Run through them all. n = 0 for r,req in enumerate(reqs): for f,fmt_combo in enumerate(fmt_combos): for b,burst_len in enumerate(burst_lens): try: caps = cam.do_capture([req]*burst_len, fmt_combo) successes.append((n,r,f,b)) print "==> Success[%02d]: R%d F%d B%d" % (n,r,f,b) # Dump the captures out to jpegs. if not isinstance(caps, list): caps = [caps] elif isinstance(caps[0], list): caps = sum(caps, []) for c,cap in enumerate(caps): img = its.image.convert_capture_to_rgb_image(cap, props=props) if debug: its.image.write_image(img, "%s_n%02d_r%d_f%d_b%d_c%d.jpg"%(NAME,n,r,f,b,c)) except Exception as e: print e print "==> Failure[%02d]: R%d F%d B%d" % (n,r,f,b) failures.append((n,r,f,b)) if stop_at_first_failure: sys.exit(0) n += 1 num_fail = len(failures) num_success = len(successes) num_total = len(reqs)*len(fmt_combos)*len(burst_lens) num_not_run = num_total - num_success - num_fail print "\nFailures (%d / %d):" % (num_fail, num_total) for (n,r,f,b) in failures: print " %02d: R%d F%d B%d" % (n,r,f,b) print "\nSuccesses (%d / %d):" % (num_success, num_total) for (n,r,f,b) in successes: print " %02d: R%d F%d B%d" % (n,r,f,b) if num_not_run > 0: print "\nNumber of tests not run: %d / %d" % (num_not_run, num_total) print "" # The test passes if all the combinations successfully capture. assert(num_fail == 0) assert(num_success == num_total) if __name__ == '__main__': main()