1#!/usr/bin/env python3.4
2#
3#   Copyright 2018 - The Android Open Source Project
4#
5#   Licensed under the Apache License, Version 2.0 (the "License");
6#   you may not use this file except in compliance with the License.
7#   You may obtain a copy of the License at
8#
9#       http://www.apache.org/licenses/LICENSE-2.0
10#
11#   Unless required by applicable law or agreed to in writing, software
12#   distributed under the License is distributed on an "AS IS" BASIS,
13#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14#   See the License for the specific language governing permissions and
15#   limitations under the License.
16
17import csv
18import os
19import time
20import acts_contrib.test_utils.bt.bt_test_utils as btutils
21import acts_contrib.test_utils.power.PowerBTBaseTest as PBtBT
22
23EXTRA_PLAY_TIME = 30
24
25
26class PowerBTcalibrationTest(PBtBT.PowerBTBaseTest):
27    def setup_test(self):
28
29        super().setup_test()
30        self.attenuator = self.attenuators[0]
31        btutils.enable_bqr(self.dut)
32        time.sleep(2)
33        btutils.disable_bluetooth(self.dut.droid)
34        time.sleep(2)
35        btutils.enable_bluetooth(self.dut.droid, self.dut.ed)
36        btutils.connect_phone_to_headset(self.dut, self.bt_device, 60)
37        vol = self.dut.droid.getMaxMediaVolume() * self.volume
38        self.dut.droid.setMediaVolume(int(vol))
39
40        self.cal_data_path = os.path.join(self.log_path, 'Calibration')
41        self.log_file = os.path.join(self.cal_data_path, 'Cal_data.csv')
42        os.makedirs(os.path.dirname(self.log_file), exist_ok=True)
43
44    def test_calibrate(self):
45        """Run calibration to get attenuation value at each power level
46
47        """
48
49        self.cal_matrix = []
50        self.media.play()
51        time.sleep(EXTRA_PLAY_TIME)
52
53        # Loop through attenuation in 1 dB step until reaching at PL10
54        self.log.info('Starting Calibration Process')
55        pl10_count = 0
56        for i in range(int(self.attenuator.get_max_atten())):
57
58            self.attenuator.set_atten(i)
59            bt_metrics_dict = btutils.get_bt_metric(self.dut)
60            pwl = bt_metrics_dict['pwlv'][self.dut.serial]
61            self.log.info('Reach PW {} at attenuation {} dB'.format(pwl, i))
62            self.cal_matrix.append([i, pwl])
63            if pwl == 10:
64                pl10_count += 1
65            if pl10_count > 5:
66                break
67
68        # Write cal results to csv
69        with open(self.log_file, 'w', newline='') as f:
70            writer = csv.writer(f)
71            writer.writerows(self.cal_matrix)
72