# Copyright 2015 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. from autotest_lib.client.bin import test from autotest_lib.client.common_lib.cros.tendo import buffet_tester class buffet_RefreshAccessToken(test.test): """Test that buffet can refresh its access token.""" version = 1 def initialize(self): self._helper = buffet_tester.BuffetTester() def run_once(self): # Erase all buffet state and restart it pointing to our fake # server, register with the cloud and check we can poll for # commands. self._helper.restart_buffet(reset_state=True) self._helper.check_buffet_status_is(buffet_tester.STATUS_UNCONFIGURED) device_id = self._helper.register_with_server() self._helper.check_buffet_is_polling(device_id) # Now invalidate buffet's current access token and check that # we can still poll for commands. This demonstrates that # buffet is able to get a new access token if the one that # it's been using has been revoked. self._helper._oauth_client.invalidate_all_access_tokens() self._helper.check_buffet_is_polling(device_id) self._helper.check_buffet_status_is( buffet_tester.STATUS_CONNECTED, expected_device_id=device_id) def cleanup(self): self._helper.close()