view tests/test-hgweb-symrev.t @ 26623:5a95fe44121d

clonebundles: support for seeding clones from pre-generated bundles Cloning can be an expensive operation for servers because the server generates a bundle from existing repository data at request time. For a large repository like mozilla-central, this consumes 4+ minutes of CPU time on the server. It also results in significant network utilization. Multiplied by hundreds or even thousands of clients and the ensuing load can result in difficulties scaling the Mercurial server. Despite generation of bundles being deterministic until the next changeset is added, the generation of bundles to service a clone request is not cached. Each clone thus performs redundant work. This is wasteful. This patch introduces the "clonebundles" extension and related client-side functionality to help alleviate this deficiency. The client-side feature is behind an experimental flag and is not enabled by default. It works as follows: 1) Server operator generates a bundle and makes it available on a server (likely HTTP). 2) Server operator defines the URL of a bundle file in a .hg/clonebundles.manifest file. 3) Client `hg clone`ing sees the server is advertising bundle URLs. 4) Client fetches and applies the advertised bundle. 5) Client performs equivalent of `hg pull` to fetch changes made since the bundle was created. Essentially, the server performs the expensive work of generating a bundle once and all subsequent clones fetch a static file from somewhere. Scaling static file serving is a much more manageable problem than scaling a Python application like Mercurial. Assuming your repository grows less than 1% per day, the end result is 99+% of CPU and network load from clones is eliminated, allowing Mercurial servers to scale more easily. Serving static files also means data can be transferred to clients as fast as they can consume it, rather than as fast as servers can generate it. This makes clones faster. Mozilla has implemented similar functionality of this patch on hg.mozilla.org using a custom extension. We are hosting bundle files in Amazon S3 and CloudFront (a CDN) and have successfully offloaded >1 TB/day in data transfer from hg.mozilla.org, freeing up significant bandwidth and CPU resources. The positive impact has been stellar and I believe it has proved its value to be included in Mercurial core. I feel it is important for the client-side support to be enabled in core by default because it means that clients will get faster, more reliable clones and will enable server operators to reduce load without requiring any client-side configuration changes (assuming clients are up to date, of course). The scope of this feature is narrowly and specifically tailored to cloning, despite "serve pulls from pre-generated bundles" being a valid and useful feature. I would eventually like for Mercurial servers to support transferring *all* repository data via statically hosted files. You could imagine a server that siphons all pushed data to bundle files and instructs clients to apply a stream of bundles to reconstruct all repository data. This feature, while useful and powerful, is significantly more work to implement because it requires the server component have awareness of discovery and a mapping of which changesets are in which files. Full, clone bundles, by contrast, are much simpler. The wire protocol command is named "clonebundles" instead of something more generic like "staticbundles" to leave the door open for a new, more powerful and more generic server-side component with minimal backwards compatibility implications. The name "bundleclone" is used by Mozilla's extension and would cause problems since there are subtle differences in Mozilla's extension. Mozilla's experience with this idea has taught us that some form of "content negotiation" is required. Not all clients will support all bundle formats or even URLs (advanced TLS requirements, etc). To ensure the highest uptake possible, a server needs to advertise multiple versions of bundles and clients need to be able to choose the most appropriate from that list one. The "attributes" in each server-advertised entry facilitate this filtering and sorting. Their use will become apparent in subsequent patches. Initial inspiration and credit for the idea of cloning from static files belongs to Augie Fackler and his "lookaside clone" extension proof of concept.
author Gregory Szorc <gregory.szorc@gmail.com>
date Fri, 09 Oct 2015 11:22:01 -0700
parents 264e88901c44
children e901df65b108
line wrap: on
line source

#require serve

Test symbolic revision usage in links produced by hgweb pages. There are
multiple issues related to this:
- issue2296
- issue2826
- issue3594
- issue3634

Set up the repo

  $ hg init test
  $ cd test
  $ echo 0 > foo
  $ mkdir dir
  $ echo 0 > dir/bar
  $ hg ci -Am 'first'
  adding dir/bar
  adding foo
  $ echo 1 >> foo
  $ hg ci -m 'second'
  $ echo 2 >> foo
  $ hg ci -m 'third'
  $ hg bookmark -r1 xyzzy

  $ hg log -G --template '{rev}:{node|short} {tags} {bookmarks}\n'
  @  2:9d8c40cba617 tip
  |
  o  1:a7c1559b7bba  xyzzy
  |
  o  0:43c799df6e75
  
  $ hg serve --config web.allow_archive=zip -n test -p $HGPORT -d --pid-file=hg.pid -E errors.log
  $ cat hg.pid >> $DAEMON_PIDS

  $ REVLINKS='href=[^>]+(rev=|/)(43c799df6e75|0|a7c1559b7bba|1|xyzzy|9d8c40cba617|2|tip|default)'

(De)referencing symbolic revisions (paper)

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=paper' | egrep $REVLINKS
  <li><a href="/graph/tip?style=paper">graph</a></li>
  <li><a href="/rev/tip?style=paper">changeset</a></li>
  <li><a href="/file/tip?style=paper">browse</a></li>
  <a href="/archive/tip.zip">zip</a>
  <a href="/shortlog/tip?revcount=30&style=paper">less</a>
  <a href="/shortlog/tip?revcount=120&style=paper">more</a>
  | rev 2: <a href="/shortlog/43c799df6e75?style=paper">(0)</a> <a href="/shortlog/tip?style=paper">tip</a> 
     <a href="/rev/9d8c40cba617?style=paper">third</a>
     <a href="/rev/a7c1559b7bba?style=paper">second</a>
     <a href="/rev/43c799df6e75?style=paper">first</a>
  <a href="/shortlog/tip?revcount=30&style=paper">less</a>
  <a href="/shortlog/tip?revcount=120&style=paper">more</a>
  | rev 2: <a href="/shortlog/43c799df6e75?style=paper">(0)</a> <a href="/shortlog/tip?style=paper">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/tip?style=paper">log</a></li>
  <li><a href="/rev/tip?style=paper">changeset</a></li>
  <li><a href="/file/tip?style=paper">browse</a></li>
  <a href="/graph/tip?revcount=30&style=paper">less</a>
  <a href="/graph/tip?revcount=120&style=paper">more</a>
  | rev 2: <a href="/graph/43c799df6e75?style=paper">(0)</a> <a href="/graph/tip?style=paper">tip</a> 
  <a href="/graph/tip?revcount=30&style=paper">less</a>
  <a href="/graph/tip?revcount=120&style=paper">more</a>
  | rev 2: <a href="/graph/43c799df6e75?style=paper">(0)</a> <a href="/graph/tip?style=paper">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/tip?style=paper">log</a></li>
  <li><a href="/graph/tip?style=paper">graph</a></li>
  <li><a href="/rev/tip?style=paper">changeset</a></li>
  <a href="/archive/tip.zip">zip</a>
   directory / @ 2:<a href="/rev/9d8c40cba617?style=paper">9d8c40cba617</a>
    <td class="name"><a href="/file/tip/?style=paper">[up]</a></td>
  <a href="/file/tip/dir?style=paper">
  <a href="/file/tip/dir/?style=paper">
  <a href="/file/tip/foo?style=paper">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'branches?style=paper' | egrep $REVLINKS
  <a href="/shortlog/default?style=paper" class="open">
  <a href="/shortlog/9d8c40cba617?style=paper" class="open">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'tags?style=paper' | egrep $REVLINKS
  <a href="/rev/tip?style=paper">
  <a href="/rev/9d8c40cba617?style=paper">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'bookmarks?style=paper' | egrep $REVLINKS
  <a href="/rev/xyzzy?style=paper">
  <a href="/rev/a7c1559b7bba?style=paper">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=paper&rev=all()' | egrep $REVLINKS
     <a href="/rev/9d8c40cba617?style=paper">third</a>
     <a href="/rev/a7c1559b7bba?style=paper">second</a>
     <a href="/rev/43c799df6e75?style=paper">first</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'rev/xyzzy?style=paper' | egrep $REVLINKS
   <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
   <li><a href="/graph/xyzzy?style=paper">graph</a></li>
   <li><a href="/raw-rev/xyzzy?style=paper">raw</a></li>
   <li><a href="/file/xyzzy?style=paper">browse</a></li>
  <a href="/archive/xyzzy.zip">zip</a>
   changeset 1:<a href="/rev/a7c1559b7bba?style=paper">a7c1559b7bba</a>
   <td class="author"><a href="/rev/43c799df6e75?style=paper">43c799df6e75</a> </td>
   <td class="author"> <a href="/rev/9d8c40cba617?style=paper">9d8c40cba617</a></td>
   <td class="files"><a href="/file/a7c1559b7bba/foo?style=paper">foo</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog/xyzzy?style=paper' | egrep $REVLINKS
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy?style=paper">browse</a></li>
  <a href="/archive/xyzzy.zip">zip</a>
  <a href="/shortlog/xyzzy?revcount=30&style=paper">less</a>
  <a href="/shortlog/xyzzy?revcount=120&style=paper">more</a>
  | rev 1: <a href="/shortlog/43c799df6e75?style=paper">(0)</a> <a href="/shortlog/tip?style=paper">tip</a> 
     <a href="/rev/a7c1559b7bba?style=paper">second</a>
     <a href="/rev/43c799df6e75?style=paper">first</a>
  <a href="/shortlog/xyzzy?revcount=30&style=paper">less</a>
  <a href="/shortlog/xyzzy?revcount=120&style=paper">more</a>
  | rev 1: <a href="/shortlog/43c799df6e75?style=paper">(0)</a> <a href="/shortlog/tip?style=paper">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph/xyzzy?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy?style=paper">browse</a></li>
  <a href="/graph/xyzzy?revcount=30&style=paper">less</a>
  <a href="/graph/xyzzy?revcount=120&style=paper">more</a>
  | rev 1: <a href="/graph/43c799df6e75?style=paper">(0)</a> <a href="/graph/tip?style=paper">tip</a> 
  <a href="/graph/xyzzy?revcount=30&style=paper">less</a>
  <a href="/graph/xyzzy?revcount=120&style=paper">more</a>
  | rev 1: <a href="/graph/43c799df6e75?style=paper">(0)</a> <a href="/graph/tip?style=paper">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <a href="/archive/xyzzy.zip">zip</a>
   directory / @ 1:<a href="/rev/a7c1559b7bba?style=paper">a7c1559b7bba</a>
    <td class="name"><a href="/file/xyzzy/?style=paper">[up]</a></td>
  <a href="/file/xyzzy/dir?style=paper">
  <a href="/file/xyzzy/dir/?style=paper">
  <a href="/file/xyzzy/foo?style=paper">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy/foo?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy/?style=paper">browse</a></li>
  <li><a href="/file/tip/foo?style=paper">latest</a></li>
  <li><a href="/diff/xyzzy/foo?style=paper">diff</a></li>
  <li><a href="/comparison/xyzzy/foo?style=paper">comparison</a></li>
  <li><a href="/annotate/xyzzy/foo?style=paper">annotate</a></li>
  <li><a href="/log/xyzzy/foo?style=paper">file log</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
   view foo @ 1:<a href="/rev/a7c1559b7bba?style=paper">a7c1559b7bba</a>
   <td class="author"><a href="/file/43c799df6e75/foo?style=paper">43c799df6e75</a> </td>
   <td class="author"><a href="/file/9d8c40cba617/foo?style=paper">9d8c40cba617</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy/foo?style=paper' | egrep $REVLINKS
     href="/atom-log/tip/foo" title="Atom feed for test:foo" />
     href="/rss-log/tip/foo" title="RSS feed for test:foo" />
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy?style=paper">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=paper">file</a></li>
  <li><a href="/diff/xyzzy/foo?style=paper">diff</a></li>
  <li><a href="/comparison/xyzzy/foo?style=paper">comparison</a></li>
  <li><a href="/annotate/xyzzy/foo?style=paper">annotate</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
  <a href="/atom-log/a7c1559b7bba/foo" title="subscribe to atom feed">
  <a href="/log/xyzzy/foo?revcount=30&style=paper">less</a>
  <a href="/log/xyzzy/foo?revcount=120&style=paper">more</a>
  | <a href="/log/43c799df6e75/foo?style=paper">(0)</a> <a href="/log/tip/foo?style=paper">tip</a> </div>
     <a href="/rev/a7c1559b7bba?style=paper">second</a>
     <a href="/rev/43c799df6e75?style=paper">first</a>
  <a href="/log/xyzzy/foo?revcount=30&style=paper">less</a>
  <a href="/log/xyzzy/foo?revcount=120&style=paper">more</a>
  | <a href="/log/43c799df6e75/foo?style=paper">(0)</a> <a href="/log/tip/foo?style=paper">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'annotate/xyzzy/foo?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy/?style=paper">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=paper">file</a></li>
  <li><a href="/file/tip/foo?style=paper">latest</a></li>
  <li><a href="/diff/xyzzy/foo?style=paper">diff</a></li>
  <li><a href="/comparison/xyzzy/foo?style=paper">comparison</a></li>
  <li><a href="/log/xyzzy/foo?style=paper">file log</a></li>
  <li><a href="/raw-annotate/xyzzy/foo">raw</a></li>
   annotate foo @ 1:<a href="/rev/a7c1559b7bba?style=paper">a7c1559b7bba</a>
   <td class="author"><a href="/file/43c799df6e75/foo?style=paper">43c799df6e75</a> </td>
   <td class="author"><a href="/file/9d8c40cba617/foo?style=paper">9d8c40cba617</a> </td>
  <a href="/annotate/43c799df6e75/foo?style=paper#l1"
  <a href="/annotate/a7c1559b7bba/foo?style=paper#l2"

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'diff/xyzzy/foo?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy?style=paper">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=paper">file</a></li>
  <li><a href="/file/tip/foo?style=paper">latest</a></li>
  <li><a href="/comparison/xyzzy/foo?style=paper">comparison</a></li>
  <li><a href="/annotate/xyzzy/foo?style=paper">annotate</a></li>
  <li><a href="/log/xyzzy/foo?style=paper">file log</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
   diff foo @ 1:<a href="/rev/a7c1559b7bba?style=paper">a7c1559b7bba</a>
   <td><a href="/file/43c799df6e75/foo?style=paper">43c799df6e75</a> </td>
   <td><a href="/file/9d8c40cba617/foo?style=paper">9d8c40cba617</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'comparison/xyzzy/foo?style=paper' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=paper">log</a></li>
  <li><a href="/graph/xyzzy?style=paper">graph</a></li>
  <li><a href="/rev/xyzzy?style=paper">changeset</a></li>
  <li><a href="/file/xyzzy?style=paper">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=paper">file</a></li>
  <li><a href="/file/tip/foo?style=paper">latest</a></li>
  <li><a href="/diff/xyzzy/foo?style=paper">diff</a></li>
  <li><a href="/annotate/xyzzy/foo?style=paper">annotate</a></li>
  <li><a href="/log/xyzzy/foo?style=paper">file log</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
   comparison foo @ 1:<a href="/rev/a7c1559b7bba?style=paper">a7c1559b7bba</a>
   <td><a href="/file/43c799df6e75/foo?style=paper">43c799df6e75</a> </td>
   <td><a href="/file/9d8c40cba617/foo?style=paper">9d8c40cba617</a> </td>

(De)referencing symbolic revisions (coal)

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=coal' | egrep $REVLINKS
  <li><a href="/graph/tip?style=coal">graph</a></li>
  <li><a href="/rev/tip?style=coal">changeset</a></li>
  <li><a href="/file/tip?style=coal">browse</a></li>
  <a href="/archive/tip.zip">zip</a>
  <a href="/shortlog/tip?revcount=30&style=coal">less</a>
  <a href="/shortlog/tip?revcount=120&style=coal">more</a>
  | rev 2: <a href="/shortlog/43c799df6e75?style=coal">(0)</a> <a href="/shortlog/tip?style=coal">tip</a> 
     <a href="/rev/9d8c40cba617?style=coal">third</a>
     <a href="/rev/a7c1559b7bba?style=coal">second</a>
     <a href="/rev/43c799df6e75?style=coal">first</a>
  <a href="/shortlog/tip?revcount=30&style=coal">less</a>
  <a href="/shortlog/tip?revcount=120&style=coal">more</a>
  | rev 2: <a href="/shortlog/43c799df6e75?style=coal">(0)</a> <a href="/shortlog/tip?style=coal">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/tip?style=coal">log</a></li>
  <li><a href="/rev/tip?style=coal">changeset</a></li>
  <li><a href="/file/tip?style=coal">browse</a></li>
  <a href="/graph/tip?revcount=30&style=coal">less</a>
  <a href="/graph/tip?revcount=120&style=coal">more</a>
  | rev 2: <a href="/graph/43c799df6e75?style=coal">(0)</a> <a href="/graph/tip?style=coal">tip</a> 
  <a href="/graph/tip?revcount=30&style=coal">less</a>
  <a href="/graph/tip?revcount=120&style=coal">more</a>
  | rev 2: <a href="/graph/43c799df6e75?style=coal">(0)</a> <a href="/graph/tip?style=coal">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/tip?style=coal">log</a></li>
  <li><a href="/graph/tip?style=coal">graph</a></li>
  <li><a href="/rev/tip?style=coal">changeset</a></li>
  <a href="/archive/tip.zip">zip</a>
   directory / @ 2:<a href="/rev/9d8c40cba617?style=coal">9d8c40cba617</a>
    <td class="name"><a href="/file/tip/?style=coal">[up]</a></td>
  <a href="/file/tip/dir?style=coal">
  <a href="/file/tip/dir/?style=coal">
  <a href="/file/tip/foo?style=coal">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'branches?style=coal' | egrep $REVLINKS
  <a href="/shortlog/default?style=coal" class="open">
  <a href="/shortlog/9d8c40cba617?style=coal" class="open">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'tags?style=coal' | egrep $REVLINKS
  <a href="/rev/tip?style=coal">
  <a href="/rev/9d8c40cba617?style=coal">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'bookmarks?style=coal' | egrep $REVLINKS
  <a href="/rev/xyzzy?style=coal">
  <a href="/rev/a7c1559b7bba?style=coal">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=coal&rev=all()' | egrep $REVLINKS
     <a href="/rev/9d8c40cba617?style=coal">third</a>
     <a href="/rev/a7c1559b7bba?style=coal">second</a>
     <a href="/rev/43c799df6e75?style=coal">first</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'rev/xyzzy?style=coal' | egrep $REVLINKS
   <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
   <li><a href="/graph/xyzzy?style=coal">graph</a></li>
   <li><a href="/raw-rev/xyzzy?style=coal">raw</a></li>
   <li><a href="/file/xyzzy?style=coal">browse</a></li>
  <a href="/archive/xyzzy.zip">zip</a>
   changeset 1:<a href="/rev/a7c1559b7bba?style=coal">a7c1559b7bba</a>
   <td class="author"><a href="/rev/43c799df6e75?style=coal">43c799df6e75</a> </td>
   <td class="author"> <a href="/rev/9d8c40cba617?style=coal">9d8c40cba617</a></td>
   <td class="files"><a href="/file/a7c1559b7bba/foo?style=coal">foo</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog/xyzzy?style=coal' | egrep $REVLINKS
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy?style=coal">browse</a></li>
  <a href="/archive/xyzzy.zip">zip</a>
  <a href="/shortlog/xyzzy?revcount=30&style=coal">less</a>
  <a href="/shortlog/xyzzy?revcount=120&style=coal">more</a>
  | rev 1: <a href="/shortlog/43c799df6e75?style=coal">(0)</a> <a href="/shortlog/tip?style=coal">tip</a> 
     <a href="/rev/a7c1559b7bba?style=coal">second</a>
     <a href="/rev/43c799df6e75?style=coal">first</a>
  <a href="/shortlog/xyzzy?revcount=30&style=coal">less</a>
  <a href="/shortlog/xyzzy?revcount=120&style=coal">more</a>
  | rev 1: <a href="/shortlog/43c799df6e75?style=coal">(0)</a> <a href="/shortlog/tip?style=coal">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph/xyzzy?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy?style=coal">browse</a></li>
  <a href="/graph/xyzzy?revcount=30&style=coal">less</a>
  <a href="/graph/xyzzy?revcount=120&style=coal">more</a>
  | rev 1: <a href="/graph/43c799df6e75?style=coal">(0)</a> <a href="/graph/tip?style=coal">tip</a> 
  <a href="/graph/xyzzy?revcount=30&style=coal">less</a>
  <a href="/graph/xyzzy?revcount=120&style=coal">more</a>
  | rev 1: <a href="/graph/43c799df6e75?style=coal">(0)</a> <a href="/graph/tip?style=coal">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <a href="/archive/xyzzy.zip">zip</a>
   directory / @ 1:<a href="/rev/a7c1559b7bba?style=coal">a7c1559b7bba</a>
    <td class="name"><a href="/file/xyzzy/?style=coal">[up]</a></td>
  <a href="/file/xyzzy/dir?style=coal">
  <a href="/file/xyzzy/dir/?style=coal">
  <a href="/file/xyzzy/foo?style=coal">

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy/foo?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy/?style=coal">browse</a></li>
  <li><a href="/file/tip/foo?style=coal">latest</a></li>
  <li><a href="/diff/xyzzy/foo?style=coal">diff</a></li>
  <li><a href="/comparison/xyzzy/foo?style=coal">comparison</a></li>
  <li><a href="/annotate/xyzzy/foo?style=coal">annotate</a></li>
  <li><a href="/log/xyzzy/foo?style=coal">file log</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
   view foo @ 1:<a href="/rev/a7c1559b7bba?style=coal">a7c1559b7bba</a>
   <td class="author"><a href="/file/43c799df6e75/foo?style=coal">43c799df6e75</a> </td>
   <td class="author"><a href="/file/9d8c40cba617/foo?style=coal">9d8c40cba617</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy/foo?style=coal' | egrep $REVLINKS
     href="/atom-log/tip/foo" title="Atom feed for test:foo" />
     href="/rss-log/tip/foo" title="RSS feed for test:foo" />
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy?style=coal">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=coal">file</a></li>
  <li><a href="/diff/xyzzy/foo?style=coal">diff</a></li>
  <li><a href="/comparison/xyzzy/foo?style=coal">comparison</a></li>
  <li><a href="/annotate/xyzzy/foo?style=coal">annotate</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
  <a href="/atom-log/a7c1559b7bba/foo" title="subscribe to atom feed">
  <a href="/log/xyzzy/foo?revcount=30&style=coal">less</a>
  <a href="/log/xyzzy/foo?revcount=120&style=coal">more</a>
  | <a href="/log/43c799df6e75/foo?style=coal">(0)</a> <a href="/log/tip/foo?style=coal">tip</a> </div>
     <a href="/rev/a7c1559b7bba?style=coal">second</a>
     <a href="/rev/43c799df6e75?style=coal">first</a>
  <a href="/log/xyzzy/foo?revcount=30&style=coal">less</a>
  <a href="/log/xyzzy/foo?revcount=120&style=coal">more</a>
  | <a href="/log/43c799df6e75/foo?style=coal">(0)</a> <a href="/log/tip/foo?style=coal">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'annotate/xyzzy/foo?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy/?style=coal">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=coal">file</a></li>
  <li><a href="/file/tip/foo?style=coal">latest</a></li>
  <li><a href="/diff/xyzzy/foo?style=coal">diff</a></li>
  <li><a href="/comparison/xyzzy/foo?style=coal">comparison</a></li>
  <li><a href="/log/xyzzy/foo?style=coal">file log</a></li>
  <li><a href="/raw-annotate/xyzzy/foo">raw</a></li>
   annotate foo @ 1:<a href="/rev/a7c1559b7bba?style=coal">a7c1559b7bba</a>
   <td class="author"><a href="/file/43c799df6e75/foo?style=coal">43c799df6e75</a> </td>
   <td class="author"><a href="/file/9d8c40cba617/foo?style=coal">9d8c40cba617</a> </td>
  <a href="/annotate/43c799df6e75/foo?style=coal#l1"
  <a href="/annotate/a7c1559b7bba/foo?style=coal#l2"

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'diff/xyzzy/foo?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy?style=coal">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=coal">file</a></li>
  <li><a href="/file/tip/foo?style=coal">latest</a></li>
  <li><a href="/comparison/xyzzy/foo?style=coal">comparison</a></li>
  <li><a href="/annotate/xyzzy/foo?style=coal">annotate</a></li>
  <li><a href="/log/xyzzy/foo?style=coal">file log</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
   diff foo @ 1:<a href="/rev/a7c1559b7bba?style=coal">a7c1559b7bba</a>
   <td><a href="/file/43c799df6e75/foo?style=coal">43c799df6e75</a> </td>
   <td><a href="/file/9d8c40cba617/foo?style=coal">9d8c40cba617</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'comparison/xyzzy/foo?style=coal' | egrep $REVLINKS
  <li><a href="/shortlog/xyzzy?style=coal">log</a></li>
  <li><a href="/graph/xyzzy?style=coal">graph</a></li>
  <li><a href="/rev/xyzzy?style=coal">changeset</a></li>
  <li><a href="/file/xyzzy?style=coal">browse</a></li>
  <li><a href="/file/xyzzy/foo?style=coal">file</a></li>
  <li><a href="/file/tip/foo?style=coal">latest</a></li>
  <li><a href="/diff/xyzzy/foo?style=coal">diff</a></li>
  <li><a href="/annotate/xyzzy/foo?style=coal">annotate</a></li>
  <li><a href="/log/xyzzy/foo?style=coal">file log</a></li>
  <li><a href="/raw-file/xyzzy/foo">raw</a></li>
   comparison foo @ 1:<a href="/rev/a7c1559b7bba?style=coal">a7c1559b7bba</a>
   <td><a href="/file/43c799df6e75/foo?style=coal">43c799df6e75</a> </td>
   <td><a href="/file/9d8c40cba617/foo?style=coal">9d8c40cba617</a> </td>

(De)referencing symbolic revisions (gitweb)

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'summary?style=gitweb' | egrep $REVLINKS
  <a href="/file?style=gitweb">files</a> | <a href="/archive/tip.zip">zip</a>  |
  <a class="list" href="/rev/9d8c40cba617?style=gitweb">
  <a href="/rev/9d8c40cba617?style=gitweb">changeset</a> |
  <a href="/file/9d8c40cba617?style=gitweb">files</a>
  <a class="list" href="/rev/a7c1559b7bba?style=gitweb">
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a> |
  <a href="/file/a7c1559b7bba?style=gitweb">files</a>
  <a class="list" href="/rev/43c799df6e75?style=gitweb">
  <a href="/rev/43c799df6e75?style=gitweb">changeset</a> |
  <a href="/file/43c799df6e75?style=gitweb">files</a>
  <td><a class="list" href="/rev/xyzzy?style=gitweb"><b>xyzzy</b></a></td>
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a> |
  <a href="/log/a7c1559b7bba?style=gitweb">changelog</a> |
  <a href="/file/a7c1559b7bba?style=gitweb">files</a>
  <td class="open"><a class="list" href="/shortlog/default?style=gitweb"><b>default</b></a></td>
  <a href="/changeset/9d8c40cba617?style=gitweb">changeset</a> |
  <a href="/log/9d8c40cba617?style=gitweb">changelog</a> |
  <a href="/file/9d8c40cba617?style=gitweb">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=gitweb' | egrep $REVLINKS
  <a href="/log/tip?style=gitweb">changelog</a> |
  <a href="/file/tip?style=gitweb">files</a> | <a href="/archive/tip.zip">zip</a>  |
  <br/><a href="/shortlog/43c799df6e75?style=gitweb">(0)</a> <a href="/shortlog/tip?style=gitweb">tip</a> <br/>
  <a class="list" href="/rev/9d8c40cba617?style=gitweb">
  <a href="/rev/9d8c40cba617?style=gitweb">changeset</a> |
  <a href="/file/9d8c40cba617?style=gitweb">files</a>
  <a class="list" href="/rev/a7c1559b7bba?style=gitweb">
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a> |
  <a href="/file/a7c1559b7bba?style=gitweb">files</a>
  <a class="list" href="/rev/43c799df6e75?style=gitweb">
  <a href="/rev/43c799df6e75?style=gitweb">changeset</a> |
  <a href="/file/43c799df6e75?style=gitweb">files</a>
  <a href="/shortlog/43c799df6e75?style=gitweb">(0)</a> <a href="/shortlog/tip?style=gitweb">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log?style=gitweb' | egrep $REVLINKS
  <a href="/shortlog/tip?style=gitweb">shortlog</a> |
  <a href="/file/tip?style=gitweb">files</a> | <a href="/archive/tip.zip">zip</a>  |
  <a href="/log/43c799df6e75?style=gitweb">(0)</a>  <a href="/log/tip?style=gitweb">tip</a> <br/>
  <a class="title" href="/rev/9d8c40cba617?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>third<span class="logtags"> <span class="branchtag" title="default">default</span> <span class="tagtag" title="tip">tip</span> </span></a>
  <a href="/rev/9d8c40cba617?style=gitweb">changeset</a><br/>
  <a class="title" href="/rev/a7c1559b7bba?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>second<span class="logtags"> <span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a>
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a><br/>
  <a class="title" href="/rev/43c799df6e75?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>first<span class="logtags"> </span></a>
  <a href="/rev/43c799df6e75?style=gitweb">changeset</a><br/>
  <a href="/log/43c799df6e75?style=gitweb">(0)</a>  <a href="/log/tip?style=gitweb">tip</a> <br/>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph?style=gitweb' | egrep $REVLINKS
  <a href="/log/tip?style=gitweb">changelog</a> |
  <a href="/file/tip?style=gitweb">files</a> |
  <a href="/graph/tip?revcount=30&style=gitweb">less</a>
  <a href="/graph/tip?revcount=120&style=gitweb">more</a>
  | <a href="/graph/43c799df6e75?style=gitweb">(0)</a> <a href="/graph/tip?style=gitweb">tip</a> <br/>
  <a href="/graph/tip?revcount=30&style=gitweb">less</a>
  <a href="/graph/tip?revcount=120&style=gitweb">more</a>
  | <a href="/graph/43c799df6e75?style=gitweb">(0)</a> <a href="/graph/tip?style=gitweb">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'tags?style=gitweb' | egrep $REVLINKS
  <td><a class="list" href="/rev/tip?style=gitweb"><b>tip</b></a></td>
  <a href="/rev/9d8c40cba617?style=gitweb">changeset</a> |
  <a href="/log/9d8c40cba617?style=gitweb">changelog</a> |
  <a href="/file/9d8c40cba617?style=gitweb">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'bookmarks?style=gitweb' | egrep $REVLINKS
  <td><a class="list" href="/rev/xyzzy?style=gitweb"><b>xyzzy</b></a></td>
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a> |
  <a href="/log/a7c1559b7bba?style=gitweb">changelog</a> |
  <a href="/file/a7c1559b7bba?style=gitweb">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'branches?style=gitweb' | egrep $REVLINKS
  <td class="open"><a class="list" href="/shortlog/default?style=gitweb"><b>default</b></a></td>
  <a href="/changeset/9d8c40cba617?style=gitweb">changeset</a> |
  <a href="/log/9d8c40cba617?style=gitweb">changelog</a> |
  <a href="/file/9d8c40cba617?style=gitweb">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file?style=gitweb' | egrep $REVLINKS
  <a href="/rev/tip?style=gitweb">changeset</a>  | <a href="/archive/tip.zip">zip</a>  |
  <td><a href="/file/tip/?style=gitweb">[up]</a></td>
  <a href="/file/tip/dir?style=gitweb">dir</a>
  <a href="/file/tip/dir/?style=gitweb"></a>
  <a href="/file/tip/dir?style=gitweb">files</a>
  <a class="list" href="/file/tip/foo?style=gitweb">foo</a>
  <a href="/file/tip/foo?style=gitweb">file</a> |
  <a href="/log/tip/foo?style=gitweb">revisions</a> |
  <a href="/annotate/tip/foo?style=gitweb">annotate</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=gitweb&rev=all()' | egrep $REVLINKS
  <a href="/file?style=gitweb">files</a> | <a href="/archive/tip.zip">zip</a> 
  <a class="title" href="/rev/9d8c40cba617?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>third<span class="logtags"> <span class="branchtag" title="default">default</span> <span class="tagtag" title="tip">tip</span> </span></a>
  <a href="/rev/9d8c40cba617?style=gitweb">changeset</a><br/>
  <a class="title" href="/rev/a7c1559b7bba?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>second<span class="logtags"> <span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a>
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a><br/>
  <a class="title" href="/rev/43c799df6e75?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>first<span class="logtags"> </span></a>
  <a href="/rev/43c799df6e75?style=gitweb">changeset</a><br/>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'rev/xyzzy?style=gitweb' | egrep $REVLINKS
  <a href="/shortlog/xyzzy?style=gitweb">shortlog</a> |
  <a href="/log/xyzzy?style=gitweb">changelog</a> |
  <a href="/file/xyzzy?style=gitweb">files</a> |
  <a href="/raw-rev/xyzzy">raw</a>  | <a href="/archive/xyzzy.zip">zip</a>  |
  <a class="title" href="/raw-rev/a7c1559b7bba">second <span class="logtags"><span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a>
   <td style="font-family:monospace"><a class="list" href="/rev/a7c1559b7bba?style=gitweb">a7c1559b7bba</a></td>
  <a class="list" href="/rev/43c799df6e75?style=gitweb">43c799df6e75</a>
  <a class="list" href="/rev/9d8c40cba617?style=gitweb">9d8c40cba617</a>
  <td><a class="list" href="/diff/a7c1559b7bba/foo?style=gitweb">foo</a></td>
  <a href="/file/a7c1559b7bba/foo?style=gitweb">file</a> |
  <a href="/annotate/a7c1559b7bba/foo?style=gitweb">annotate</a> |
  <a href="/diff/a7c1559b7bba/foo?style=gitweb">diff</a> |
  <a href="/comparison/a7c1559b7bba/foo?style=gitweb">comparison</a> |
  <a href="/log/a7c1559b7bba/foo?style=gitweb">revisions</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog/xyzzy?style=gitweb' | egrep $REVLINKS
  <a href="/log/xyzzy?style=gitweb">changelog</a> |
  <a href="/file/xyzzy?style=gitweb">files</a> | <a href="/archive/xyzzy.zip">zip</a>  |
  <br/><a href="/shortlog/43c799df6e75?style=gitweb">(0)</a> <a href="/shortlog/tip?style=gitweb">tip</a> <br/>
  <a class="list" href="/rev/a7c1559b7bba?style=gitweb">
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a> |
  <a href="/file/a7c1559b7bba?style=gitweb">files</a>
  <a class="list" href="/rev/43c799df6e75?style=gitweb">
  <a href="/rev/43c799df6e75?style=gitweb">changeset</a> |
  <a href="/file/43c799df6e75?style=gitweb">files</a>
  <a href="/shortlog/43c799df6e75?style=gitweb">(0)</a> <a href="/shortlog/tip?style=gitweb">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy?style=gitweb' | egrep $REVLINKS
  <a href="/shortlog/xyzzy?style=gitweb">shortlog</a> |
  <a href="/file/xyzzy?style=gitweb">files</a> | <a href="/archive/xyzzy.zip">zip</a>  |
  <a href="/log/43c799df6e75?style=gitweb">(0)</a>  <a href="/log/tip?style=gitweb">tip</a> <br/>
  <a class="title" href="/rev/a7c1559b7bba?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>second<span class="logtags"> <span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a>
  <a href="/rev/a7c1559b7bba?style=gitweb">changeset</a><br/>
  <a class="title" href="/rev/43c799df6e75?style=gitweb"><span class="age">Thu, 01 Jan 1970 00:00:00 +0000</span>first<span class="logtags"> </span></a>
  <a href="/rev/43c799df6e75?style=gitweb">changeset</a><br/>
  <a href="/log/43c799df6e75?style=gitweb">(0)</a>  <a href="/log/tip?style=gitweb">tip</a> <br/>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph/xyzzy?style=gitweb' | egrep $REVLINKS
  <a href="/log/xyzzy?style=gitweb">changelog</a> |
  <a href="/file/xyzzy?style=gitweb">files</a> |
  <a href="/graph/xyzzy?revcount=30&style=gitweb">less</a>
  <a href="/graph/xyzzy?revcount=120&style=gitweb">more</a>
  | <a href="/graph/43c799df6e75?style=gitweb">(0)</a> <a href="/graph/tip?style=gitweb">tip</a> <br/>
  <a href="/graph/xyzzy?revcount=30&style=gitweb">less</a>
  <a href="/graph/xyzzy?revcount=120&style=gitweb">more</a>
  | <a href="/graph/43c799df6e75?style=gitweb">(0)</a> <a href="/graph/tip?style=gitweb">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy?style=gitweb' | egrep $REVLINKS
  <a href="/rev/xyzzy?style=gitweb">changeset</a>  | <a href="/archive/xyzzy.zip">zip</a>  |
  <td><a href="/file/xyzzy/?style=gitweb">[up]</a></td>
  <a href="/file/xyzzy/dir?style=gitweb">dir</a>
  <a href="/file/xyzzy/dir/?style=gitweb"></a>
  <a href="/file/xyzzy/dir?style=gitweb">files</a>
  <a class="list" href="/file/xyzzy/foo?style=gitweb">foo</a>
  <a href="/file/xyzzy/foo?style=gitweb">file</a> |
  <a href="/log/xyzzy/foo?style=gitweb">revisions</a> |
  <a href="/annotate/xyzzy/foo?style=gitweb">annotate</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy/foo?style=gitweb' | egrep $REVLINKS
  <a href="/file/xyzzy/?style=gitweb">files</a> |
  <a href="/rev/xyzzy?style=gitweb">changeset</a> |
  <a href="/file/tip/foo?style=gitweb">latest</a> |
  <a href="/log/xyzzy/foo?style=gitweb">revisions</a> |
  <a href="/annotate/xyzzy/foo?style=gitweb">annotate</a> |
  <a href="/diff/xyzzy/foo?style=gitweb">diff</a> |
  <a href="/comparison/xyzzy/foo?style=gitweb">comparison</a> |
  <a href="/raw-file/xyzzy/foo">raw</a> |
   <td style="font-family:monospace"><a class="list" href="/rev/a7c1559b7bba?style=gitweb">a7c1559b7bba</a></td>
  <a class="list" href="/file/43c799df6e75/foo?style=gitweb">
  <a class="list" href="/file/9d8c40cba617/foo?style=gitweb">9d8c40cba617</a></td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy/foo?style=gitweb' | egrep $REVLINKS
  <a href="/file/xyzzy/foo?style=gitweb">file</a> |
  <a href="/annotate/xyzzy/foo?style=gitweb">annotate</a> |
  <a href="/diff/xyzzy/foo?style=gitweb">diff</a> |
  <a href="/comparison/xyzzy/foo?style=gitweb">comparison</a> |
  <a href="/rss-log/tip/foo">rss</a> |
  <a href="/log/43c799df6e75/foo?style=gitweb">(0)</a> <a href="/log/tip/foo?style=gitweb">tip</a> 
  <a class="list" href="/rev/a7c1559b7bba?style=gitweb">
  <a href="/file/a7c1559b7bba/foo?style=gitweb">file</a> |
  <a href="/diff/a7c1559b7bba/foo?style=gitweb">diff</a> |
  <a href="/annotate/a7c1559b7bba/foo?style=gitweb">annotate</a>
  <a class="list" href="/rev/43c799df6e75?style=gitweb">
  <a href="/file/43c799df6e75/foo?style=gitweb">file</a> |
  <a href="/diff/43c799df6e75/foo?style=gitweb">diff</a> |
  <a href="/annotate/43c799df6e75/foo?style=gitweb">annotate</a>
  <a href="/log/43c799df6e75/foo?style=gitweb">(0)</a> <a href="/log/tip/foo?style=gitweb">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'annotate/xyzzy/foo?style=gitweb' | egrep $REVLINKS
  <a href="/file/xyzzy/?style=gitweb">files</a> |
  <a href="/rev/xyzzy?style=gitweb">changeset</a> |
  <a href="/file/xyzzy/foo?style=gitweb">file</a> |
  <a href="/file/tip/foo?style=gitweb">latest</a> |
  <a href="/log/xyzzy/foo?style=gitweb">revisions</a> |
  <a href="/diff/xyzzy/foo?style=gitweb">diff</a> |
  <a href="/comparison/xyzzy/foo?style=gitweb">comparison</a> |
  <a href="/raw-annotate/xyzzy/foo">raw</a> |
   <td style="font-family:monospace"><a class="list" href="/rev/a7c1559b7bba?style=gitweb">a7c1559b7bba</a></td>
  <a class="list" href="/annotate/43c799df6e75/foo?style=gitweb">
  <a class="list" href="/annotate/9d8c40cba617/foo?style=gitweb">9d8c40cba617</a></td>
  <a href="/annotate/43c799df6e75/foo?style=gitweb#l1"
  <a href="/annotate/a7c1559b7bba/foo?style=gitweb#l2"

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'diff/xyzzy/foo?style=gitweb' | egrep $REVLINKS
  <a href="/file/xyzzy?style=gitweb">files</a> |
  <a href="/rev/xyzzy?style=gitweb">changeset</a> |
  <a href="/file/xyzzy/foo?style=gitweb">file</a> |
  <a href="/file/tip/foo?style=gitweb">latest</a> |
  <a href="/log/xyzzy/foo?style=gitweb">revisions</a> |
  <a href="/annotate/xyzzy/foo?style=gitweb">annotate</a> |
  <a href="/comparison/xyzzy/foo?style=gitweb">comparison</a> |
  <a href="/raw-diff/xyzzy/foo">raw</a> |
   <td style="font-family:monospace"><a class="list" href="/rev/a7c1559b7bba?style=gitweb">a7c1559b7bba</a></td>
  <a class="list" href="/diff/43c799df6e75/foo?style=gitweb">
  <a class="list" href="/diff/9d8c40cba617/foo?style=gitweb">9d8c40cba617</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'comparison/xyzzy/foo?style=gitweb' | egrep $REVLINKS
  <a href="/file/xyzzy?style=gitweb">files</a> |
  <a href="/rev/xyzzy?style=gitweb">changeset</a> |
  <a href="/file/xyzzy/foo?style=gitweb">file</a> |
  <a href="/file/tip/foo?style=gitweb">latest</a> |
  <a href="/log/xyzzy/foo?style=gitweb">revisions</a> |
  <a href="/annotate/xyzzy/foo?style=gitweb">annotate</a> |
  <a href="/diff/xyzzy/foo?style=gitweb">diff</a> |
  <a href="/raw-diff/xyzzy/foo">raw</a> |
   <td style="font-family:monospace"><a class="list" href="/rev/a7c1559b7bba?style=gitweb">a7c1559b7bba</a></td>
  <a class="list" href="/comparison/43c799df6e75/foo?style=gitweb">
  <a class="list" href="/comparison/9d8c40cba617/foo?style=gitweb">9d8c40cba617</a>

(De)referencing symbolic revisions (monoblue)

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'summary?style=monoblue' | egrep $REVLINKS
              <li><a href="/archive/tip.zip">zip</a></li>
  <a href="/rev/9d8c40cba617?style=monoblue">
  <a href="/rev/9d8c40cba617?style=monoblue">changeset</a> |
  <a href="/file/9d8c40cba617?style=monoblue">files</a>
  <a href="/rev/a7c1559b7bba?style=monoblue">
  <a href="/rev/a7c1559b7bba?style=monoblue">changeset</a> |
  <a href="/file/a7c1559b7bba?style=monoblue">files</a>
  <a href="/rev/43c799df6e75?style=monoblue">
  <a href="/rev/43c799df6e75?style=monoblue">changeset</a> |
  <a href="/file/43c799df6e75?style=monoblue">files</a>
  <td><a href="/rev/xyzzy?style=monoblue">xyzzy</a></td>
  <a href="/rev/a7c1559b7bba?style=monoblue">changeset</a> |
  <a href="/log/a7c1559b7bba?style=monoblue">changelog</a> |
  <a href="/file/a7c1559b7bba?style=monoblue">files</a>
  <td class="open"><a href="/shortlog/default?style=monoblue">default</a></td>
  <a href="/rev/9d8c40cba617?style=monoblue">changeset</a> |
  <a href="/log/9d8c40cba617?style=monoblue">changelog</a> |
  <a href="/file/9d8c40cba617?style=monoblue">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/tip?style=monoblue">graph</a></li>
              <li><a href="/file/tip?style=monoblue">files</a></li>
              <li><a href="/archive/tip.zip">zip</a></li>
  <a href="/rev/9d8c40cba617?style=monoblue">
  <a href="/rev/9d8c40cba617?style=monoblue">changeset</a> |
  <a href="/file/9d8c40cba617?style=monoblue">files</a>
  <a href="/rev/a7c1559b7bba?style=monoblue">
  <a href="/rev/a7c1559b7bba?style=monoblue">changeset</a> |
  <a href="/file/a7c1559b7bba?style=monoblue">files</a>
  <a href="/rev/43c799df6e75?style=monoblue">
  <a href="/rev/43c799df6e75?style=monoblue">changeset</a> |
  <a href="/file/43c799df6e75?style=monoblue">files</a>
      <a href="/shortlog/43c799df6e75?style=monoblue">(0)</a> <a href="/shortlog/tip?style=monoblue">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/tip?style=monoblue">graph</a></li>
              <li><a href="/file/tip?style=monoblue">files</a></li>
              <li><a href="/archive/tip.zip">zip</a></li>
      <h3 class="changelog"><a class="title" href="/rev/9d8c40cba617?style=monoblue">third<span class="logtags"> <span class="branchtag" title="default">default</span> <span class="tagtag" title="tip">tip</span> </span></a></h3>
  <h3 class="changelog"><a class="title" href="/rev/a7c1559b7bba?style=monoblue">second<span class="logtags"> <span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a></h3>
  <h3 class="changelog"><a class="title" href="/rev/43c799df6e75?style=monoblue">first<span class="logtags"> </span></a></h3>
  <a href="/log/43c799df6e75?style=monoblue">(0)</a>  <a href="/log/tip?style=monoblue">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph?style=monoblue' | egrep $REVLINKS
              <li><a href="/file/tip?style=monoblue">files</a></li>
          <a href="/graph/tip?revcount=30&style=monoblue">less</a>
          <a href="/graph/tip?revcount=120&style=monoblue">more</a>
          | <a href="/graph/43c799df6e75?style=monoblue">(0)</a> <a href="/graph/tip?style=monoblue">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'tags?style=monoblue' | egrep $REVLINKS
  <td><a href="/rev/tip?style=monoblue">tip</a></td>
  <a href="/rev/9d8c40cba617?style=monoblue">changeset</a> |
  <a href="/log/9d8c40cba617?style=monoblue">changelog</a> |
  <a href="/file/9d8c40cba617?style=monoblue">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'bookmarks?style=monoblue' | egrep $REVLINKS
  <td><a href="/rev/xyzzy?style=monoblue">xyzzy</a></td>
  <a href="/rev/a7c1559b7bba?style=monoblue">changeset</a> |
  <a href="/log/a7c1559b7bba?style=monoblue">changelog</a> |
  <a href="/file/a7c1559b7bba?style=monoblue">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'branches?style=monoblue' | egrep $REVLINKS
  <td class="open"><a href="/shortlog/default?style=monoblue">default</a></td>
  <a href="/rev/9d8c40cba617?style=monoblue">changeset</a> |
  <a href="/log/9d8c40cba617?style=monoblue">changelog</a> |
  <a href="/file/9d8c40cba617?style=monoblue">files</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/tip?style=monoblue">graph</a></li>
          <li><a href="/rev/tip?style=monoblue">changeset</a></li>
          <li><a href="/archive/tip.zip">zip</a></li>
              <td><a href="/file/tip/?style=monoblue">[up]</a></td>
  <a href="/file/tip/dir?style=monoblue">dir</a>
  <a href="/file/tip/dir/?style=monoblue"></a>
  <td><a href="/file/tip/dir?style=monoblue">files</a></td>
  <td><a href="/file/tip/foo?style=monoblue">foo</a></td>
  <a href="/file/tip/foo?style=monoblue">file</a> |
  <a href="/log/tip/foo?style=monoblue">revisions</a> |
  <a href="/annotate/tip/foo?style=monoblue">annotate</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=monoblue&rev=all()' | egrep $REVLINKS
              <li><a href="/archive/tip.zip">zip</a></li>
      <h3 class="changelog"><a class="title" href="/rev/9d8c40cba617?style=monoblue">third<span class="logtags"> <span class="branchtag" title="default">default</span> <span class="tagtag" title="tip">tip</span> </span></a></h3>
  <h3 class="changelog"><a class="title" href="/rev/a7c1559b7bba?style=monoblue">second<span class="logtags"> <span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a></h3>
  <h3 class="changelog"><a class="title" href="/rev/43c799df6e75?style=monoblue">first<span class="logtags"> </span></a></h3>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'rev/xyzzy?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
          <li><a href="/raw-rev/xyzzy">raw</a></li>
          <li><a href="/archive/xyzzy.zip">zip</a></li>
      <h3 class="changeset"><a href="/raw-rev/a7c1559b7bba">second <span class="logtags"><span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a></h3>
          <dd><a href="/rev/a7c1559b7bba?style=monoblue">a7c1559b7bba</a></dd>
  <dd><a href="/rev/43c799df6e75?style=monoblue">43c799df6e75</a></dd>
  <dd><a href="/rev/9d8c40cba617?style=monoblue">9d8c40cba617</a></dd>
  <td><a href="/diff/a7c1559b7bba/foo?style=monoblue">foo</a></td>
  <a href="/file/a7c1559b7bba/foo?style=monoblue">file</a> |
  <a href="/annotate/a7c1559b7bba/foo?style=monoblue">annotate</a> |
  <a href="/diff/a7c1559b7bba/foo?style=monoblue">diff</a> |
  <a href="/comparison/a7c1559b7bba/foo?style=monoblue">comparison</a> |
  <a href="/log/a7c1559b7bba/foo?style=monoblue">revisions</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog/xyzzy?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
              <li><a href="/archive/xyzzy.zip">zip</a></li>
  <a href="/rev/a7c1559b7bba?style=monoblue">
  <a href="/rev/a7c1559b7bba?style=monoblue">changeset</a> |
  <a href="/file/a7c1559b7bba?style=monoblue">files</a>
  <a href="/rev/43c799df6e75?style=monoblue">
  <a href="/rev/43c799df6e75?style=monoblue">changeset</a> |
  <a href="/file/43c799df6e75?style=monoblue">files</a>
      <a href="/shortlog/43c799df6e75?style=monoblue">(0)</a> <a href="/shortlog/tip?style=monoblue">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
              <li><a href="/archive/xyzzy.zip">zip</a></li>
      <h3 class="changelog"><a class="title" href="/rev/a7c1559b7bba?style=monoblue">second<span class="logtags"> <span class="bookmarktag" title="xyzzy">xyzzy</span> </span></a></h3>
  <h3 class="changelog"><a class="title" href="/rev/43c799df6e75?style=monoblue">first<span class="logtags"> </span></a></h3>
  <a href="/log/43c799df6e75?style=monoblue">(0)</a>  <a href="/log/tip?style=monoblue">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph/xyzzy?style=monoblue' | egrep $REVLINKS
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
          <a href="/graph/xyzzy?revcount=30&style=monoblue">less</a>
          <a href="/graph/xyzzy?revcount=120&style=monoblue">more</a>
          | <a href="/graph/43c799df6e75?style=monoblue">(0)</a> <a href="/graph/tip?style=monoblue">tip</a> 

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
          <li><a href="/rev/xyzzy?style=monoblue">changeset</a></li>
          <li><a href="/archive/xyzzy.zip">zip</a></li>
              <td><a href="/file/xyzzy/?style=monoblue">[up]</a></td>
  <a href="/file/xyzzy/dir?style=monoblue">dir</a>
  <a href="/file/xyzzy/dir/?style=monoblue"></a>
  <td><a href="/file/xyzzy/dir?style=monoblue">files</a></td>
  <td><a href="/file/xyzzy/foo?style=monoblue">foo</a></td>
  <a href="/file/xyzzy/foo?style=monoblue">file</a> |
  <a href="/log/xyzzy/foo?style=monoblue">revisions</a> |
  <a href="/annotate/xyzzy/foo?style=monoblue">annotate</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy/foo?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy/?style=monoblue">files</a></li>
          <li><a href="/file/tip/foo?style=monoblue">latest</a></li>
          <li><a href="/log/xyzzy/foo?style=monoblue">revisions</a></li>
          <li><a href="/annotate/xyzzy/foo?style=monoblue">annotate</a></li>
          <li><a href="/diff/xyzzy/foo?style=monoblue">diff</a></li>
          <li><a href="/comparison/xyzzy/foo?style=monoblue">comparison</a></li>
          <li><a href="/raw-file/xyzzy/foo">raw</a></li>
          <dd><a class="list" href="/rev/a7c1559b7bba?style=monoblue">a7c1559b7bba</a></dd>
  <a href="/file/43c799df6e75/foo?style=monoblue">
  <a href="/file/9d8c40cba617/foo?style=monoblue">9d8c40cba617</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy/foo?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
          <li><a href="/file/xyzzy/foo?style=monoblue">file</a></li>
          <li><a href="/annotate/xyzzy/foo?style=monoblue">annotate</a></li>
          <li><a href="/diff/xyzzy/foo?style=monoblue">diff</a></li>
          <li><a href="/comparison/xyzzy/foo?style=monoblue">comparison</a></li>
          <li><a href="/rss-log/tip/foo">rss</a></li>
  <a href="/rev/a7c1559b7bba?style=monoblue">
  <a href="/file/a7c1559b7bba/foo?style=monoblue">file</a> |
  <a href="/diff/a7c1559b7bba/foo?style=monoblue">diff</a> |
  <a href="/annotate/a7c1559b7bba/foo?style=monoblue">annotate</a>
  <a href="/rev/43c799df6e75?style=monoblue">
  <a href="/file/43c799df6e75/foo?style=monoblue">file</a> |
  <a href="/diff/43c799df6e75/foo?style=monoblue">diff</a> |
  <a href="/annotate/43c799df6e75/foo?style=monoblue">annotate</a>
      <a href="/log/43c799df6e75/foo?style=monoblue">(0)</a><a href="/log/tip/foo?style=monoblue">tip</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'annotate/xyzzy/foo?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy/?style=monoblue">files</a></li>
          <li><a href="/file/xyzzy/foo?style=monoblue">file</a></li>
          <li><a href="/file/tip/foo?style=monoblue">latest</a></li>
          <li><a href="/log/xyzzy/foo?style=monoblue">revisions</a></li>
          <li><a href="/diff/xyzzy/foo?style=monoblue">diff</a></li>
          <li><a href="/comparison/xyzzy/foo?style=monoblue">comparison</a></li>
          <li><a href="/raw-annotate/xyzzy/foo">raw</a></li>
          <dd><a href="/rev/a7c1559b7bba?style=monoblue">a7c1559b7bba</a></dd>
  <a href="/annotate/43c799df6e75/foo?style=monoblue">
  <a href="/annotate/9d8c40cba617/foo?style=monoblue">9d8c40cba617</a>
  <a href="/annotate/43c799df6e75/foo?style=monoblue#l1"
  <a href="/annotate/a7c1559b7bba/foo?style=monoblue#l2"

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'diff/xyzzy/foo?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
          <li><a href="/file/xyzzy/foo?style=monoblue">file</a></li>
          <li><a href="/file/tip/foo?style=monoblue">latest</a></li>
          <li><a href="/log/xyzzy/foo?style=monoblue">revisions</a></li>
          <li><a href="/annotate/xyzzy/foo?style=monoblue">annotate</a></li>
          <li><a href="/comparison/xyzzy/foo?style=monoblue">comparison</a></li>
          <li><a href="/raw-diff/xyzzy/foo">raw</a></li>
          <dd><a href="/rev/a7c1559b7bba?style=monoblue">a7c1559b7bba</a></dd>
  <dd><a href="/diff/43c799df6e75/foo?style=monoblue">43c799df6e75</a></dd>
  <dd><a href="/diff/9d8c40cba617/foo?style=monoblue">9d8c40cba617</a></dd>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'comparison/xyzzy/foo?style=monoblue' | egrep $REVLINKS
              <li><a href="/graph/xyzzy?style=monoblue">graph</a></li>
              <li><a href="/file/xyzzy?style=monoblue">files</a></li>
          <li><a href="/file/xyzzy/foo?style=monoblue">file</a></li>
          <li><a href="/file/tip/foo?style=monoblue">latest</a></li>
          <li><a href="/log/xyzzy/foo?style=monoblue">revisions</a></li>
          <li><a href="/annotate/xyzzy/foo?style=monoblue">annotate</a></li>
          <li><a href="/diff/xyzzy/foo?style=monoblue">diff</a></li>
          <li><a href="/raw-diff/xyzzy/foo">raw</a></li>
          <dd><a href="/rev/a7c1559b7bba?style=monoblue">a7c1559b7bba</a></dd>
  <dd><a href="/comparison/43c799df6e75/foo?style=monoblue">43c799df6e75</a></dd>
  <dd><a href="/comparison/9d8c40cba617/foo?style=monoblue">9d8c40cba617</a></dd>

(De)referencing symbolic revisions (spartan)

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=spartan' | egrep $REVLINKS
  <a href="/log/tip?style=spartan">changelog</a>
  <a href="/graph/tip?style=spartan">graph</a>
  <a href="/file/tip/?style=spartan">files</a>
  <a href="/archive/tip.zip">zip</a> 
  navigate: <small class="navigate"><a href="/shortlog/43c799df6e75?style=spartan">(0)</a> <a href="/shortlog/tip?style=spartan">tip</a> </small>
    <td class="node"><a href="/rev/9d8c40cba617?style=spartan">third</a></td>
    <td class="node"><a href="/rev/a7c1559b7bba?style=spartan">second</a></td>
    <td class="node"><a href="/rev/43c799df6e75?style=spartan">first</a></td>
  navigate: <small class="navigate"><a href="/shortlog/43c799df6e75?style=spartan">(0)</a> <a href="/shortlog/tip?style=spartan">tip</a> </small>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log?style=spartan' | egrep $REVLINKS
  <a href="/shortlog/tip?style=spartan">shortlog</a>
  <a href="/graph/tip?style=spartan">graph</a>
  <a href="/file/tip?style=spartan">files</a>
  <a href="/archive/tip.zip">zip</a> 
  navigate: <small class="navigate"><a href="/log/43c799df6e75?style=spartan">(0)</a>  <a href="/log/tip?style=spartan">tip</a> </small>
    <td class="node"><a href="/rev/9d8c40cba617?style=spartan">9d8c40cba617</a></td>
    <th class="files"><a href="/file/9d8c40cba617?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/9d8c40cba617/foo?style=spartan">foo</a> </td>
    <td class="node"><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
    <th class="files"><a href="/file/a7c1559b7bba?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/a7c1559b7bba/foo?style=spartan">foo</a> </td>
    <td class="node"><a href="/rev/43c799df6e75?style=spartan">43c799df6e75</a></td>
    <th class="files"><a href="/file/43c799df6e75?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/43c799df6e75/dir/bar?style=spartan">dir/bar</a> <a href="/diff/43c799df6e75/foo?style=spartan">foo</a> </td>
  navigate: <small class="navigate"><a href="/log/43c799df6e75?style=spartan">(0)</a>  <a href="/log/tip?style=spartan">tip</a> </small>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph?style=spartan' | egrep $REVLINKS
  <a href="/log/tip?style=spartan">changelog</a>
  <a href="/shortlog/tip?style=spartan">shortlog</a>
  <a href="/file/tip/?style=spartan">files</a>
  navigate: <small class="navigate"><a href="/graph/43c799df6e75?style=spartan">(0)</a> <a href="/graph/tip?style=spartan">tip</a> </small>
  navigate: <small class="navigate"><a href="/graph/43c799df6e75?style=spartan">(0)</a> <a href="/graph/tip?style=spartan">tip</a> </small>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'tags?style=spartan' | egrep $REVLINKS
  <a href="/rev/9d8c40cba617?style=spartan">tip</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'branches?style=spartan' | egrep $REVLINKS
  <a href="/shortlog/9d8c40cba617?style=spartan" class="open">default</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file?style=spartan' | egrep $REVLINKS
  <a href="/log/tip?style=spartan">changelog</a>
  <a href="/shortlog/tip?style=spartan">shortlog</a>
  <a href="/graph/tip?style=spartan">graph</a>
  <a href="/rev/tip?style=spartan">changeset</a>
  <a href="/archive/tip.zip">zip</a> 
  <h2><a href="/">Mercurial</a>  / files for changeset <a href="/rev/9d8c40cba617">9d8c40cba617</a>: /</h2>
    <td><a href="/file/tip/?style=spartan">[up]</a>
  <a href="/file/tip/dir?style=spartan">dir/</a>
  <a href="/file/tip/dir/?style=spartan">
  <td><a href="/file/tip/foo?style=spartan">foo</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog?style=spartan&rev=all()' | egrep $REVLINKS
  <a href="/archive/tip.zip">zip</a> 
    <td class="node"><a href="/rev/9d8c40cba617?style=spartan">9d8c40cba617</a></td>
  <a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a>
    <th class="files"><a href="/file/9d8c40cba617?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/9d8c40cba617/foo?style=spartan">foo</a> </td>
    <td class="node"><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
  <a href="/rev/43c799df6e75?style=spartan">43c799df6e75</a>
  <td class="child"><a href="/rev/9d8c40cba617?style=spartan">9d8c40cba617</a></td>
    <th class="files"><a href="/file/a7c1559b7bba?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/a7c1559b7bba/foo?style=spartan">foo</a> </td>
    <td class="node"><a href="/rev/43c799df6e75?style=spartan">43c799df6e75</a></td>
  <td class="child"><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
    <th class="files"><a href="/file/43c799df6e75?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/43c799df6e75/dir/bar?style=spartan">dir/bar</a> <a href="/diff/43c799df6e75/foo?style=spartan">foo</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'rev/xyzzy?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/file/xyzzy?style=spartan">files</a>
  <a href="/raw-rev/xyzzy">raw</a>
  <a href="/archive/xyzzy.zip">zip</a> 
   <td class="changeset"><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
  <td class="parent"><a href="/rev/43c799df6e75?style=spartan">43c799df6e75</a></td>
  <td class="child"><a href="/rev/9d8c40cba617?style=spartan">9d8c40cba617</a></td>
   <td class="files"><a href="/file/a7c1559b7bba/foo?style=spartan">foo</a> </td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'shortlog/xyzzy?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/file/xyzzy/?style=spartan">files</a>
  <a href="/archive/xyzzy.zip">zip</a> 
  navigate: <small class="navigate"><a href="/shortlog/43c799df6e75?style=spartan">(0)</a> <a href="/shortlog/tip?style=spartan">tip</a> </small>
    <td class="node"><a href="/rev/a7c1559b7bba?style=spartan">second</a></td>
    <td class="node"><a href="/rev/43c799df6e75?style=spartan">first</a></td>
  navigate: <small class="navigate"><a href="/shortlog/43c799df6e75?style=spartan">(0)</a> <a href="/shortlog/tip?style=spartan">tip</a> </small>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy?style=spartan' | egrep $REVLINKS
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/file/xyzzy?style=spartan">files</a>
  <a href="/archive/xyzzy.zip">zip</a> 
  navigate: <small class="navigate"><a href="/log/43c799df6e75?style=spartan">(0)</a>  <a href="/log/tip?style=spartan">tip</a> </small>
    <td class="node"><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
    <th class="files"><a href="/file/a7c1559b7bba?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/a7c1559b7bba/foo?style=spartan">foo</a> </td>
    <td class="node"><a href="/rev/43c799df6e75?style=spartan">43c799df6e75</a></td>
    <th class="files"><a href="/file/43c799df6e75?style=spartan">files</a>:</th>
    <td class="files"><a href="/diff/43c799df6e75/dir/bar?style=spartan">dir/bar</a> <a href="/diff/43c799df6e75/foo?style=spartan">foo</a> </td>
  navigate: <small class="navigate"><a href="/log/43c799df6e75?style=spartan">(0)</a>  <a href="/log/tip?style=spartan">tip</a> </small>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'graph/xyzzy?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/file/xyzzy/?style=spartan">files</a>
  navigate: <small class="navigate"><a href="/graph/43c799df6e75?style=spartan">(0)</a> <a href="/graph/tip?style=spartan">tip</a> </small>
  navigate: <small class="navigate"><a href="/graph/43c799df6e75?style=spartan">(0)</a> <a href="/graph/tip?style=spartan">tip</a> </small>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/rev/xyzzy?style=spartan">changeset</a>
  <a href="/archive/xyzzy.zip">zip</a> 
  <h2><a href="/">Mercurial</a>  / files for changeset <a href="/rev/a7c1559b7bba">a7c1559b7bba</a>: /</h2>
    <td><a href="/file/xyzzy/?style=spartan">[up]</a>
  <a href="/file/xyzzy/dir?style=spartan">dir/</a>
  <a href="/file/xyzzy/dir/?style=spartan">
  <td><a href="/file/xyzzy/foo?style=spartan">foo</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'file/xyzzy/foo?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/rev/xyzzy?style=spartan">changeset</a>
  <a href="/file/xyzzy/?style=spartan">files</a>
  <a href="/log/xyzzy/foo?style=spartan">revisions</a>
  <a href="/annotate/xyzzy/foo?style=spartan">annotate</a>
  <a href="/raw-file/xyzzy/foo">raw</a>
   <td><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
  <a href="/file/43c799df6e75/foo?style=spartan">
  <td><a href="/file/9d8c40cba617/foo?style=spartan">9d8c40cba617</a></td>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'log/xyzzy/foo?style=spartan' | egrep $REVLINKS
     href="/atom-log/tip/foo" title="Atom feed for test:foo">
     href="/rss-log/tip/foo" title="RSS feed for test:foo">
  <a href="/file/xyzzy/foo?style=spartan">file</a>
  <a href="/annotate/xyzzy/foo?style=spartan">annotate</a>
  <a type="application/rss+xml" href="/rss-log/tip/foo">rss</a>
  <a type="application/atom+xml" href="/atom-log/tip/foo" title="Atom feed for test:foo">atom</a>
  <p>navigate: <small class="navigate"><a href="/log/43c799df6e75/foo?style=spartan">(0)</a> <a href="/log/tip/foo?style=spartan">tip</a> </small></p>
    <th class="firstline"><a href="/rev/a7c1559b7bba?style=spartan">second</a></th>
     <a href="/file/a7c1559b7bba/foo?style=spartan">a7c1559b7bba</a>
     <a href="/diff/a7c1559b7bba/foo?style=spartan">(diff)</a>
     <a href="/annotate/a7c1559b7bba/foo?style=spartan">(annotate)</a>
    <th class="firstline"><a href="/rev/43c799df6e75?style=spartan">first</a></th>
     <a href="/file/43c799df6e75/foo?style=spartan">43c799df6e75</a>
     <a href="/diff/43c799df6e75/foo?style=spartan">(diff)</a>
     <a href="/annotate/43c799df6e75/foo?style=spartan">(annotate)</a>

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'annotate/xyzzy/foo?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/rev/xyzzy?style=spartan">changeset</a>
  <a href="/file/xyzzy/?style=spartan">files</a>
  <a href="/file/xyzzy/foo?style=spartan">file</a>
  <a href="/log/xyzzy/foo?style=spartan">revisions</a>
  <a href="/raw-annotate/xyzzy/foo">raw</a>
   <td><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
  <a href="/annotate/43c799df6e75/foo?style=spartan">
  <td><a href="/annotate/9d8c40cba617/foo?style=spartan">9d8c40cba617</a></td>
  <a href="/annotate/43c799df6e75/foo?style=spartan#l1"
  <a href="/annotate/a7c1559b7bba/foo?style=spartan#l2"

  $ "$TESTDIR/get-with-headers.py" 127.0.0.1:$HGPORT 'diff/xyzzy/foo?style=spartan' | egrep $REVLINKS
  <a href="/log/xyzzy?style=spartan">changelog</a>
  <a href="/shortlog/xyzzy?style=spartan">shortlog</a>
  <a href="/graph/xyzzy?style=spartan">graph</a>
  <a href="/rev/xyzzy?style=spartan">changeset</a>
  <a href="/file/xyzzy/foo?style=spartan">file</a>
  <a href="/log/xyzzy/foo?style=spartan">revisions</a>
  <a href="/annotate/xyzzy/foo?style=spartan">annotate</a>
  <a href="/raw-diff/xyzzy/foo">raw</a>
   <td class="revision"><a href="/rev/a7c1559b7bba?style=spartan">a7c1559b7bba</a></td>
  <td class="parent"><a href="/rev/43c799df6e75?style=spartan">43c799df6e75</a></td>
  <td class="child"><a href="/rev/9d8c40cba617?style=spartan">9d8c40cba617</a></td>

Done

  $ cat errors.log
  $ "$TESTDIR/killdaemons.py" $DAEMON_PIDS
  $ cd ..