test-hgweb.t
686 lines
| 17.9 KiB
| text/troff
|
Tads3Lexer
/ tests / test-hgweb.t
Matt Mackall
|
r22046 | #require serve | ||
Mads Kiilerich
|
r15446 | |||
Matt Mackall
|
r12432 | Some tests for hgweb. Tests static files, plain files and different 404's. | ||
$ hg init test | ||||
$ cd test | ||||
$ mkdir da | ||||
$ echo foo > da/foo | ||||
$ echo foo > foo | ||||
$ hg ci -Ambase | ||||
adding da/foo | ||||
adding foo | ||||
r25777 | $ hg bookmark -r0 '@' | |||
$ hg bookmark -r0 'a b c' | ||||
$ hg bookmark -r0 'd/e/f' | ||||
Matt Mackall
|
r12432 | $ hg serve -n test -p $HGPORT -d --pid-file=hg.pid -A access.log -E errors.log | ||
$ cat hg.pid >> $DAEMON_PIDS | ||||
manifest | ||||
Matt Mackall
|
r25472 | $ (get-with-headers.py localhost:$HGPORT 'file/tip/?style=raw') | ||
Matt Mackall
|
r12432 | 200 Script output follows | ||
drwxr-xr-x da | ||||
-rw-r--r-- 4 foo | ||||
Matt Mackall
|
r25472 | $ (get-with-headers.py localhost:$HGPORT 'file/tip/da?style=raw') | ||
Matt Mackall
|
r12432 | 200 Script output follows | ||
-rw-r--r-- 4 foo | ||||
plain file | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'file/tip/foo?style=raw' | ||
Matt Mackall
|
r12432 | 200 Script output follows | ||
foo | ||||
should give a 404 - static file that does not exist | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'static/bogus' | ||
Matt Mackall
|
r12432 | 404 Not Found | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
Benoit Allard
|
r14046 | <script type="text/javascript" src="/static/mercurial.js"></script> | ||
Matt Mackall
|
r12432 | |||
<title>test: error</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
<a href="http://mercurial.selenic.com/"> | ||||
<img src="/static/hglogo.png" width=75 height=90 border=0 alt="mercurial" /></a> | ||||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
Alexander Solovyov
|
r13597 | <li><a href="/bookmarks">bookmarks</a></li> | ||
Matt Mackall
|
r12432 | <li><a href="/branches">branches</a></li> | ||
Ross Lagerwall
|
r17290 | </ul> | ||
<ul> | ||||
Augie Fackler
|
r12680 | <li><a href="/help">help</a></li> | ||
Matt Mackall
|
r12432 | </ul> | ||
</div> | ||||
<div class="main"> | ||||
Bryan O'Sullivan
|
r18264 | <h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||
Matt Mackall
|
r12432 | <h3>error</h3> | ||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30"></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Matt Mackall
|
r12432 | </form> | ||
<div class="description"> | ||||
<p> | ||||
An error occurred while processing your request: | ||||
</p> | ||||
<p> | ||||
Not Found | ||||
</p> | ||||
</div> | ||||
</div> | ||||
</div> | ||||
Benoit Allard
|
r14046 | <script type="text/javascript">process_dates()</script> | ||
Matt Mackall
|
r12432 | |||
</body> | ||||
</html> | ||||
[1] | ||||
should give a 404 - bad revision | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'file/spam/foo?style=raw' | ||
Matt Mackall
|
r12432 | 404 Not Found | ||
error: revision not found: spam | ||||
[1] | ||||
should give a 400 - bad command | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'file/tip/foo?cmd=spam&style=raw' | ||
Matt Mackall
|
r12432 | 400* (glob) | ||
error: no such method: spam | ||||
[1] | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py --headeronly localhost:$HGPORT '?cmd=spam' | ||
Anton Shestakov
|
r22506 | 400 no such method: spam | ||
[1] | ||||
should give a 400 - bad command as a part of url path (issue4071) | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py --headeronly localhost:$HGPORT 'spam' | ||
Anton Shestakov
|
r22506 | 400 no such method: spam | ||
[1] | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py --headeronly localhost:$HGPORT 'raw-spam' | ||
Anton Shestakov
|
r22506 | 400 no such method: spam | ||
[1] | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py --headeronly localhost:$HGPORT 'spam/tip/foo' | ||
Anton Shestakov
|
r22506 | 400 no such method: spam | ||
[1] | ||||
Matt Mackall
|
r12432 | should give a 404 - file does not exist | ||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'file/tip/bork?style=raw' | ||
Matt Mackall
|
r12432 | 404 Not Found | ||
error: bork@2ef0ac749a14: not found in manifest | ||||
[1] | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'file/tip/bork' | ||
Matt Mackall
|
r12432 | 404 Not Found | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
Benoit Allard
|
r14046 | <script type="text/javascript" src="/static/mercurial.js"></script> | ||
Matt Mackall
|
r12432 | |||
<title>test: error</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
<a href="http://mercurial.selenic.com/"> | ||||
<img src="/static/hglogo.png" width=75 height=90 border=0 alt="mercurial" /></a> | ||||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
Alexander Solovyov
|
r13597 | <li><a href="/bookmarks">bookmarks</a></li> | ||
Matt Mackall
|
r12432 | <li><a href="/branches">branches</a></li> | ||
Ross Lagerwall
|
r17290 | </ul> | ||
<ul> | ||||
Augie Fackler
|
r12680 | <li><a href="/help">help</a></li> | ||
Matt Mackall
|
r12432 | </ul> | ||
</div> | ||||
<div class="main"> | ||||
Bryan O'Sullivan
|
r18264 | <h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||
Matt Mackall
|
r12432 | <h3>error</h3> | ||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30"></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Matt Mackall
|
r12432 | </form> | ||
<div class="description"> | ||||
<p> | ||||
An error occurred while processing your request: | ||||
</p> | ||||
<p> | ||||
bork@2ef0ac749a14: not found in manifest | ||||
</p> | ||||
</div> | ||||
</div> | ||||
</div> | ||||
Benoit Allard
|
r14046 | <script type="text/javascript">process_dates()</script> | ||
Matt Mackall
|
r12432 | |||
</body> | ||||
</html> | ||||
[1] | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'diff/tip/bork?style=raw' | ||
Matt Mackall
|
r12432 | 404 Not Found | ||
error: bork@2ef0ac749a14: not found in manifest | ||||
[1] | ||||
try bad style | ||||
Matt Mackall
|
r25472 | $ (get-with-headers.py localhost:$HGPORT 'file/tip/?style=foobar') | ||
Matt Mackall
|
r12432 | 200 Script output follows | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
Benoit Allard
|
r14046 | <script type="text/javascript" src="/static/mercurial.js"></script> | ||
Matt Mackall
|
r12432 | |||
<title>test: 2ef0ac749a14 /</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
<a href="http://mercurial.selenic.com/"> | ||||
<img src="/static/hglogo.png" alt="mercurial" /></a> | ||||
</div> | ||||
<ul> | ||||
r25606 | <li><a href="/shortlog/tip">log</a></li> | |||
<li><a href="/graph/tip">graph</a></li> | ||||
Matt Mackall
|
r12432 | <li><a href="/tags">tags</a></li> | ||
Alexander Solovyov
|
r13597 | <li><a href="/bookmarks">bookmarks</a></li> | ||
Matt Mackall
|
r12432 | <li><a href="/branches">branches</a></li> | ||
</ul> | ||||
<ul> | ||||
r25606 | <li><a href="/rev/tip">changeset</a></li> | |||
Matt Mackall
|
r12432 | <li class="active">browse</li> | ||
</ul> | ||||
<ul> | ||||
</ul> | ||||
Augie Fackler
|
r12666 | <ul> | ||
<li><a href="/help">help</a></li> | ||||
</ul> | ||||
Matt Mackall
|
r12432 | </div> | ||
<div class="main"> | ||||
Bryan O'Sullivan
|
r18264 | <h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||
r25617 | <h3> | |||
directory / @ 0:<a href="/rev/2ef0ac749a14">2ef0ac749a14</a> | ||||
r25777 | <span class="tag">tip</span> <span class="tag">@</span> <span class="tag">a b c</span> <span class="tag">d/e/f</span> | |||
r25617 | </h3> | |||
Matt Mackall
|
r12432 | |||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Matt Mackall
|
r12432 | </form> | ||
<table class="bigtable"> | ||||
Anton Shestakov
|
r24054 | <thead> | ||
Matt Mackall
|
r12432 | <tr> | ||
<th class="name">name</th> | ||||
<th class="size">size</th> | ||||
<th class="permissions">permissions</th> | ||||
</tr> | ||||
Anton Shestakov
|
r24054 | </thead> | ||
Alexander Plavin
|
r19447 | <tbody class="stripes2"> | ||
<tr class="fileline"> | ||||
r25606 | <td class="name"><a href="/file/tip/">[up]</a></td> | |||
Matt Mackall
|
r12432 | <td class="size"></td> | ||
<td class="permissions">drwxr-xr-x</td> | ||||
</tr> | ||||
Alexander Plavin
|
r19447 | <tr class="fileline"> | ||
Matt Mackall
|
r12432 | <td class="name"> | ||
r25606 | <a href="/file/tip/da"> | |||
Matt Mackall
|
r12432 | <img src="/static/coal-folder.png" alt="dir."/> da/ | ||
</a> | ||||
r25606 | <a href="/file/tip/da/"> | |||
Matt Mackall
|
r12432 | |||
</a> | ||||
</td> | ||||
<td class="size"></td> | ||||
<td class="permissions">drwxr-xr-x</td> | ||||
</tr> | ||||
Alexander Plavin
|
r19447 | <tr class="fileline"> | ||
Matt Mackall
|
r12432 | <td class="filename"> | ||
r25606 | <a href="/file/tip/foo"> | |||
Matt Mackall
|
r12432 | <img src="/static/coal-file.png" alt="file"/> foo | ||
</a> | ||||
</td> | ||||
<td class="size">4</td> | ||||
<td class="permissions">-rw-r--r--</td> | ||||
</tr> | ||||
Alexander Plavin
|
r19447 | </tbody> | ||
Matt Mackall
|
r12432 | </table> | ||
</div> | ||||
</div> | ||||
Benoit Allard
|
r14046 | <script type="text/javascript">process_dates()</script> | ||
Matt Mackall
|
r12432 | |||
</body> | ||||
</html> | ||||
stop and restart | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Matt Mackall
|
r12432 | $ hg serve -p $HGPORT -d --pid-file=hg.pid -A access.log | ||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Test the access/error files are opened in append mode | ||||
Augie Fackler
|
r22947 | $ $PYTHON -c "print len(file('access.log').readlines()), 'log lines written'" | ||
Anton Shestakov
|
r22506 | 14 log lines written | ||
Matt Mackall
|
r12432 | |||
static file | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py --twice localhost:$HGPORT 'static/style-gitweb.css' - date etag server | ||
Matt Mackall
|
r12432 | 200 Script output follows | ||
Gregory Szorc
|
r23744 | content-length: 5372 | ||
Mads Kiilerich
|
r18380 | content-type: text/css | ||
Matt Mackall
|
r12432 | |||
Alexander Plavin
|
r19076 | body { font-family: sans-serif; font-size: 12px; border:solid #d9d8d1; border-width:1px; margin:10px; } | ||
Matt Mackall
|
r12432 | a { color:#0000cc; } | ||
a:hover, a:visited, a:active { color:#880000; } | ||||
div.page_header { height:25px; padding:8px; font-size:18px; font-weight:bold; background-color:#d9d8d1; } | ||||
div.page_header a:visited { color:#0000cc; } | ||||
div.page_header a:hover { color:#880000; } | ||||
div.page_nav { padding:8px; } | ||||
div.page_nav a:visited { color:#0000cc; } | ||||
div.page_path { padding:8px; border:solid #d9d8d1; border-width:0px 0px 1px} | ||||
div.page_footer { padding:4px 8px; background-color: #d9d8d1; } | ||||
div.page_footer_text { float:left; color:#555555; font-style:italic; } | ||||
div.page_body { padding:8px; } | ||||
div.title, a.title { | ||||
display:block; padding:6px 8px; | ||||
font-weight:bold; background-color:#edece6; text-decoration:none; color:#000000; | ||||
} | ||||
a.title:hover { background-color: #d9d8d1; } | ||||
div.title_text { padding:6px 0px; border: solid #d9d8d1; border-width:0px 0px 1px; } | ||||
div.log_body { padding:8px 8px 8px 150px; } | ||||
.age { white-space:nowrap; } | ||||
span.age { position:relative; float:left; width:142px; font-style:italic; } | ||||
div.log_link { | ||||
padding:0px 8px; | ||||
font-size:10px; font-family:sans-serif; font-style:normal; | ||||
position:relative; float:left; width:136px; | ||||
} | ||||
div.list_head { padding:6px 8px 4px; border:solid #d9d8d1; border-width:1px 0px 0px; font-style:italic; } | ||||
a.list { text-decoration:none; color:#000000; } | ||||
a.list:hover { text-decoration:underline; color:#880000; } | ||||
table { padding:8px 4px; } | ||||
th { padding:2px 5px; font-size:12px; text-align:left; } | ||||
tr.light:hover, .parity0:hover { background-color:#edece6; } | ||||
tr.dark, .parity1 { background-color:#f6f6f0; } | ||||
tr.dark:hover, .parity1:hover { background-color:#edece6; } | ||||
td { padding:2px 5px; font-size:12px; vertical-align:top; } | ||||
td.closed { background-color: #99f; } | ||||
td.link { padding:2px 5px; font-family:sans-serif; font-size:10px; } | ||||
td.indexlinks { white-space: nowrap; } | ||||
td.indexlinks a { | ||||
padding: 2px 5px; line-height: 10px; | ||||
border: 1px solid; | ||||
color: #ffffff; background-color: #7777bb; | ||||
border-color: #aaaadd #333366 #333366 #aaaadd; | ||||
font-weight: bold; text-align: center; text-decoration: none; | ||||
font-size: 10px; | ||||
} | ||||
td.indexlinks a:hover { background-color: #6666aa; } | ||||
div.pre { font-family:monospace; font-size:12px; white-space:pre; } | ||||
div.diff_info { font-family:monospace; color:#000099; background-color:#edece6; font-style:italic; } | ||||
div.index_include { border:solid #d9d8d1; border-width:0px 0px 1px; padding:12px 8px; } | ||||
div.search { margin:4px 8px; position:absolute; top:56px; right:12px } | ||||
.linenr { color:#999999; text-decoration:none } | ||||
div.rss_logo { float: right; white-space: nowrap; } | ||||
div.rss_logo a { | ||||
padding:3px 6px; line-height:10px; | ||||
border:1px solid; border-color:#fcc7a5 #7d3302 #3e1a01 #ff954e; | ||||
color:#ffffff; background-color:#ff6600; | ||||
font-weight:bold; font-family:sans-serif; font-size:10px; | ||||
text-align:center; text-decoration:none; | ||||
} | ||||
div.rss_logo a:hover { background-color:#ee5500; } | ||||
pre { margin: 0; } | ||||
span.logtags span { | ||||
padding: 0px 4px; | ||||
font-size: 10px; | ||||
font-weight: normal; | ||||
border: 1px solid; | ||||
background-color: #ffaaff; | ||||
border-color: #ffccff #ff00ee #ff00ee #ffccff; | ||||
} | ||||
span.logtags span.tagtag { | ||||
background-color: #ffffaa; | ||||
border-color: #ffffcc #ffee00 #ffee00 #ffffcc; | ||||
} | ||||
span.logtags span.branchtag { | ||||
background-color: #aaffaa; | ||||
border-color: #ccffcc #00cc33 #00cc33 #ccffcc; | ||||
} | ||||
span.logtags span.inbranchtag { | ||||
background-color: #d5dde6; | ||||
border-color: #e3ecf4 #9398f4 #9398f4 #e3ecf4; | ||||
} | ||||
Yuya Nishihara
|
r13863 | span.logtags span.bookmarktag { | ||
background-color: #afdffa; | ||||
border-color: #ccecff #46ace6 #46ace6 #ccecff; | ||||
} | ||||
Gregory Szorc
|
r23744 | span.difflineplus { color:#008800; } | ||
span.difflineminus { color:#cc0000; } | ||||
span.difflineat { color:#990099; } | ||||
Matt Mackall
|
r12432 | |||
/* Graph */ | ||||
div#wrapper { | ||||
position: relative; | ||||
margin: 0; | ||||
padding: 0; | ||||
margin-top: 3px; | ||||
} | ||||
canvas { | ||||
position: absolute; | ||||
z-index: 5; | ||||
top: -0.9em; | ||||
margin: 0; | ||||
} | ||||
ul#nodebgs { | ||||
list-style: none inside none; | ||||
padding: 0; | ||||
margin: 0; | ||||
top: -0.7em; | ||||
} | ||||
ul#graphnodes li, ul#nodebgs li { | ||||
height: 39px; | ||||
} | ||||
ul#graphnodes { | ||||
position: absolute; | ||||
z-index: 10; | ||||
top: -0.8em; | ||||
list-style: none inside none; | ||||
padding: 0; | ||||
} | ||||
ul#graphnodes li .info { | ||||
display: block; | ||||
font-size: 100%; | ||||
position: relative; | ||||
top: -3px; | ||||
font-style: italic; | ||||
} | ||||
wujek srujek
|
r17202 | |||
/* Comparison */ | ||||
.legend { | ||||
padding: 1.5% 0 1.5% 0; | ||||
} | ||||
.legendinfo { | ||||
border: 1px solid #d9d8d1; | ||||
font-size: 80%; | ||||
text-align: center; | ||||
padding: 0.5%; | ||||
} | ||||
.equal { | ||||
background-color: #ffffff; | ||||
} | ||||
.delete { | ||||
Matt Mackall
|
r17243 | background-color: #faa; | ||
color: #333; | ||||
wujek srujek
|
r17202 | } | ||
.insert { | ||||
Matt Mackall
|
r17243 | background-color: #ffa; | ||
wujek srujek
|
r17202 | } | ||
.replace { | ||||
Matt Mackall
|
r17243 | background-color: #e8e8e8; | ||
wujek srujek
|
r17202 | } | ||
.comparison { | ||||
overflow-x: auto; | ||||
} | ||||
.header th { | ||||
text-align: center; | ||||
} | ||||
.block { | ||||
border-top: 1px solid #d9d8d1; | ||||
} | ||||
Augie Fackler
|
r20256 | |||
.scroll-loading { | ||||
-webkit-animation: change_color 1s linear 0s infinite alternate; | ||||
-moz-animation: change_color 1s linear 0s infinite alternate; | ||||
-o-animation: change_color 1s linear 0s infinite alternate; | ||||
animation: change_color 1s linear 0s infinite alternate; | ||||
} | ||||
@-webkit-keyframes change_color { | ||||
from { background-color: #A0CEFF; } to { } | ||||
} | ||||
@-moz-keyframes change_color { | ||||
from { background-color: #A0CEFF; } to { } | ||||
} | ||||
@-o-keyframes change_color { | ||||
from { background-color: #A0CEFF; } to { } | ||||
} | ||||
@keyframes change_color { | ||||
from { background-color: #A0CEFF; } to { } | ||||
} | ||||
.scroll-loading-error { | ||||
background-color: #FFCCCC !important; | ||||
} | ||||
Matt Mackall
|
r12432 | 304 Not Modified | ||
Anton Shestakov
|
r22577 | phase changes are refreshed (issue4061) | ||
$ echo bar >> foo | ||||
$ hg ci -msecret --secret | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'log?style=raw' | ||
Anton Shestakov
|
r22577 | 200 Script output follows | ||
# HG changelog | ||||
# Node ID 2ef0ac749a14e4f57a5a822464a0902c6f7f448f | ||||
changeset: 2ef0ac749a14e4f57a5a822464a0902c6f7f448f | ||||
revision: 0 | ||||
user: test | ||||
date: Thu, 01 Jan 1970 00:00:00 +0000 | ||||
summary: base | ||||
branch: default | ||||
tag: tip | ||||
r25777 | bookmark: @ | |||
bookmark: a b c | ||||
bookmark: d/e/f | ||||
Anton Shestakov
|
r22577 | |||
$ hg phase --draft tip | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'log?style=raw' | ||
Anton Shestakov
|
r22577 | 200 Script output follows | ||
# HG changelog | ||||
# Node ID a084749e708a9c4c0a5b652a2a446322ce290e04 | ||||
changeset: a084749e708a9c4c0a5b652a2a446322ce290e04 | ||||
revision: 1 | ||||
user: test | ||||
date: Thu, 01 Jan 1970 00:00:00 +0000 | ||||
summary: secret | ||||
branch: default | ||||
tag: tip | ||||
changeset: 2ef0ac749a14e4f57a5a822464a0902c6f7f448f | ||||
revision: 0 | ||||
user: test | ||||
date: Thu, 01 Jan 1970 00:00:00 +0000 | ||||
summary: base | ||||
r25777 | bookmark: @ | |||
bookmark: a b c | ||||
bookmark: d/e/f | ||||
Anton Shestakov
|
r22577 | |||
r25777 | access bookmarks | |||
$ get-with-headers.py localhost:$HGPORT 'rev/@?style=paper' | egrep '^200|changeset 0:' | ||||
200 Script output follows | ||||
changeset 0:<a href="/rev/2ef0ac749a14?style=paper">2ef0ac749a14</a> | ||||
$ get-with-headers.py localhost:$HGPORT 'rev/%40?style=paper' | egrep '^200|changeset 0:' | ||||
200 Script output follows | ||||
changeset 0:<a href="/rev/2ef0ac749a14?style=paper">2ef0ac749a14</a> | ||||
$ get-with-headers.py localhost:$HGPORT 'rev/a%20b%20c?style=paper' | egrep '^200|changeset 0:' | ||||
200 Script output follows | ||||
changeset 0:<a href="/rev/2ef0ac749a14?style=paper">2ef0ac749a14</a> | ||||
$ get-with-headers.py localhost:$HGPORT 'rev/d%252Fe%252Ff?style=paper' | egrep '^200|changeset 0:' | ||||
200 Script output follows | ||||
changeset 0:<a href="/rev/2ef0ac749a14?style=paper">2ef0ac749a14</a> | ||||
Yuya Nishihara
|
r24296 | no style can be loaded from directories other than the specified paths | ||
$ mkdir -p x/templates/fallback | ||||
$ cat <<EOF > x/templates/fallback/map | ||||
> default = 'shortlog' | ||||
> shortlog = 'fall back to default\n' | ||||
> mimetype = 'text/plain' | ||||
> EOF | ||||
$ cat <<EOF > x/map | ||||
> default = 'shortlog' | ||||
> shortlog = 'access to outside of templates directory\n' | ||||
> mimetype = 'text/plain' | ||||
> EOF | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Yuya Nishihara
|
r24296 | $ hg serve -p $HGPORT -d --pid-file=hg.pid -A access.log -E errors.log \ | ||
> --config web.style=fallback --config web.templates=x/templates | ||||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT "?style=`pwd`/x" | ||
Yuya Nishihara
|
r24296 | 200 Script output follows | ||
fall back to default | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT '?style=..' | ||
Yuya Nishihara
|
r24296 | 200 Script output follows | ||
fall back to default | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT '?style=./..' | ||
Yuya Nishihara
|
r24296 | 200 Script output follows | ||
fall back to default | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT '?style=.../.../' | ||
Yuya Nishihara
|
r24296 | 200 Script output follows | ||
fall back to default | ||||
Matt Mackall
|
r12432 | errors | ||
$ cat errors.log | ||||
Mads Kiilerich
|
r16913 | |||
Gregory Szorc
|
r23409 | Uncaught exceptions result in a logged error and canned HTTP response | ||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Gregory Szorc
|
r23409 | $ hg --config extensions.hgweberror=$TESTDIR/hgweberror.py serve -p $HGPORT -d --pid-file=hg.pid -A access.log -E errors.log | ||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'raiseerror' transfer-encoding content-type | ||
Gregory Szorc
|
r23409 | 500 Internal Server Error | ||
transfer-encoding: chunked | ||||
Internal Server Error (no-eol) | ||||
[1] | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Gregory Szorc
|
r23409 | $ head -1 errors.log | ||
.* Exception happened during processing request '/raiseerror': (re) | ||||
Uncaught exception after partial content sent | ||||
Matt Mackall
|
r23952 | $ hg --config extensions.hgweberror=$TESTDIR/hgweberror.py serve -p $HGPORT -d --pid-file=hg.pid -A access.log -E errors.log | ||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py localhost:$HGPORT 'raiseerror?partialresponse=1' transfer-encoding content-type | ||
Gregory Szorc
|
r23409 | 200 Script output follows | ||
transfer-encoding: chunked | ||||
content-type: text/plain | ||||
partial content | ||||
Internal Server Error (no-eol) | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Mads Kiilerich
|
r16913 | $ cd .. | ||