Home | History | Annotate | Download | only in pyautolib
      1 # Copyright (c) 2011 The Chromium 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 
      5 """History: python representation for history.
      6 
      7 Obtain one of these from PyUITestSuite::GetHistoryInfo() call.
      8 
      9 Example:
     10 class MyTest(pyauto.PyUITest):
     11   def testBasic(self):
     12     url = 'http://www.google.com/'
     13     self.NavigateToURL(url)
     14     history = self.GetHistoryInfo()
     15     self.assertEqual(1, len(history))
     16     self.assertEqual(url, history[0]['url'])
     17 
     18 See more tests in chrome/test/functional/history.py.
     19 """
     20 
     21 import simplejson as json
     22 
     23 from pyauto_errors import JSONInterfaceError
     24 
     25 
     26 class HistoryInfo(object):
     27   """Represent info about browsing history.
     28 
     29   The info is represented as a list of history items containing url, title,
     30   time, etc.
     31   """
     32   def __init__(self, history_dict):
     33     """Initialize a HistoryInfo from a string of json.
     34 
     35     Args:
     36       json_string: a dictionary as returned by the IPC command 'GetHistoryInfo'.
     37                    A typical dict representing history info looks like:
     38                    {'history': [
     39                       {'url': 'http://www.google.com/',
     40                        'title': 'Google',
     41                        ...,
     42                        ...,
     43                     }, ] }
     44 
     45     Raises:
     46       pyauto_errors.JSONInterfaceError if the automation call returns an error.
     47     """
     48     # JSON string prepared in GetHistoryInfo() in automation_provider.cc
     49     self.historydict = history_dict
     50 
     51   def History(self):
     52     """Get history list.
     53 
     54     History is ordered latest first, that is in the same order as
     55     chrome://history/ would list.
     56 
     57     Example:
     58     [ { u'snippet': u'',
     59         u'starred': False,
     60         u'time': 1271781612,
     61         u'title': u'Google News',
     62         u'url': u'http://news.google.com/'},
     63       { u'snippet': u'',
     64         u'starred': True,
     65         u'time': 1271781602,
     66         u'title': u'Google',
     67         u'url': u'http://www.google.com/'}]
     68 
     69     The snippet attribute will be empty in most cases. If GetHistoryInfo() is
     70     provided a non-empty search_text arg, the snippet attribute will contain the
     71     snippet as it would be visible when searching for that text in the
     72     chrome://history/ UI.
     73 
     74     Returns:
     75       [item1, item2, ...]
     76     """
     77     return self.historydict.get('history', [])
     78