1# Copyright (c) 2013 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.bin import test
8from autotest_lib.client.common_lib import error
9from autotest_lib.client.common_lib.cros.network import interface
10from autotest_lib.client.cros import shill_temporary_profile
11from autotest_lib.client.cros.networking import wifi_proxy
12
13class network_BasicProfileProperties(test.test):
14    """Test that shill's DBus properties for profiles work."""
15
16    version = 1
17
18    PROFILE_NAME = 'test'
19    PROFILE_PROPERTY_NAME = 'Name'
20    PROFILE_PROPERTY_ENTRIES = 'Entries'
21
22
23    @staticmethod
24    def get_field_from_properties(properties, field):
25        """Get a field from a dictionary of properties.
26
27        Raises an exception on failure.
28
29        @param properties dict of properties (presumably from some
30                DBus object).
31        @param field string key to search for in |properties|.
32        @return value of properties[field].
33
34        """
35        if not field in properties:
36            raise error.TestFail('No %s field in properties %r?' %
37                                 (field, properties))
38
39        return properties[field]
40
41
42    def run_once(self):
43        """Test body."""
44        shill = wifi_proxy.WifiProxy.get_proxy()
45        with shill_temporary_profile.ShillTemporaryProfile(
46                shill.manager, profile_name=self.PROFILE_NAME):
47            profiles = shill.get_profiles()
48            logging.info('Got profiles %r', profiles)
49            # The last profile should be the one we just created.
50            profile = profiles[-1]
51            profile_properties = shill.dbus2primitive(
52                    profile.GetProperties(utf8_strings=True))
53            logging.debug('Profile properties: %r.', profile_properties)
54            profile_name = self.get_field_from_properties(
55                    profile_properties, self.PROFILE_PROPERTY_NAME)
56            if profile_name != self.PROFILE_NAME:
57                raise error.TestFail('Found unexpected top profile with name '
58                                     '%r.' % profile_name)
59
60            entries = shill.dbus2primitive(self.get_field_from_properties(
61                    profile_properties, self.PROFILE_PROPERTY_ENTRIES))
62            logging.info('Found entries: %r', entries)
63            ethernet_if = interface.Interface.get_connected_ethernet_interface()
64            mac = ethernet_if.mac_address.replace(':', '').lower()
65            ethernet_entry_key = 'ethernet_%s' % mac
66            if not ethernet_entry_key in entries:
67                raise error.TestFail('Missing ethernet entry %s from profile.' %
68                                     ethernet_entry_key)
69
70            entry = profile.GetEntry(ethernet_entry_key)
71