Adds a markdown to docbook script.

Patch set 3 makes the jobname the filename and adds a second job for
building the programming api mdown book.

Patch set 4 corrects the job name to match the file name.

Patch set 5 renames the .sh.save file and adds it to the job builders.

Patch set 6 addresses final comments - appending to the gerrit-doc.properties
file and removes tabs.

Patch set 7 addresses comments. Would like to continue work on markdown to
docbook and delay work on the properties script if possible.

Patch set 8 removes docbook-properties as a prebuilder and removes DOC_OPERATING_SYSTEM
as a variable. Rebase against master also.

Updates macros.yaml and manuals.yaml to pass in filename for markdown files.

Adds properties injection to the markdown to docbook jobs.

Removes extraenous tab from modules/openstack_project/files/zuul/layout.yaml

Additional fixes to pass in filename correctly and remove DOC_OPERATING_SYSTEM, fix
filname typo.

Removes file extension from markdown files, removes echo to gerrit-doc-properties
from markdown-docbook script.

Removes docbook-properties builder references as needed.

Change-Id: I46c07cd11e96e8fc463a377519926a43981e4b3d
Reviewed-on: https://review.openstack.org/12214
Reviewed-by: James E. Blair <corvus@inaugust.com>
Reviewed-by: Monty Taylor <mordred@inaugust.com>
Reviewed-by: Clark Boylan <clark.boylan@gmail.com>
Approved: Clark Boylan <clark.boylan@gmail.com>
Tested-by: Jenkins
This commit is contained in:
annegentle 2012-08-30 14:35:23 -05:00 committed by Jenkins
parent 3da857a51a
commit 53e9722b0b
5 changed files with 138 additions and 0 deletions

View File

@ -0,0 +1,19 @@
#!/bin/bash -e
# Documentation can be submitted in markdown and then converted to docbook
# so it can be built with the maven plugin. This is used by Jenkins when
# invoking certain docs jobs and the resulting output is made available to maven.
# In case we start doing something more sophisticated with other refs
# later (such as tags).
BRANCH=$ZUUL_REFNAME
shopt -s extglob
# Need to get the file name to insert here so it can be reused for multiple projects
# Filenames for the known repos that could do this are openstackapi-programming.mdown
# and images-api-v2.0.md and openstackapi-programming and images-api-v2.0 are the names
# for the ID and xml filename.
FILENAME=$1
pandoc -f markdown -t docbook -s ${FILENAME}.@(md|mdown) | xsltproc -o - /usr/share/xml/docbook/stylesheet/docbook5/db4-upgrade.xsl - | xmllint --format - | sed -e 's,<article,<book xml:id="$FILENAME",' | sed -e 's,</article>,</book> > $FILENAME.xml'
pwd

View File

@ -0,0 +1,29 @@
#!/bin/bash -e
# Documentation is published to a URL depending on the branch of the
# openstack-manuals project. This script determines what that location
# should be, and writes a properties file. This is used by Jenkins when
# invoking certain docs jobs and made available to maven.
# In case we start doing something more sophisticated with other refs
# later (such as tags).
BRANCH=$GERRIT_REFNAME
# The master branch should get published to /trunk
if [ $BRANCH == "master" ]
then
DOC_RELEASE_PATH="trunk"
DOC_COMMENTS_ENABLED=0
fi
# The stable/<releasename> branch should get published to /releasename, such as diablo or essex
if [[ $BRANCH =~ ^stable/(.*)$ ]]
then
DOC_RELEASE_PATH=${BASH_REMATCH[1]}
DOC_COMMENTS_ENABLED=1
fi
echo "DOC_RELEASE_PATH=$DOC_RELEASE_PATH" >gerrit-doc.properties
echo "DOC_COMMENTS_ENABLED=$DOC_COMMENTS_ENABLED" >>gerrit-doc.properties
pwd

View File

@ -23,6 +23,11 @@
builders: builders:
- shell: "mvn package" - shell: "mvn package"
- builder:
name: markdown-docbook
builders:
- shell: "/usr/local/jenkins/slave_scripts/markdown-docbook.sh {filename}"
- builder: - builder:
name: gerrit-package name: gerrit-package
builders: builders:

View File

@ -84,3 +84,83 @@
target: 'api/openstack-volume/1.0/' target: 'api/openstack-volume/1.0/'
remove-prefix: 'doc/target/docbkx/webhelp/volume-api-1.0/volume-api-guide/' remove-prefix: 'doc/target/docbkx/webhelp/volume-api-1.0/volume-api-guide/'
excludes: '**/*.xml,**/null*' excludes: '**/*.xml,**/null*'
- job:
name: images-api-v20
project-type: maven
concurrent: true
node: precise
wrappers:
- timeout:
timeout: 40
fail: true
triggers:
- zuul-post
prebuilders:
- gerrit-git-prep
- markdown-docbook
filename: "images-api-v2.0"
properties:
- inject:
script-file: /usr/local/jenkins/slave_scripts/docbook-properties.sh
properties-file: gerrit-doc.properties
maven:
root-module:
group-id: org.openstack.docs
artifact-id: openstack-guide
root-pom: openstack-image-service-api/pom.xml
goals: 'clean generate-sources'
publishers:
- console-log-post
- ftp:
site: docs.openstack.org
source: 'doc/target/docbkx/webhelp/images-api-2.0/**'
target: 'api/openstack-image-service/2.0/'
remove-prefix: 'doc/target/docbkx/webhelp/images-api-2.0/'
excludes: '**/*.xml,**/null*'
- job:
name: openstackapi-programming
project-type: maven
concurrent: true
node: precise
wrappers:
- timeout:
timeout: 40
fail: true
triggers:
- zuul-post
prebuilders:
- gerrit-git-prep
- markdown-docbook
filename: "openstackapi-programming"
properties:
- inject:
script-file: /usr/local/jenkins/slave_scripts/docbook-properties.sh
properties-file: gerrit-doc.properties
maven:
root-module:
group-id: org.openstack.docs
artifact-id: openstack-guide
root-pom: doc/src/docbkx/openstack-api-programming/pom.xml
goals: 'clean generate-sources'
publishers:
- console-log-post
- ftp:
site: docs.openstack.org
source: 'doc/target/docbkx/webhelp/openstack-api-programming/**'
target: 'api/openstack-compute/programmer/'
remove-prefix: 'doc/target/docbkx/webhelp/openstack-api-programming/'
excludes: '**/*.xml,**/null*'

View File

@ -663,3 +663,8 @@ projects:
- gate-volume-api-merge - gate-volume-api-merge
post: post:
- volume-api - volume-api
- name: openstack/image-api
post:
- images-api-v20