423.2.1
by John Arbash Meinel
Start working on some code to do load testing of loggerhead. |
1 |
# Copyright 2009, 2010, 2011 Canonical Ltd
|
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
2 |
#
|
3 |
# This program is free software; you can redistribute it and/or modify
|
|
4 |
# it under the terms of the GNU General Public License as published by
|
|
5 |
# the Free Software Foundation; either version 2 of the License, or
|
|
6 |
# (at your option) any later version.
|
|
7 |
#
|
|
8 |
# This program is distributed in the hope that it will be useful,
|
|
9 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
10 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
11 |
# GNU General Public License for more details.
|
|
12 |
#
|
|
13 |
# You should have received a copy of the GNU General Public License
|
|
14 |
# along with this program; if not, write to the Free Software
|
|
15 |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
16 |
||
262.2.1
by Martin Pool
Stub code to allow loggerhead to load as a plugin |
17 |
|
18 |
# This file allows loggerhead to be treated as a plugin for bzr.
|
|
19 |
#
|
|
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
20 |
# XXX: Because loggerhead already contains a loggerhead directory, much of the
|
21 |
# code is going to appear loaded at bzrlib.plugins.loggerhead.loggerhead.
|
|
22 |
# This seems like the easiest thing, because bzrlib wants the top-level plugin
|
|
23 |
# directory to be the module, but when it's used as a library people expect
|
|
24 |
# the source directory to contain a directory called loggerhead. -- mbp
|
|
25 |
# 20090123
|
|
26 |
||
27 |
"""Loggerhead web viewer for Bazaar branches.
|
|
28 |
||
329.2.1
by Matt Nordhoff
Strip trailing whitespace |
29 |
This provides a new option "--http" to the "bzr serve" command, that
|
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
30 |
starts a web server to browse the contents of a branch.
|
31 |
"""
|
|
262.2.1
by Martin Pool
Stub code to allow loggerhead to load as a plugin |
32 |
|
420
by Max Kanat-Alexander
Merge info file, mark as compatible with bzr 2.3. |
33 |
from info import ( |
34 |
bzr_plugin_version as version_info, |
|
35 |
bzr_compatible_versions, |
|
36 |
)
|
|
262.2.2
by Martin Pool
Merge in 'serve --http' based on code from mwh |
37 |
|
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
38 |
if __name__ == 'bzrlib.plugins.loggerhead': |
39 |
import bzrlib |
|
262.2.5
by Martin Pool
This loggerhead will work with bzr 1.13 |
40 |
from bzrlib.api import require_any_api |
423.2.1
by John Arbash Meinel
Start working on some code to do load testing of loggerhead. |
41 |
from bzrlib import commands |
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
42 |
|
420
by Max Kanat-Alexander
Merge info file, mark as compatible with bzr 2.3. |
43 |
require_any_api(bzrlib, bzr_compatible_versions) |
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
44 |
|
423.1.1
by Jelmer Vernooij
remove support for pre-1.16 bzr. |
45 |
from bzrlib.transport import transport_server_registry |
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
46 |
|
47 |
DEFAULT_HOST = '0.0.0.0' |
|
262.2.4
by Martin Pool
Act as a plugin only when loaded by bzr; update docs |
48 |
DEFAULT_PORT = 8080 |
360
by Martin Albisetti
Avoid diluting sys.path if loggerhead is installed systemwide, install loggerhead as a plugin (Jelmer Vernooij) |
49 |
HELP = ('Loggerhead, a web-based code viewer and server. (default port: %d)' % |
352.4.3
by Matt Nordhoff
Better line-wrapping |
50 |
(DEFAULT_PORT,)) |
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
51 |
|
418.1.1
by John Arbash Meinel
Allow running the loggerhead test suite using 'bzr selftest' |
52 |
def _ensure_loggerhead_path(): |
53 |
"""Ensure that you can 'import loggerhead' and get the root."""
|
|
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
54 |
# loggerhead internal code will try to 'import loggerhead', so
|
359.1.2
by Jelmer Vernooij
Avoid diluting sys.path if loggerhead is installed systemwide. |
55 |
# let's put it on the path if we can't find it in the existing path
|
56 |
try: |
|
405.1.3
by John Arbash Meinel
Change the import check so it actually works. |
57 |
import loggerhead.apps.transport |
359.1.2
by Jelmer Vernooij
Avoid diluting sys.path if loggerhead is installed systemwide. |
58 |
except ImportError: |
59 |
import os.path, sys |
|
60 |
sys.path.append(os.path.dirname(__file__)) |
|
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
61 |
|
418.1.1
by John Arbash Meinel
Allow running the loggerhead test suite using 'bzr selftest' |
62 |
def serve_http(transport, host=None, port=None, inet=None): |
63 |
from paste.httpexceptions import HTTPExceptionHandler |
|
64 |
from paste.httpserver import serve |
|
65 |
||
66 |
_ensure_loggerhead_path() |
|
67 |
||
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
68 |
from loggerhead.apps.transport import BranchesFromTransportRoot |
69 |
from loggerhead.config import LoggerheadConfig |
|
411.2.7
by John Arbash Meinel
Remove duplicated effort in setup_logging. |
70 |
from loggerhead.main import setup_logging |
389.2.1
by Matt Nordhoff
Some random PEP 8 and otehr stylistic changes. |
71 |
|
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
72 |
if host is None: |
73 |
host = DEFAULT_HOST |
|
74 |
if port is None: |
|
75 |
port = DEFAULT_PORT |
|
359.2.2
by Matt Nordhoff
Fix a stupid mistake constructing argv |
76 |
argv = ['--host', host, '--port', str(port), '--', transport.base] |
77 |
if not transport.is_readonly(): |
|
78 |
argv.insert(0, '--allow-writes') |
|
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
79 |
config = LoggerheadConfig(argv) |
411.2.7
by John Arbash Meinel
Remove duplicated effort in setup_logging. |
80 |
setup_logging(config, init_logging=False, log_file=sys.stderr) |
388
by Matt Nordhoff
serve_http was passing a transport to BranchesFromTransportRoot, not an URL. |
81 |
app = BranchesFromTransportRoot(transport.base, config) |
352.4.1
by Matt Nordhoff
Use the "bzr serve" protocol registry if it's available. |
82 |
app = HTTPExceptionHandler(app) |
83 |
serve(app, host=host, port=port) |
|
84 |
||
423.1.1
by Jelmer Vernooij
remove support for pre-1.16 bzr. |
85 |
transport_server_registry.register('http', serve_http, help=HELP) |
423.2.1
by John Arbash Meinel
Start working on some code to do load testing of loggerhead. |
86 |
|
87 |
class cmd_load_test_loggerhead(commands.Command): |
|
88 |
"""Run a load test against a live loggerhead instance.
|
|
423.2.4
by John Arbash Meinel
Add a <noop> command to the RequestWorker. |
89 |
|
90 |
Pass in the name of a script file to run. See loggerhead/load_test.py
|
|
91 |
for a description of the file format.
|
|
423.2.1
by John Arbash Meinel
Start working on some code to do load testing of loggerhead. |
92 |
"""
|
93 |
||
423.2.4
by John Arbash Meinel
Add a <noop> command to the RequestWorker. |
94 |
takes_args = ["filename"] |
95 |
||
96 |
def run(self, filename): |
|
423.2.1
by John Arbash Meinel
Start working on some code to do load testing of loggerhead. |
97 |
from bzrlib.plugins.loggerhead.loggerhead import load_test |
423.2.4
by John Arbash Meinel
Add a <noop> command to the RequestWorker. |
98 |
script = load_test.run_script(filename) |
423.2.6
by John Arbash Meinel
Avoid getting a lazy object error by instantiating an |
99 |
for thread_id in sorted(script._threads): |
100 |
worker = script._threads[thread_id][0] |
|
423.2.4
by John Arbash Meinel
Add a <noop> command to the RequestWorker. |
101 |
for url, success, time in worker.stats: |
423.2.5
by John Arbash Meinel
Allow comment strings in the scripts. |
102 |
self.outf.write(' %5.3fs %s %s\n' |
103 |
% (time, str(success)[0], url)) |
|
423.2.4
by John Arbash Meinel
Add a <noop> command to the RequestWorker. |
104 |
|
105 |
commands.register_command(cmd_load_test_loggerhead) |
|
418.1.1
by John Arbash Meinel
Allow running the loggerhead test suite using 'bzr selftest' |
106 |
|
107 |
def load_tests(standard_tests, module, loader): |
|
108 |
_ensure_loggerhead_path() |
|
109 |
standard_tests.addTests(loader.loadTestsFromModuleNames( |
|
110 |
['bzrlib.plugins.loggerhead.loggerhead.tests'])) |
|
111 |
return standard_tests |