Introduction
This document is addressed to Torque committers who wish to edit and
deploy the Torque site. If you find anything missing or wrong,
please edit this document. If you find any procedure unsatisfactory,
change it and document it here :-).
Site source code and build process
The complete Torque site resides in the module torque-site.
Only the reports from the subprojects are pulled into the main
site via a process documented below.
The subprojects do not have an own xdoc subdirectory.
For a local build of the site, cd into the torque parent dir and run
mvn post-site (if you just run mvn site,
the reports from the other modules will not be pulled in).
When finished, the site can be found in
torque-site/target/site.
Transferring the module reports to the main site
The project reports of the subprojects are pulled into the
main site during the site lifecycle of the main site.
This happens in the following automated steps, which are defined
in the pom.xml of the torque-site module:
-
In the pre-site phase, the reports are copied from the
site directories of the respective modules to the target directory
of the site module
(directories generator-site, runtime-site, ...).
They are renamed to xml, the doctype header
is removed, and in some cases xhtml errors are fixed.
-
In the site phase, the copied reports are transformed by the xslt
stylesheet torque-site/src/site/xslt/body-content.xsl
such that only the body part remains and the "page frame"
is omitted. The result is written to the directories
generator-site-content, runtime-site-content...
-
In the post-site phase, the body parts of the report are
inserted into the placeholder pages which sources can be found in
torque-site/src/site/xdoc/documentation/modules/generator/reports,
torque-site/src/site/xdoc/documentation/modules/runtime/reports...
Some reports do not need to be transformed, e.g. the
cobertura report, the javadocs and the sources xref, they are copied
unchanged.
Deploying the site
This is a step-by-step guide to deploy the whole site.
The guide assumes that putty on windows is used as ssh tool.
First, an entry for the site must be created in maven's setting.xml,
e.g.:
<server>
<id>apache.db.torque.site</id>
<username>tfischer</username>
<filePermissions>664</filePermissions>
<directoryPermissions>775</directoryPermissions>
<configuration>
<sshExecutable>C:/Programme/PuTTY/plink</sshExecutable>
<scpExecutable>C:/Programme/PuTTY/pscp</scpExecutable>
</configuration>
</server>
Then an appropriate private key must be created using puttygen.
Save the key at a safe place locally, and paste the public key to the
~/.ssh/authorized_keys2 file relative to your home directory
on people.apache.org.
Now you can begin to build and deploy the site:
-
run "mvn clean post-site" in the torque-parent module.
-
check the site in torque-site/target/site
-
Start putty's pageant.
-
Load the private key you have generated previously into pageant.
-
It might be a good idea to create a tar.gz backup of the current
state of the site in your apache home directory, in case anything goes
wrong.
-
run mvn site:deploy in the torque-site module.
-
Wait till the site is rsynced to the apache web servers
(might take some hours). Alternatively, check
http://www.apache.org/dev/project-site.html
for a proxy setting which allows to look at the newly deployed site
before the rsync happens,
but this might not work under all circumstances.
-
Empty the cache of your browser and check everything is ok on
http://db.apache.org/torque/releases/torque-4.0/index.html
-
If you are satisfied with the new site and no-one complains during
the next few days, delete the backup tar.gz.
Updating the site for a new release
-
Check that all version numbers are up to date, especially in the
tutorial, usage pages and on the download page.
-
Check that the correct internal version id is in the configuration
fixVersionIds of the maven-changes-plugin in the pom of the
torque-site project. The correct number can be determined by opening
the torque project in jira, clicking on "versions" in the left menu,
click on the appropriate version and then on "release notes" on top
of the site. The version number is the number appearing last in the
URL of the page.