# 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()