From 78ea56b5e322746dbe49c51e93b5fd86574a6df7 Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Mon, 16 Jan 2012 12:06:31 +0000 Subject: [PATCH 1/9] initial commit of docs --- .gitignore | 2 + docs/api-objects.txt | 21 + docs/browsermobproxy-module.html | 164 +++++ docs/browsermobproxy-pysrc.html | 116 ++++ docs/browsermobproxy.client-module.html | 129 ++++ docs/browsermobproxy.client-pysrc.html | 236 +++++++ docs/browsermobproxy.client.Client-class.html | 607 ++++++++++++++++++ docs/browsermobproxy.server-module.html | 129 ++++ docs/browsermobproxy.server-pysrc.html | 181 ++++++ docs/browsermobproxy.server.Server-class.html | 380 +++++++++++ docs/class-tree.html | 113 ++++ docs/crarr.png | Bin 0 -> 340 bytes docs/epydoc.css | 322 ++++++++++ docs/epydoc.js | 293 +++++++++ docs/frames.html | 17 + docs/help.html | 268 ++++++++ docs/identifier-index.html | 260 ++++++++ docs/index.html | 17 + docs/module-tree.html | 110 ++++ docs/redirect.html | 38 ++ docs/toc-browsermobproxy-module.html | 32 + docs/toc-browsermobproxy.client-module.html | 31 + docs/toc-browsermobproxy.server-module.html | 31 + docs/toc-everything.html | 35 + docs/toc.html | 35 + index.html | 25 + stylesheets/style.css | 21 + 27 files changed, 3613 insertions(+) create mode 100644 .gitignore create mode 100644 docs/api-objects.txt create mode 100644 docs/browsermobproxy-module.html create mode 100644 docs/browsermobproxy-pysrc.html create mode 100644 docs/browsermobproxy.client-module.html create mode 100644 docs/browsermobproxy.client-pysrc.html create mode 100644 docs/browsermobproxy.client.Client-class.html create mode 100644 docs/browsermobproxy.server-module.html create mode 100644 docs/browsermobproxy.server-pysrc.html create mode 100644 docs/browsermobproxy.server.Server-class.html create mode 100644 docs/class-tree.html create mode 100644 docs/crarr.png create mode 100644 docs/epydoc.css create mode 100644 docs/epydoc.js create mode 100644 docs/frames.html create mode 100644 docs/help.html create mode 100644 docs/identifier-index.html create mode 100644 docs/index.html create mode 100644 docs/module-tree.html create mode 100644 docs/redirect.html create mode 100644 docs/toc-browsermobproxy-module.html create mode 100644 docs/toc-browsermobproxy.client-module.html create mode 100644 docs/toc-browsermobproxy.server-module.html create mode 100644 docs/toc-everything.html create mode 100644 docs/toc.html create mode 100644 index.html create mode 100644 stylesheets/style.css diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..3819313 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +*.swp +*.swo diff --git a/docs/api-objects.txt b/docs/api-objects.txt new file mode 100644 index 0000000..521c89d --- /dev/null +++ b/docs/api-objects.txt @@ -0,0 +1,21 @@ +browsermobproxy browsermobproxy-module.html +browsermobproxy.client browsermobproxy.client-module.html +browsermobproxy.server browsermobproxy.server-module.html +browsermobproxy.client.Client browsermobproxy.client.Client-class.html +browsermobproxy.client.Client.new_har browsermobproxy.client.Client-class.html#new_har +browsermobproxy.client.Client.whitelist browsermobproxy.client.Client-class.html#whitelist +browsermobproxy.client.Client.close browsermobproxy.client.Client-class.html#close +browsermobproxy.client.Client.selenium_proxy browsermobproxy.client.Client-class.html#selenium_proxy +browsermobproxy.client.Client.__init__ browsermobproxy.client.Client-class.html#__init__ +browsermobproxy.client.Client.LIMITS browsermobproxy.client.Client-class.html#LIMITS +browsermobproxy.client.Client.har browsermobproxy.client.Client-class.html#har +browsermobproxy.client.Client.blacklist browsermobproxy.client.Client-class.html#blacklist +browsermobproxy.client.Client.new_page browsermobproxy.client.Client-class.html#new_page +browsermobproxy.client.Client.limits browsermobproxy.client.Client-class.html#limits +browsermobproxy.server.Server browsermobproxy.server.Server-class.html +browsermobproxy.server.Server.create_proxy browsermobproxy.server.Server-class.html#create_proxy +browsermobproxy.server.Server.url browsermobproxy.server.Server-class.html#url +browsermobproxy.server.Server._is_listening browsermobproxy.server.Server-class.html#_is_listening +browsermobproxy.server.Server.stop browsermobproxy.server.Server-class.html#stop +browsermobproxy.server.Server.start browsermobproxy.server.Server-class.html#start +browsermobproxy.server.Server.__init__ browsermobproxy.server.Server-class.html#__init__ diff --git a/docs/browsermobproxy-module.html b/docs/browsermobproxy-module.html new file mode 100644 index 0000000..696a83c --- /dev/null +++ b/docs/browsermobproxy-module.html @@ -0,0 +1,164 @@ + + + + + browsermobproxy + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy + + + + + + +
[hide private]
[frames] | no frames]
+
+ +

Package browsermobproxy

source code

+
+

Version: + 0.0.1 +

+
+ + + + + + +
+ + + + + +
Submodules[hide private]
+
+
+ +
+ + + + + + + + + + + + +
+ + + + + +
Variables[hide private]
+
+   + + Server +
+   + + Client +
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy-pysrc.html b/docs/browsermobproxy-pysrc.html new file mode 100644 index 0000000..4dbf9aa --- /dev/null +++ b/docs/browsermobproxy-pysrc.html @@ -0,0 +1,116 @@ + + + + + browsermobproxy + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy + + + + + + +
[hide private]
[frames] | no frames]
+
+

Source Code for Package browsermobproxy

+
+1  __version__ = '0.0.1' 
+2   
+3  from server import Server 
+4  from client import Client 
+5   
+6  __all__ = ['Server', 'Client', 'browsermobproxy'] 
+7   
+
+
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy.client-module.html b/docs/browsermobproxy.client-module.html new file mode 100644 index 0000000..217374f --- /dev/null +++ b/docs/browsermobproxy.client-module.html @@ -0,0 +1,129 @@ + + + + + browsermobproxy.client + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy :: + Module client + + + + + + +
[hide private]
[frames] | no frames]
+
+ +

Module client

source code

+ + + + + + + + + +
+ + + + + +
Classes[hide private]
+
+   + + Client +
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy.client-pysrc.html b/docs/browsermobproxy.client-pysrc.html new file mode 100644 index 0000000..3f4c21b --- /dev/null +++ b/docs/browsermobproxy.client-pysrc.html @@ -0,0 +1,236 @@ + + + + + browsermobproxy.client + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy :: + Module client + + + + + + +
[hide private]
[frames] | no frames]
+
+

Source Code for Module browsermobproxy.client

+
+  1  from httplib2 import Http 
+  2  from urllib import urlencode 
+  3  import json 
+
4 + 5 -class Client(object): +
6 +
7 - def __init__(self, url): +
8 """ + 9 Initialises a new Client object + 10 :Args: + 11 - url: This is where the BrowserMob Proxy lives + 12 """ + 13 self.host = url + 14 h = Http() + 15 resp, content = h.request('%s/proxy' % self.host, 'POST', urlencode('')) + 16 jcontent = json.loads(content) + 17 self.port = jcontent['port'] + 18 url_parts = self.host.split(":") + 19 self.proxy = url_parts[0] + ":" + url_parts[1] + ":" + str(self.port) +
20 +
21 - def new_har(self, ref=None): +
22 """ + 23 This sets a new HAR to be recorded + 24 :Args: + 25 - ref: A reference for the HAR. Defaults to None + 26 """ + 27 h = Http() + 28 resp, content = h.request('%s/proxy/%s/har' % (self.host, self.port), + 29 'PUT', ref or '') +
30 +
31 - def new_page(self, ref): +
32 """ + 33 This sets a new page to be recorded + 34 :Args: + 35 - ref: A reference for the new page. Defaults to None + 36 """ + 37 h = Http() + 38 resp, content = h.request('%s/proxy/%s/har/pageRef' % (self.host, self.port), + 39 'PUT', ref or '') + 40 if content: + 41 return json.loads(content) +
42 + 43 @property +
44 - def har(self): +
45 """ + 46 Gets the HAR that has been recorded + 47 """ + 48 h = Http() + 49 resp, content = h.request('%s/proxy/%s/har' % (self.host, self.port), + 50 'GET') + 51 return json.loads(content) +
52 +
53 - def selenium_proxy(self): +
54 """ + 55 Returns a Selenium WebDriver Proxy class with details of the HTTP Proxy + 56 """ + 57 from selenium import webdriver + 58 return webdriver.Proxy({"httpProxy":self.proxy}) +
59 +
60 - def whitelist(self, regexp, status_code): +
61 """ + 62 Sets a list of URL patterns to whitelist + 63 :Args: + 64 - regex: a comma separated list of regular expressions + 65 - status_code: the HTTP status code to return for URLs that do not match the whitelist + 66 + 67 """ + 68 h = Http() + 69 resp, content = h.request('%s/proxy/%s/whitelist' % (self.host, self.port), + 70 'PUT', urlencode({ 'regex': regexp, 'status': status_code + 71 })) +
72 + 73 +
74 - def blacklist(self, regexp, status_code): +
75 """ + 76 Sets a list of URL patterns to blacklist + 77 :Args: + 78 - regex: a comma separated list of regular expressions + 79 - status_code: the HTTP status code to return for URLs that do not match the blacklist + 80 + 81 """ + 82 + 83 h = Http() + 84 resp, content = h.request('%s/proxy/%s/blacklist' % (self.host, self.port), + 85 'PUT', urlencode({ 'regex': regexp, 'status': status_code + 86 })) +
87 + 88 LIMITS = { + 89 'upstream_kbps' : 'upstreamKbps', + 90 'downstream_kbps' : 'downstreamKbps', + 91 'latency' : 'latency' + 92 } + 93 + 94 +
95 - def limits(self, options): +
96 """ + 97 Limit the bandwidth through the proxy. + 98 :Args: + 99 - options: A dictionary with all the details you want to set. +100 downstreamKbps - Sets the downstream kbps +101 upstreamKbps - Sets the upstream kbps +102 latency - Add the given latency to each HTTP request +103 """ +104 params = {} +105 +106 for (k, v) in options.items(): +107 if not self.LIMITS.has_key(k): +108 raise Exception('invalid key: %s' % k) +109 +110 params[self.LIMITS[k]] = int(v) +111 +112 if len(params.items()) == 0: +113 raise Exception("You need to specify one of the valid Keys") +114 +115 h = Http() +116 resp, content = h.request('%s/proxy/%s/limit' % (self.host, self.port), +117 'PUT', urlencode(params)) +
118 +
119 - def close(self): +
120 """ +121 shuts down the proxy and closes the port +122 """ +123 h = Http() +124 resp, content = h.request('%s/proxy/%s' % (self.host, self.port), +125 'DELETE' ) +
126 +
+
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy.client.Client-class.html b/docs/browsermobproxy.client.Client-class.html new file mode 100644 index 0000000..fc43b8e --- /dev/null +++ b/docs/browsermobproxy.client.Client-class.html @@ -0,0 +1,607 @@ + + + + + browsermobproxy.client.Client + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy :: + Module client :: + Class Client + + + + + + +
[hide private]
[frames] | no frames]
+
+ +

Class Client

source code

+
+object --+
+         |
+        Client
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + +
Instance Methods[hide private]
+
+   + + + + + + +
__init__(self, + url)
+ Initialises a new Client object :Args:
+ source code + +
+ +
+   + + + + + + +
new_har(self, + ref=None)
+ This sets a new HAR to be recorded :Args:
+ source code + +
+ +
+   + + + + + + +
new_page(self, + ref)
+ This sets a new page to be recorded :Args:
+ source code + +
+ +
+   + + + + + + +
har(self)
+ Gets the HAR that has been recorded
+ source code + +
+ +
+   + + + + + + +
selenium_proxy(self)
+ Returns a Selenium WebDriver Proxy class with details of the HTTP + Proxy
+ source code + +
+ +
+   + + + + + + +
whitelist(self, + regexp, + status_code)
+ Sets a list of URL patterns to whitelist :Args:
+ source code + +
+ +
+   + + + + + + +
blacklist(self, + regexp, + status_code)
+ Sets a list of URL patterns to blacklist :Args:
+ source code + +
+ +
+   + + + + + + +
limits(self, + options)
+ Limit the bandwidth through the proxy.
+ source code + +
+ +
+   + + + + + + +
close(self)
+ shuts down the proxy and closes the port
+ source code + +
+ +
+

Inherited from object: + __delattr__, + __format__, + __getattribute__, + __hash__, + __new__, + __reduce__, + __reduce_ex__, + __repr__, + __setattr__, + __sizeof__, + __str__, + __subclasshook__ +

+
+ + + + + + + + + +
+ + + + + +
Class Variables[hide private]
+
+   + + LIMITS = {'upstream_kbps': 'upstreamKbps', 'downstream_kbps': ... +
+ + + + + + + + + +
+ + + + + +
Properties[hide private]
+
+

Inherited from object: + __class__ +

+
+ + + + + + +
+ + + + + +
Method Details[hide private]
+
+ +
+ +
+ + +
+

__init__(self, + url) +
(Constructor) +

+
source code  +
+ +

Initialises a new Client object :Args:

+
    +
  • + url: This is where the BrowserMob Proxy lives +
  • +
+
+
Overrides: + object.__init__ +
+
+
+
+ +
+ +
+ + +
+

new_har(self, + ref=None) +

+
source code  +
+ +

This sets a new HAR to be recorded :Args:

+
    +
  • + ref: A reference for the HAR. Defaults to None +
  • +
+
+
+
+
+ +
+ +
+ + +
+

new_page(self, + ref) +

+
source code  +
+ +

This sets a new page to be recorded :Args:

+
    +
  • + ref: A reference for the new page. Defaults to None +
  • +
+
+
+
+
+ +
+ +
+ + +
+

har(self) +

+
source code  +
+ +

Gets the HAR that has been recorded

+
+
Decorators:
+
    +
  • @property
  • +
+
+
+
+ +
+ +
+ + +
+

whitelist(self, + regexp, + status_code) +

+
source code  +
+ +

Sets a list of URL patterns to whitelist :Args:

+
    +
  • + regex: a comma separated list of regular expressions +
  • +
  • + status_code: the HTTP status code to return for URLs that do not + match the whitelist +
  • +
+
+
+
+
+ +
+ +
+ + +
+

blacklist(self, + regexp, + status_code) +

+
source code  +
+ +

Sets a list of URL patterns to blacklist :Args:

+
    +
  • + regex: a comma separated list of regular expressions +
  • +
  • + status_code: the HTTP status code to return for URLs that do not + match the blacklist +
  • +
+
+
+
+
+ +
+ +
+ + +
+

limits(self, + options) +

+
source code  +
+ +

Limit the bandwidth through the proxy. :Args:

+
    +
  • + options: A dictionary with all the details you want to set. + downstreamKbps - Sets the downstream kbps upstreamKbps - Sets the + upstream kbps latency - Add the given latency to each HTTP request +
  • +
+
+
+
+
+
+ + + + + + +
+ + + + + +
Class Variable Details[hide private]
+
+ +
+ +
+

LIMITS

+ +
+
+
+
Value:
+
+{'upstream_kbps': 'upstreamKbps', 'downstream_kbps': 'downstreamKbps',\
+ 'latency': 'latency'}
+
+
+
+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy.server-module.html b/docs/browsermobproxy.server-module.html new file mode 100644 index 0000000..8540363 --- /dev/null +++ b/docs/browsermobproxy.server-module.html @@ -0,0 +1,129 @@ + + + + + browsermobproxy.server + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy :: + Module server + + + + + + +
[hide private]
[frames] | no frames]
+
+ +

Module server

source code

+ + + + + + + + + +
+ + + + + +
Classes[hide private]
+
+   + + Server +
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy.server-pysrc.html b/docs/browsermobproxy.server-pysrc.html new file mode 100644 index 0000000..9c8b043 --- /dev/null +++ b/docs/browsermobproxy.server-pysrc.html @@ -0,0 +1,181 @@ + + + + + browsermobproxy.server + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy :: + Module server + + + + + + +
[hide private]
[frames] | no frames]
+
+

Source Code for Module browsermobproxy.server

+
+ 1  from subprocess import Popen, PIPE, STDOUT 
+ 2  import socket 
+ 3  import time 
+ 4   
+ 5  from client import Client 
+
6 + 7 + 8 -class Server(object): +
9 +
10 - def __init__(self, path, options={}): +
11 """ +12 Initialises a Server object +13 +14 :Args: +15 - path : Path to the browsermob proxy batch file +16 - options : Dictionary that can hold the port. More items will be added in the future. +17 This defaults to an empty dictionary +18 """ +19 self.path = path +20 self.port = options['port'] if options.has_key('port') else 8080 +21 self.command = ['sh', path, '--port=%s' % self.port] +
22 +
23 - def start(self): +
24 """ +25 This will start the browsermob proxy and then wait until it can interact with it +26 """ +27 self.process = Popen(self.command, stdout=PIPE, stderr=STDOUT) +28 count = 0 +29 while not self._is_listening(): +30 time.sleep(0.1) +31 count += 1 +32 if count == 30: +33 raise Exception("Can't connect to Browsermob-Proxy") +
34 +
35 - def stop(self): +
36 """ +37 This will stop the process running the proxy +38 """ +39 try: +40 if self.process: +41 self.process.kill() +42 self.process.wait() +43 except AttributeError: +44 # kill may not be available under windows environment +45 pass +
46 +47 @property +
48 - def url(self): +
49 """ +50 Gets the url that the proxy is running on. This is not the URL clients should connect to. +51 """ +52 return "http://localhost:%d" % self.port +
53 +54 @property +
55 - def create_proxy(self): +
56 """ +57 Gets a client class that allow to set all the proxy details that you may need to. +58 """ +59 client = Client(self.url) +60 return client +
61 +
62 - def _is_listening(self): +
63 try: +64 socket_ = socket.socket(socket.AF_INET, socket.SOCK_STREAM) +65 socket_.settimeout(1) +66 socket_.connect(("localhost", self.port)) +67 socket_.close() +68 return True +69 except socket.error: +70 return False +
71 +
+
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/browsermobproxy.server.Server-class.html b/docs/browsermobproxy.server.Server-class.html new file mode 100644 index 0000000..54b3889 --- /dev/null +++ b/docs/browsermobproxy.server.Server-class.html @@ -0,0 +1,380 @@ + + + + + browsermobproxy.server.Server + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + Package browsermobproxy :: + Module server :: + Class Server + + + + + + +
[hide private]
[frames] | no frames]
+
+ +

Class Server

source code

+
+object --+
+         |
+        Server
+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + + +
Instance Methods[hide private]
+
+   + + + + + + +
__init__(self, + path, + options={})
+ Initialises a Server object
+ source code + +
+ +
+   + + + + + + +
start(self)
+ This will start the browsermob proxy and then wait until it can + interact with it
+ source code + +
+ +
+   + + + + + + +
stop(self)
+ This will stop the process running the proxy
+ source code + +
+ +
+   + + + + + + +
url(self)
+ Gets the url that the proxy is running on.
+ source code + +
+ +
+   + + + + + + +
create_proxy(self)
+ Gets a client class that allow to set all the proxy details that you + may need to.
+ source code + +
+ +
+   + + + + + + +
_is_listening(self) + source code + +
+ +
+

Inherited from object: + __delattr__, + __format__, + __getattribute__, + __hash__, + __new__, + __reduce__, + __reduce_ex__, + __repr__, + __setattr__, + __sizeof__, + __str__, + __subclasshook__ +

+
+ + + + + + + + + +
+ + + + + +
Properties[hide private]
+
+

Inherited from object: + __class__ +

+
+ + + + + + +
+ + + + + +
Method Details[hide private]
+
+ +
+ +
+ + +
+

__init__(self, + path, + options={}) +
(Constructor) +

+
source code  +
+ +

Initialises a Server object

+

:Args:

+
    +
  • + path : Path to the browsermob proxy batch file +
  • +
  • + options : Dictionary that can hold the port. More items will be added + in the future. This defaults to an empty dictionary +
  • +
+
+
Overrides: + object.__init__ +
+
+
+
+ +
+ +
+ + +
+

url(self) +

+
source code  +
+ +

Gets the url that the proxy is running on. This is not the URL clients + should connect to.

+
+
Decorators:
+
    +
  • @property
  • +
+
+
+
+ +
+ +
+ + +
+

create_proxy(self) +

+
source code  +
+ +

Gets a client class that allow to set all the proxy details that you + may need to.

+
+
Decorators:
+
    +
  • @property
  • +
+
+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/class-tree.html b/docs/class-tree.html new file mode 100644 index 0000000..57ef2e3 --- /dev/null +++ b/docs/class-tree.html @@ -0,0 +1,113 @@ + + + + + Class Hierarchy + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
  + + + + +
[hide private]
[frames] | no frames]
+
+
+ [ Module Hierarchy + | Class Hierarchy ] +

+

Class Hierarchy

+ + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/crarr.png b/docs/crarr.png new file mode 100644 index 0000000000000000000000000000000000000000..26b43c52433b71e72a9a478c52d446278335f0e4 GIT binary patch literal 340 zcmeAS@N?(olHy`uVBq!ia0vp^f?NMQuI$%1#8??M1uoZK z0}62#ctjR6FvuMOVaB`*rFK9;mUKs7M+SzC{oH>NS%G}l0G|-o|NsA=J-p%i`2!7U zCdJ_j4{u-SDsoA1U`TRixpVcz%O`iHHAYk?=&YaLkmD!Pp6~GW^M_S4D^grJKD>P~ zuPf!ku`N^TLavn`Edv_JSQ6wH%;50sMjDXg>*?YcQgJIe!GUqln>_|<+Os&OOUQS1 zY~Wzutud*iVS#|PHMc&?2WHoZpEo8l+6!Oc$x~=%U)469Gl^f?nq7UBw#1AXkrEde cmFKWBXcRFE*(?@T0vgQV>FVdQ&MBb@0LpZ4r2qf` literal 0 HcmV?d00001 diff --git a/docs/epydoc.css b/docs/epydoc.css new file mode 100644 index 0000000..86d4170 --- /dev/null +++ b/docs/epydoc.css @@ -0,0 +1,322 @@ + + +/* Epydoc CSS Stylesheet + * + * This stylesheet can be used to customize the appearance of epydoc's + * HTML output. + * + */ + +/* Default Colors & Styles + * - Set the default foreground & background color with 'body'; and + * link colors with 'a:link' and 'a:visited'. + * - Use bold for decision list terms. + * - The heading styles defined here are used for headings *within* + * docstring descriptions. All headings used by epydoc itself use + * either class='epydoc' or class='toc' (CSS styles for both + * defined below). + */ +body { background: #ffffff; color: #000000; } +p { margin-top: 0.5em; margin-bottom: 0.5em; } +a:link { color: #0000ff; } +a:visited { color: #204080; } +dt { font-weight: bold; } +h1 { font-size: +140%; font-style: italic; + font-weight: bold; } +h2 { font-size: +125%; font-style: italic; + font-weight: bold; } +h3 { font-size: +110%; font-style: italic; + font-weight: normal; } +code { font-size: 100%; } +/* N.B.: class, not pseudoclass */ +a.link { font-family: monospace; } + +/* Page Header & Footer + * - The standard page header consists of a navigation bar (with + * pointers to standard pages such as 'home' and 'trees'); a + * breadcrumbs list, which can be used to navigate to containing + * classes or modules; options links, to show/hide private + * variables and to show/hide frames; and a page title (using + *

). The page title may be followed by a link to the + * corresponding source code (using 'span.codelink'). + * - The footer consists of a navigation bar, a timestamp, and a + * pointer to epydoc's homepage. + */ +h1.epydoc { margin: 0; font-size: +140%; font-weight: bold; } +h2.epydoc { font-size: +130%; font-weight: bold; } +h3.epydoc { font-size: +115%; font-weight: bold; + margin-top: 0.2em; } +td h3.epydoc { font-size: +115%; font-weight: bold; + margin-bottom: 0; } +table.navbar { background: #a0c0ff; color: #000000; + border: 2px groove #c0d0d0; } +table.navbar table { color: #000000; } +th.navbar-select { background: #70b0ff; + color: #000000; } +table.navbar a { text-decoration: none; } +table.navbar a:link { color: #0000ff; } +table.navbar a:visited { color: #204080; } +span.breadcrumbs { font-size: 85%; font-weight: bold; } +span.options { font-size: 70%; } +span.codelink { font-size: 85%; } +td.footer { font-size: 85%; } + +/* Table Headers + * - Each summary table and details section begins with a 'header' + * row. This row contains a section title (marked by + * 'span.table-header') as well as a show/hide private link + * (marked by 'span.options', defined above). + * - Summary tables that contain user-defined groups mark those + * groups using 'group header' rows. + */ +td.table-header { background: #70b0ff; color: #000000; + border: 1px solid #608090; } +td.table-header table { color: #000000; } +td.table-header table a:link { color: #0000ff; } +td.table-header table a:visited { color: #204080; } +span.table-header { font-size: 120%; font-weight: bold; } +th.group-header { background: #c0e0f8; color: #000000; + text-align: left; font-style: italic; + font-size: 115%; + border: 1px solid #608090; } + +/* Summary Tables (functions, variables, etc) + * - Each object is described by a single row of the table with + * two cells. The left cell gives the object's type, and is + * marked with 'code.summary-type'. The right cell gives the + * object's name and a summary description. + * - CSS styles for the table's header and group headers are + * defined above, under 'Table Headers' + */ +table.summary { border-collapse: collapse; + background: #e8f0f8; color: #000000; + border: 1px solid #608090; + margin-bottom: 0.5em; } +td.summary { border: 1px solid #608090; } +code.summary-type { font-size: 85%; } +table.summary a:link { color: #0000ff; } +table.summary a:visited { color: #204080; } + + +/* Details Tables (functions, variables, etc) + * - Each object is described in its own div. + * - A single-row summary table w/ table-header is used as + * a header for each details section (CSS style for table-header + * is defined above, under 'Table Headers'). + */ +table.details { border-collapse: collapse; + background: #e8f0f8; color: #000000; + border: 1px solid #608090; + margin: .2em 0 0 0; } +table.details table { color: #000000; } +table.details a:link { color: #0000ff; } +table.details a:visited { color: #204080; } + +/* Fields */ +dl.fields { margin-left: 2em; margin-top: 1em; + margin-bottom: 1em; } +dl.fields dd ul { margin-left: 0em; padding-left: 0em; } +dl.fields dd ul li ul { margin-left: 2em; padding-left: 0em; } +div.fields { margin-left: 2em; } +div.fields p { margin-bottom: 0.5em; } + +/* Index tables (identifier index, term index, etc) + * - link-index is used for indices containing lists of links + * (namely, the identifier index & term index). + * - index-where is used in link indices for the text indicating + * the container/source for each link. + * - metadata-index is used for indices containing metadata + * extracted from fields (namely, the bug index & todo index). + */ +table.link-index { border-collapse: collapse; + background: #e8f0f8; color: #000000; + border: 1px solid #608090; } +td.link-index { border-width: 0px; } +table.link-index a:link { color: #0000ff; } +table.link-index a:visited { color: #204080; } +span.index-where { font-size: 70%; } +table.metadata-index { border-collapse: collapse; + background: #e8f0f8; color: #000000; + border: 1px solid #608090; + margin: .2em 0 0 0; } +td.metadata-index { border-width: 1px; border-style: solid; } +table.metadata-index a:link { color: #0000ff; } +table.metadata-index a:visited { color: #204080; } + +/* Function signatures + * - sig* is used for the signature in the details section. + * - .summary-sig* is used for the signature in the summary + * table, and when listing property accessor functions. + * */ +.sig-name { color: #006080; } +.sig-arg { color: #008060; } +.sig-default { color: #602000; } +.summary-sig { font-family: monospace; } +.summary-sig-name { color: #006080; font-weight: bold; } +table.summary a.summary-sig-name:link + { color: #006080; font-weight: bold; } +table.summary a.summary-sig-name:visited + { color: #006080; font-weight: bold; } +.summary-sig-arg { color: #006040; } +.summary-sig-default { color: #501800; } + +/* Subclass list + */ +ul.subclass-list { display: inline; } +ul.subclass-list li { display: inline; } + +/* To render variables, classes etc. like functions */ +table.summary .summary-name { color: #006080; font-weight: bold; + font-family: monospace; } +table.summary + a.summary-name:link { color: #006080; font-weight: bold; + font-family: monospace; } +table.summary + a.summary-name:visited { color: #006080; font-weight: bold; + font-family: monospace; } + +/* Variable values + * - In the 'variable details' sections, each varaible's value is + * listed in a 'pre.variable' box. The width of this box is + * restricted to 80 chars; if the value's repr is longer than + * this it will be wrapped, using a backslash marked with + * class 'variable-linewrap'. If the value's repr is longer + * than 3 lines, the rest will be ellided; and an ellipsis + * marker ('...' marked with 'variable-ellipsis') will be used. + * - If the value is a string, its quote marks will be marked + * with 'variable-quote'. + * - If the variable is a regexp, it is syntax-highlighted using + * the re* CSS classes. + */ +pre.variable { padding: .5em; margin: 0; + background: #dce4ec; color: #000000; + border: 1px solid #708890; } +.variable-linewrap { color: #604000; font-weight: bold; } +.variable-ellipsis { color: #604000; font-weight: bold; } +.variable-quote { color: #604000; font-weight: bold; } +.variable-group { color: #008000; font-weight: bold; } +.variable-op { color: #604000; font-weight: bold; } +.variable-string { color: #006030; } +.variable-unknown { color: #a00000; font-weight: bold; } +.re { color: #000000; } +.re-char { color: #006030; } +.re-op { color: #600000; } +.re-group { color: #003060; } +.re-ref { color: #404040; } + +/* Base tree + * - Used by class pages to display the base class hierarchy. + */ +pre.base-tree { font-size: 80%; margin: 0; } + +/* Frames-based table of contents headers + * - Consists of two frames: one for selecting modules; and + * the other listing the contents of the selected module. + * - h1.toc is used for each frame's heading + * - h2.toc is used for subheadings within each frame. + */ +h1.toc { text-align: center; font-size: 105%; + margin: 0; font-weight: bold; + padding: 0; } +h2.toc { font-size: 100%; font-weight: bold; + margin: 0.5em 0 0 -0.3em; } + +/* Syntax Highlighting for Source Code + * - doctest examples are displayed in a 'pre.py-doctest' block. + * If the example is in a details table entry, then it will use + * the colors specified by the 'table pre.py-doctest' line. + * - Source code listings are displayed in a 'pre.py-src' block. + * Each line is marked with 'span.py-line' (used to draw a line + * down the left margin, separating the code from the line + * numbers). Line numbers are displayed with 'span.py-lineno'. + * The expand/collapse block toggle button is displayed with + * 'a.py-toggle' (Note: the CSS style for 'a.py-toggle' should not + * modify the font size of the text.) + * - If a source code page is opened with an anchor, then the + * corresponding code block will be highlighted. The code + * block's header is highlighted with 'py-highlight-hdr'; and + * the code block's body is highlighted with 'py-highlight'. + * - The remaining py-* classes are used to perform syntax + * highlighting (py-string for string literals, py-name for names, + * etc.) + */ +pre.py-doctest { padding: .5em; margin: 1em; + background: #e8f0f8; color: #000000; + border: 1px solid #708890; } +table pre.py-doctest { background: #dce4ec; + color: #000000; } +pre.py-src { border: 2px solid #000000; + background: #f0f0f0; color: #000000; } +.py-line { border-left: 2px solid #000000; + margin-left: .2em; padding-left: .4em; } +.py-lineno { font-style: italic; font-size: 90%; + padding-left: .5em; } +a.py-toggle { text-decoration: none; } +div.py-highlight-hdr { border-top: 2px solid #000000; + border-bottom: 2px solid #000000; + background: #d8e8e8; } +div.py-highlight { border-bottom: 2px solid #000000; + background: #d0e0e0; } +.py-prompt { color: #005050; font-weight: bold;} +.py-more { color: #005050; font-weight: bold;} +.py-string { color: #006030; } +.py-comment { color: #003060; } +.py-keyword { color: #600000; } +.py-output { color: #404040; } +.py-name { color: #000050; } +.py-name:link { color: #000050 !important; } +.py-name:visited { color: #000050 !important; } +.py-number { color: #005000; } +.py-defname { color: #000060; font-weight: bold; } +.py-def-name { color: #000060; font-weight: bold; } +.py-base-class { color: #000060; } +.py-param { color: #000060; } +.py-docstring { color: #006030; } +.py-decorator { color: #804020; } +/* Use this if you don't want links to names underlined: */ +/*a.py-name { text-decoration: none; }*/ + +/* Graphs & Diagrams + * - These CSS styles are used for graphs & diagrams generated using + * Graphviz dot. 'img.graph-without-title' is used for bare + * diagrams (to remove the border created by making the image + * clickable). + */ +img.graph-without-title { border: none; } +img.graph-with-title { border: 1px solid #000000; } +span.graph-title { font-weight: bold; } +span.graph-caption { } + +/* General-purpose classes + * - 'p.indent-wrapped-lines' defines a paragraph whose first line + * is not indented, but whose subsequent lines are. + * - The 'nomargin-top' class is used to remove the top margin (e.g. + * from lists). The 'nomargin' class is used to remove both the + * top and bottom margin (but not the left or right margin -- + * for lists, that would cause the bullets to disappear.) + */ +p.indent-wrapped-lines { padding: 0 0 0 7em; text-indent: -7em; + margin: 0; } +.nomargin-top { margin-top: 0; } +.nomargin { margin-top: 0; margin-bottom: 0; } + +/* HTML Log */ +div.log-block { padding: 0; margin: .5em 0 .5em 0; + background: #e8f0f8; color: #000000; + border: 1px solid #000000; } +div.log-error { padding: .1em .3em .1em .3em; margin: 4px; + background: #ffb0b0; color: #000000; + border: 1px solid #000000; } +div.log-warning { padding: .1em .3em .1em .3em; margin: 4px; + background: #ffffb0; color: #000000; + border: 1px solid #000000; } +div.log-info { padding: .1em .3em .1em .3em; margin: 4px; + background: #b0ffb0; color: #000000; + border: 1px solid #000000; } +h2.log-hdr { background: #70b0ff; color: #000000; + margin: 0; padding: 0em 0.5em 0em 0.5em; + border-bottom: 1px solid #000000; font-size: 110%; } +p.log { font-weight: bold; margin: .5em 0 .5em 0; } +tr.opt-changed { color: #000000; font-weight: bold; } +tr.opt-default { color: #606060; } +pre.log { margin: 0; padding: 0; padding-left: 1em; } diff --git a/docs/epydoc.js b/docs/epydoc.js new file mode 100644 index 0000000..e787dbc --- /dev/null +++ b/docs/epydoc.js @@ -0,0 +1,293 @@ +function toggle_private() { + // Search for any private/public links on this page. Store + // their old text in "cmd," so we will know what action to + // take; and change their text to the opposite action. + var cmd = "?"; + var elts = document.getElementsByTagName("a"); + for(var i=0; i...
"; + elt.innerHTML = s; + } +} + +function toggle(id) { + elt = document.getElementById(id+"-toggle"); + if (elt.innerHTML == "-") + collapse(id); + else + expand(id); + return false; +} + +function highlight(id) { + var elt = document.getElementById(id+"-def"); + if (elt) elt.className = "py-highlight-hdr"; + var elt = document.getElementById(id+"-expanded"); + if (elt) elt.className = "py-highlight"; + var elt = document.getElementById(id+"-collapsed"); + if (elt) elt.className = "py-highlight"; +} + +function num_lines(s) { + var n = 1; + var pos = s.indexOf("\n"); + while ( pos > 0) { + n += 1; + pos = s.indexOf("\n", pos+1); + } + return n; +} + +// Collapse all blocks that mave more than `min_lines` lines. +function collapse_all(min_lines) { + var elts = document.getElementsByTagName("div"); + for (var i=0; i 0) + if (elt.id.substring(split, elt.id.length) == "-expanded") + if (num_lines(elt.innerHTML) > min_lines) + collapse(elt.id.substring(0, split)); + } +} + +function expandto(href) { + var start = href.indexOf("#")+1; + if (start != 0 && start != href.length) { + if (href.substring(start, href.length) != "-") { + collapse_all(4); + pos = href.indexOf(".", start); + while (pos != -1) { + var id = href.substring(start, pos); + expand(id); + pos = href.indexOf(".", pos+1); + } + var id = href.substring(start, href.length); + expand(id); + highlight(id); + } + } +} + +function kill_doclink(id) { + var parent = document.getElementById(id); + parent.removeChild(parent.childNodes.item(0)); +} +function auto_kill_doclink(ev) { + if (!ev) var ev = window.event; + if (!this.contains(ev.toElement)) { + var parent = document.getElementById(this.parentID); + parent.removeChild(parent.childNodes.item(0)); + } +} + +function doclink(id, name, targets_id) { + var elt = document.getElementById(id); + + // If we already opened the box, then destroy it. + // (This case should never occur, but leave it in just in case.) + if (elt.childNodes.length > 1) { + elt.removeChild(elt.childNodes.item(0)); + } + else { + // The outer box: relative + inline positioning. + var box1 = document.createElement("div"); + box1.style.position = "relative"; + box1.style.display = "inline"; + box1.style.top = 0; + box1.style.left = 0; + + // A shadow for fun + var shadow = document.createElement("div"); + shadow.style.position = "absolute"; + shadow.style.left = "-1.3em"; + shadow.style.top = "-1.3em"; + shadow.style.background = "#404040"; + + // The inner box: absolute positioning. + var box2 = document.createElement("div"); + box2.style.position = "relative"; + box2.style.border = "1px solid #a0a0a0"; + box2.style.left = "-.2em"; + box2.style.top = "-.2em"; + box2.style.background = "white"; + box2.style.padding = ".3em .4em .3em .4em"; + box2.style.fontStyle = "normal"; + box2.onmouseout=auto_kill_doclink; + box2.parentID = id; + + // Get the targets + var targets_elt = document.getElementById(targets_id); + var targets = targets_elt.getAttribute("targets"); + var links = ""; + target_list = targets.split(","); + for (var i=0; i" + + target[0] + ""; + } + + // Put it all together. + elt.insertBefore(box1, elt.childNodes.item(0)); + //box1.appendChild(box2); + box1.appendChild(shadow); + shadow.appendChild(box2); + box2.innerHTML = + "Which "+name+" do you want to see documentation for?" + + ""; + } + return false; +} + +function get_anchor() { + var href = location.href; + var start = href.indexOf("#")+1; + if ((start != 0) && (start != href.length)) + return href.substring(start, href.length); + } +function redirect_url(dottedName) { + // Scan through each element of the "pages" list, and check + // if "name" matches with any of them. + for (var i=0; i-m" or "-c"; + // extract the portion & compare it to dottedName. + var pagename = pages[i].substring(0, pages[i].length-2); + if (pagename == dottedName.substring(0,pagename.length)) { + + // We've found a page that matches `dottedName`; + // construct its URL, using leftover `dottedName` + // content to form an anchor. + var pagetype = pages[i].charAt(pages[i].length-1); + var url = pagename + ((pagetype=="m")?"-module.html": + "-class.html"); + if (dottedName.length > pagename.length) + url += "#" + dottedName.substring(pagename.length+1, + dottedName.length); + return url; + } + } + } diff --git a/docs/frames.html b/docs/frames.html new file mode 100644 index 0000000..2556081 --- /dev/null +++ b/docs/frames.html @@ -0,0 +1,17 @@ + + + + + API Documentation + + + + + + + + + diff --git a/docs/help.html b/docs/help.html new file mode 100644 index 0000000..b4ddb60 --- /dev/null +++ b/docs/help.html @@ -0,0 +1,268 @@ + + + + + Help + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
  + + + + +
[hide private]
[frames] | no frames]
+
+ +

API Documentation

+ +

This document contains the API (Application Programming Interface) +documentation for this project. Documentation for the Python +objects defined by the project is divided into separate pages for each +package, module, and class. The API documentation also includes two +pages containing information about the project as a whole: a trees +page, and an index page.

+ +

Object Documentation

+ +

Each Package Documentation page contains:

+
    +
  • A description of the package.
  • +
  • A list of the modules and sub-packages contained by the + package.
  • +
  • A summary of the classes defined by the package.
  • +
  • A summary of the functions defined by the package.
  • +
  • A summary of the variables defined by the package.
  • +
  • A detailed description of each function defined by the + package.
  • +
  • A detailed description of each variable defined by the + package.
  • +
+ +

Each Module Documentation page contains:

+
    +
  • A description of the module.
  • +
  • A summary of the classes defined by the module.
  • +
  • A summary of the functions defined by the module.
  • +
  • A summary of the variables defined by the module.
  • +
  • A detailed description of each function defined by the + module.
  • +
  • A detailed description of each variable defined by the + module.
  • +
+ +

Each Class Documentation page contains:

+
    +
  • A class inheritance diagram.
  • +
  • A list of known subclasses.
  • +
  • A description of the class.
  • +
  • A summary of the methods defined by the class.
  • +
  • A summary of the instance variables defined by the class.
  • +
  • A summary of the class (static) variables defined by the + class.
  • +
  • A detailed description of each method defined by the + class.
  • +
  • A detailed description of each instance variable defined by the + class.
  • +
  • A detailed description of each class (static) variable defined + by the class.
  • +
+ +

Project Documentation

+ +

The Trees page contains the module and class hierarchies:

+
    +
  • The module hierarchy lists every package and module, with + modules grouped into packages. At the top level, and within each + package, modules and sub-packages are listed alphabetically.
  • +
  • The class hierarchy lists every class, grouped by base + class. If a class has more than one base class, then it will be + listed under each base class. At the top level, and under each base + class, classes are listed alphabetically.
  • +
+ +

The Index page contains indices of terms and + identifiers:

+
    +
  • The term index lists every term indexed by any object's + documentation. For each term, the index provides links to each + place where the term is indexed.
  • +
  • The identifier index lists the (short) name of every package, + module, class, method, function, variable, and parameter. For each + identifier, the index provides a short description, and a link to + its documentation.
  • +
+ +

The Table of Contents

+ +

The table of contents occupies the two frames on the left side of +the window. The upper-left frame displays the project +contents, and the lower-left frame displays the module +contents:

+ + + + + + + + + +
+ Project
Contents
...
+ API
Documentation
Frame


+
+ Module
Contents
 
...
  +

+ +

The project contents frame contains a list of all packages +and modules that are defined by the project. Clicking on an entry +will display its contents in the module contents frame. Clicking on a +special entry, labeled "Everything," will display the contents of +the entire project.

+ +

The module contents frame contains a list of every +submodule, class, type, exception, function, and variable defined by a +module or package. Clicking on an entry will display its +documentation in the API documentation frame. Clicking on the name of +the module, at the top of the frame, will display the documentation +for the module itself.

+ +

The "frames" and "no frames" buttons below the top +navigation bar can be used to control whether the table of contents is +displayed or not.

+ +

The Navigation Bar

+ +

A navigation bar is located at the top and bottom of every page. +It indicates what type of page you are currently viewing, and allows +you to go to related pages. The following table describes the labels +on the navigation bar. Note that not some labels (such as +[Parent]) are not displayed on all pages.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + +
LabelHighlighted when...Links to...
[Parent](never highlighted) the parent of the current package
[Package]viewing a packagethe package containing the current object +
[Module]viewing a modulethe module containing the current object +
[Class]viewing a class the class containing the current object
[Trees]viewing the trees page the trees page
[Index]viewing the index page the index page
[Help]viewing the help page the help page
+ +

The "show private" and "hide private" buttons below +the top navigation bar can be used to control whether documentation +for private objects is displayed. Private objects are usually defined +as objects whose (short) names begin with a single underscore, but do +not end with an underscore. For example, "_x", +"__pprint", and "epydoc.epytext._tokenize" +are private objects; but "re.sub", +"__init__", and "type_" are not. However, +if a module defines the "__all__" variable, then its +contents are used to decide which objects are private.

+ +

A timestamp below the bottom navigation bar indicates when each +page was last updated.

+ + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/identifier-index.html b/docs/identifier-index.html new file mode 100644 index 0000000..bc4bc78 --- /dev/null +++ b/docs/identifier-index.html @@ -0,0 +1,260 @@ + + + + + Identifier Index + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
  + + + + +
[hide private]
[frames] | no frames]
+
+ +
+

Identifier Index

+
+[ + A + B + C + D + E + F + G + H + I + J + K + L + M + N + O + P + Q + R + S + T + U + V + W + X + Y + Z + _ +] +
+ + + + + + + + + + + + + + + + + + + +

B

+ + + + + + + + +

C

+ + + + + + + + + + + + +

H

+ + + + + + + + +

L

+ + + + + + + + +

N

+ + + + + + + + +

S

+ + + + + + + + + + + + +

U

+ + + + + + + + +

W

+ + + + + + + + +

_

+ + + + + + + + +
+

+ + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/index.html b/docs/index.html new file mode 100644 index 0000000..2556081 --- /dev/null +++ b/docs/index.html @@ -0,0 +1,17 @@ + + + + + API Documentation + + + + + + + + + diff --git a/docs/module-tree.html b/docs/module-tree.html new file mode 100644 index 0000000..b1b3365 --- /dev/null +++ b/docs/module-tree.html @@ -0,0 +1,110 @@ + + + + + Module Hierarchy + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
  + + + + +
[hide private]
[frames] | no frames]
+
+
+ [ Module Hierarchy + | Class Hierarchy ] +

+

Module Hierarchy

+ + + + + + + + + + + + + + + + + + + + + + + + +
+ + + + diff --git a/docs/redirect.html b/docs/redirect.html new file mode 100644 index 0000000..3674f1d --- /dev/null +++ b/docs/redirect.html @@ -0,0 +1,38 @@ +Epydoc Redirect Page + + + + + + + + +

Epydoc Auto-redirect page

+ +

When javascript is enabled, this page will redirect URLs of +the form redirect.html#dotted.name to the +documentation for the object with the given fully-qualified +dotted name.

+

 

+ + + + + diff --git a/docs/toc-browsermobproxy-module.html b/docs/toc-browsermobproxy-module.html new file mode 100644 index 0000000..ad8c4f8 --- /dev/null +++ b/docs/toc-browsermobproxy-module.html @@ -0,0 +1,32 @@ + + + + + browsermobproxy + + + + + +

Module browsermobproxy

+
+

Variables

+ Client
Server

+[hide private] + + + + diff --git a/docs/toc-browsermobproxy.client-module.html b/docs/toc-browsermobproxy.client-module.html new file mode 100644 index 0000000..82ea832 --- /dev/null +++ b/docs/toc-browsermobproxy.client-module.html @@ -0,0 +1,31 @@ + + + + + client + + + + + +

Module client

+
+

Classes

+ Client

+[hide private] + + + + diff --git a/docs/toc-browsermobproxy.server-module.html b/docs/toc-browsermobproxy.server-module.html new file mode 100644 index 0000000..731a9e4 --- /dev/null +++ b/docs/toc-browsermobproxy.server-module.html @@ -0,0 +1,31 @@ + + + + + server + + + + + +

Module server

+
+

Classes

+ Server

+[hide private] + + + + diff --git a/docs/toc-everything.html b/docs/toc-everything.html new file mode 100644 index 0000000..001f345 --- /dev/null +++ b/docs/toc-everything.html @@ -0,0 +1,35 @@ + + + + + Everything + + + + + +

Everything

+
+

All Classes

+ browsermobproxy.client.Client
browsermobproxy.server.Server

All Variables

+ browsermobproxy.Client
browsermobproxy.Server

+[hide private] + + + + diff --git a/docs/toc.html b/docs/toc.html new file mode 100644 index 0000000..8706e03 --- /dev/null +++ b/docs/toc.html @@ -0,0 +1,35 @@ + + + + + Table of Contents + + + + + +

Table of Contents

+
+ Everything +
+

Modules

+ browsermobproxy
browsermobproxy.client
browsermobproxy.server

+ [hide private] + + + + diff --git a/index.html b/index.html new file mode 100644 index 0000000..a5d803e --- /dev/null +++ b/index.html @@ -0,0 +1,25 @@ + + + + Python Browsermob Proxy Library + + + +
 
+
+

Python Browsermob Proxy Library

+

+ This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the Pydocs. Note that this will only work with Selenium 2.17 onwards. +

+ +

+

Releases

+

0.0.1

+
    +
  • Initial release
  • +
+

+
+ Fork me on GitHub + + diff --git a/stylesheets/style.css b/stylesheets/style.css new file mode 100644 index 0000000..f47c480 --- /dev/null +++ b/stylesheets/style.css @@ -0,0 +1,21 @@ +body { + font: 14px "Lucida Grande", Helvetica, Arial, sans-serif; + background: gray; + color: white; +} + +a { + color: #00B7FF; +} +.container { + margin: 0 auto; + width: 850px +} + +.background { + background: #CACACA url(); + display:block; + width:100%; + height:100px; + position: relative; + top:0px;} From 78b43d926083828f5ec93331159985b4e25ca7c4 Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Mon, 16 Jan 2012 20:55:24 +0000 Subject: [PATCH 2/9] added an example --- index.html | 22 ++++++++++++++++++++++ stylesheets/style.css | 13 +++++++++++++ 2 files changed, 35 insertions(+) diff --git a/index.html b/index.html index a5d803e..3d5e292 100644 --- a/index.html +++ b/index.html @@ -11,7 +11,29 @@

Python Browsermob Proxy Library

This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the Pydocs. Note that this will only work with Selenium 2.17 onwards.

+

+

Example

+
+            
+                from browsermobproxy import Server
+                server = Server("path/to/browsermob-proxy")
+                server.start()
+                proxy = server.create_proxy
+
+                from selenium import webdriver
+                profile  = webdriver.FirefoxProfile()
+                profile.set_proxy(proxy.selenium_proxy())
+                driver = webdriver.Firefox(firefox_profile=profile)
 
+                proxy.new_har("google")
+                driver.get("http://www.google.co.uk")
+                proxy.har # returns a HAR JSON blob
+
+                proxy.stop()
+                driver.quit()
+            
+        
+

Releases

0.0.1

diff --git a/stylesheets/style.css b/stylesheets/style.css index f47c480..bbc82d3 100644 --- a/stylesheets/style.css +++ b/stylesheets/style.css @@ -12,6 +12,19 @@ a { width: 850px } +pre { + font: 12px monaco, monospace; + margin: 10px; + padding: 10px; + border: 1px solid #eee; + border-bottom-color: #ddd; + -webkit-border-radius: 2px; + -moz-border-radius: 2px; + -webkit-box-shadow: inset 0 0 10px #eee; + -moz-box-shadow: inset 0 0 10px #eee; + overflow-x: auto; +} + .background { background: #CACACA url(); display:block; From 0ef15046173fa1ddde09690decb71f4b67ebe8ff Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Mon, 16 Jan 2012 21:22:50 +0000 Subject: [PATCH 3/9] fixed typo --- index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/index.html b/index.html index 3d5e292..0e06452 100644 --- a/index.html +++ b/index.html @@ -36,7 +36,7 @@

Example

Releases

-

0.0.1

+

0.0.1

  • Initial release
From 2ce0f00a322ed306331209901d99e048dc24ebfa Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Tue, 17 Jan 2012 20:06:47 +0000 Subject: [PATCH 4/9] fixed typo --- index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/index.html b/index.html index 0e06452..a563428 100644 --- a/index.html +++ b/index.html @@ -42,6 +42,6 @@

Releases

- Fork me on GitHub + Fork me on GitHub From 8e2d795115e7755f9b5d3a2ccb9efeac77e5f848 Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Thu, 29 Mar 2012 15:11:41 +0100 Subject: [PATCH 5/9] Updating release info --- index.html | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/index.html b/index.html index a563428..62917ff 100644 --- a/index.html +++ b/index.html @@ -36,7 +36,12 @@

Example

Releases

-

0.0.1

+

0.1.0

+
    +
  • Remove HTTPLib2 and replace with Requests
  • +
  • Added support for setting headers in the proxy
  • +
+

0.0.1

  • Initial release
From 4473e2f9534677ce1605d50c1412fadccdcffb49 Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Thu, 21 Jun 2012 20:22:23 +0100 Subject: [PATCH 6/9] added changelog to site and changes to API --- index.html | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/index.html b/index.html index 62917ff..e3b68bd 100644 --- a/index.html +++ b/index.html @@ -18,7 +18,7 @@

Example

from browsermobproxy import Server server = Server("path/to/browsermob-proxy") server.start() - proxy = server.create_proxy + proxy = server.create_proxy() from selenium import webdriver profile = webdriver.FirefoxProfile() @@ -36,7 +36,25 @@

Example

Releases

-

0.1.0

+

0.2.0

+
    +
  • DELETE /proxy/:port/ +
  • /proxy/:port/limits +
  • /proxy/:port/blacklist +
  • /proxy/:port/whitelist +
  • fixing /proxy/:port/har/pageRef +
  • fixing /proxy/:port/har/pageRef +
  • fixing passing in a page ref as the name for the page in /proxy/:port/har +
  • tests around /proxy/:port/har and some cleanup of the implementation +
  • make /proxy/:port/headers work +
  • wrapping selenium_proxy with webdriver_proxy since the project is more than just webdriver +
  • extending the client to play nice with remote webdriver instances +
  • create_proxy sounds and feels like a method to me, let's make it so +
  • ensure the self.process exist, to reduce possibilities of AttributeError +
  • check the path before attempting to start the server +
  • wait longer than 3 seconds for the server to come up +
+

0.1.0

  • Remove HTTPLib2 and replace with Requests
  • Added support for setting headers in the proxy
  • From 4c7143660c087adb981d98acfe087f37835799da Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Fri, 31 Jan 2014 22:50:30 +0000 Subject: [PATCH 7/9] updating gitignore to ignore the python build dirs --- .gitignore | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.gitignore b/.gitignore index 3819313..7ef79eb 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,5 @@ *.swp *.swo +browsermob_proxy.egg-info/ +browsermobproxy/ +dist/ From fb04d7caff97d6a33a712eca0bf30e4b0bd07bfe Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Fri, 31 Jan 2014 22:51:07 +0000 Subject: [PATCH 8/9] Updating changelog on page and updating link to RTD for docs --- index.html | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/index.html b/index.html index e3b68bd..5f9cdf8 100644 --- a/index.html +++ b/index.html @@ -9,7 +9,7 @@

    Python Browsermob Proxy Library

    - This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the Pydocs. Note that this will only work with Selenium 2.17 onwards. + This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the docs. Note that this will only work with Selenium 2.17 onwards.

    Example

    @@ -36,7 +36,32 @@

    Example

    Releases

    -

    0.2.0

    +

    0.6.0

    +
      +
    • Added support for parameters in har creation +
    • Bug fixes for tests that are out of date +
    • Setup server constructor to look on path for location of browsermob-proxy executable. As well as looking for a file. Also added example code for using browsermob-proxy with chrome +
    • Fix project name +
    • adding docs +
    + +

    0.5.0

    +
      +
    • Allow proxying of ssl requests with selenium. +
    • Updating case for proxy type +
    + +

    0.4.0

    +
      +
    • Allow setting basic authentication +
    • Adding the ability to remap hosts which is available from BrowserMob Proxy Beta 7 +
    • Merge pull request #6 from lukeis/patch-2 +
    • Update readme.md +
    • initial commit of event listener to auto do record +
    • server.create_proxy is a function, should be called :) +
    • forgot to add the port +
    +

    0.2.0

    • DELETE /proxy/:port/
    • /proxy/:port/limits From 6bf46e532e197f7563d3244782753ea04faab479 Mon Sep 17 00:00:00 2001 From: AutomatedTester Date: Fri, 5 Jun 2015 14:38:17 +0100 Subject: [PATCH 9/9] Updating changelog for 0.7.0 --- index.html | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/index.html b/index.html index 5f9cdf8..78e8d1c 100644 --- a/index.html +++ b/index.html @@ -6,7 +6,7 @@
       
      -
      +

      Python Browsermob Proxy Library

      This is the Python Library for interaction with the Browsermob Proxy. It allows us to create a proxy, set references and generate HAR representations. For more details read the docs. Note that this will only work with Selenium 2.17 onwards. @@ -36,7 +36,26 @@

      Example

      Releases

      -

      0.6.0

      + +

      0.7.0

      +
        +
      • Updating travis ci to use browsermob proxy 2.0 +
      • Support to use httpsProxy and httpProxy at proxy creation time +
      • Adding Python 3 support +
      • add sslProxy to Client.add_to_capabilities with tests +
      • Correct docstring for `wait_for_traffic_to_stop` +
      • Removing unused :Args: items +
      • Updating docstrings +
      • Correcting args and params for documentation +
      • updated docstrings for easier formatting on things like RTDs +
      • updated new_har() docstrings +
      • updated client documentation +
      • Added client and server docs +
      • updating version in docs +
      + + +

      0.6.0

      • Added support for parameters in har creation
      • Bug fixes for tests that are out of date