1# Copyright 2018 The Chromium OS Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5import logging
6
7from autotest_lib.client.common_lib.cros import kernel_utils
8from autotest_lib.server.cros.update_engine import update_engine_test
9
10class autoupdate_Cellular(update_engine_test.UpdateEngineTest):
11    """
12    Tests auto updating over cellular.
13
14    Usually with AU tests we use a lab devserver to hold the payload, and to be
15    the omaha instance that DUTs ping. However, over cellular they will not be
16    able to reach the devserver. So we will need to put the payload on a
17    public google storage location. We will setup an omaha instance on the DUT
18    (via autoupdate_CannedOmahaUpdate) that points to the payload on GStorage.
19
20    """
21    version = 1
22
23    def _check_for_cellular_entries_in_update_log(self):
24        """Check update_engine.log for log entries about cellular."""
25        logging.info('Making sure we have cellular entries in update_engine '
26                     'log.')
27        line1 = ('Allowing updates over cellular as permission preference is '
28                 'set to true.')
29        line2 = 'We are connected via cellular, Updates allowed: Yes'
30        self._check_update_engine_log_for_entry([line1, line2],
31                                                raise_error=True)
32
33
34    def cleanup(self):
35        """Clean up the test state."""
36        self._set_update_over_cellular_setting(False)
37        super(autoupdate_Cellular, self).cleanup()
38
39
40    def run_once(self, job_repo_url=None, full_payload=True):
41        """
42        Runs the autoupdate test over cellular once.
43
44        @param job_repo_url: The URL of the current build.
45        @param full_payload: Whether the payload should be full or delta.
46
47        """
48        payload_url = self.get_payload_for_nebraska(
49            job_repo_url, full_payload=full_payload, public_bucket=True)
50        active, inactive = kernel_utils.get_kernel_state(self._host)
51        self._set_update_over_cellular_setting(True)
52        self._run_client_test_and_check_result('autoupdate_CannedOmahaUpdate',
53                                               payload_url=payload_url,
54                                               use_cellular=True)
55        self._check_for_cellular_entries_in_update_log()
56        self._host.reboot()
57        rootfs_hostlog, _ = self._create_hostlog_files()
58        self.verify_update_events(self._FORCED_UPDATE, rootfs_hostlog)
59        kernel_utils.verify_boot_expectations(inactive, host=self._host)
60