blob: d0202dc92e4246d87e40eb7bdc0719aa6b027bec [file] [log] [blame] [edit]
# Copyright (c) 2013 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.
import ap_spec
import trendnet_ap_configurator
class Trendnet731brAPConfigurator(trendnet_ap_configurator.
TrendnetAPConfigurator):
"""Derived class to control the Trendnet TEW-731BR."""
def navigate_to_page(self, page_number):
"""Navigate to the given page.
@param page_number: the page to navigate to.
"""
self.navigate_to_login_page()
if page_number == 1:
page_url = ''.join([self.admin_interface_url,
"/wireless_basic.htm"])
self.get_url(page_url, page_title='TRENDNET')
if page_number == 2:
page_url = ''.join([self.admin_interface_url,
"/wireless_auth.htm"])
self.get_url(page_url, page_title='TRENDNET')
def navigate_to_login_page(self):
"""
We need to login first in order to configure settings.
"""
self.get_url(self.admin_interface_url, page_title='Login')
self.wait_for_object_by_id('login_n')
self.set_content_of_text_field_by_id('admin', 'login_n',
abort_check=True)
self.set_content_of_text_field_by_id('password', 'login_pass',
abort_check=True)
self.click_button_by_xpath('//input[@value="Login"]')
def _set_ssid(self, ssid):
self.set_content_of_text_field_by_id(ssid, 'show_ssid')
self._ssid = ssid
def save_page(self, page_number):
"""Save the settings of the passed in page.
@param page_number: the page to save.
"""
if page_number == 1:
xpath = ('//input[@type="button" and @value="Apply"]')
elif page_number == 2:
xpath = ('//input[@type="button" and @value="Apply"]')
self.click_button_by_xpath(xpath, alert_handler=self._alert_handler)
xpath = ('//input[@type="button" and @value="Continue"]')
self.click_button_by_xpath(xpath, alert_handler=self._alert_handler)
def _set_security_disabled(self):
self.wait_for_object_by_xpath('//select[@name="wep_type"]')
self.select_item_from_popup_by_id(' Disable ','wep_type')
def get_supported_modes(self):
return [{'band': ap_spec.BAND_2GHZ,
'modes': [ap_spec.MODE_B,
ap_spec.MODE_G,
ap_spec.MODE_N,
ap_spec.MODE_B | ap_spec.MODE_G,
ap_spec.MODE_B | ap_spec.MODE_G | ap_spec.MODE_N]}]
def _set_mode(self, mode, band=None):
# Different bands are not supported so we ignore.
# Create the mode to popup item mapping
mode_mapping = {ap_spec.MODE_B | ap_spec.MODE_G | ap_spec.MODE_N:
'2.4Ghz 802.11b/g/n mixed mode',
ap_spec.MODE_N: '2.4Ghz 802.11n only mode',
ap_spec.MODE_B: '2.4Ghz 802.11b only mode',
ap_spec.MODE_G: '2.4Ghz 802.11g only mode',
ap_spec.MODE_B | ap_spec.MODE_G:
'2.4Ghz 802.11b/g mixed mode'}
mode_name = ''
if mode in mode_mapping.keys():
mode_name = mode_mapping[mode]
else:
raise RuntimeError('The mode selected %d is not supported by router'
' %s.', hex(mode), self.name)
self.select_item_from_popup_by_id(mode_name, 'dot11_mode')
def get_supported_bands(self):
return [{'band': ap_spec.BAND_2GHZ, 'channels': range(1, 12)}]
def _set_channel(self, channel):
position = self._get_channel_popup_position(channel)
channel_choices = ['1', '2', '3', '4', '5',
'6', '7', '8', '9', '10', '11']
self.select_item_from_popup_by_id(channel_choices[position],
'wlan0_channel_t')
def _set_visibility(self, visible=True):
# value=1 is visible; value=0 is invisible
int_value = int(visible)
xpath = ('//input[@value="%d" and @name="wlan0_ssid_broadcast"]' %
int_value)
self.click_button_by_xpath(xpath, alert_handler=self._alert_handler)
def is_update_interval_supported(self):
"""
Returns True if setting the PSK refresh interval is supported.
@return True is supported; False otherwise
"""
return False
def _set_security_wep(self, key_value, authentication):
self.wait_for_object_by_xpath('//select[@name="wep_type"]')
self.select_item_from_popup_by_id(' WEP ','wep_type')
# This router doesn not support ASCII passphrase for
# generating hex key.Converting ASCII to hex before setting
self.set_content_of_text_field_by_id(key_value.encode("hex"),
'key1_64_hex')
def _set_security_wpapsk(self, security, shared_key, update_interval=1800):
self.wait_for_object_by_xpath('//select[@name="wep_type"]')
if security == ap_spec.SECURITY_TYPE_WPAPSK:
self.select_item_from_popup_by_id(' WPA ','wep_type')
else:
self.select_item_from_popup_by_id(' WPA2 ','wep_type')
self.set_content_of_text_field_by_id(shared_key,
'wlan0_psk_pass_phrase')
self.set_content_of_text_field_by_id(shared_key, 'wpapsk2')
def _alert_handler(self, alert):
"""Checks for any modal dialogs which popup to alert the user and
either raises a RuntimeError or ignores the alert.
Args:
alert: The modal dialog's contents.
"""
text = alert.text
if 'To disable SSID Broadcast will cause WPS not work' in text:
alert.accept()
else:
raise RuntimeError('We have an unhandled alert: %s' % text)