Add sphinx_python variable to sphinx role and job

Some projects, such as Zuul itself, need to use python3 to build docs.

This adds a new parameter, sphinx_python, which defines the version
of python to build documentation with. The default is python2 and
projects can choose python3 on a need basis.

Remove the comment about the need for a leading comment, since there
is now a real need for the leading comment anyway.

Replace a few direct references to {{ ansible_user_dir }}/.venv that
should have been using zuul_work_virtualenv.

Update sphinx invocation to source the virtualenv activate first.
Some sphinx modules, such as sphinxcontrib.programoutput, attempt to
execute programs and only invoking sphinx-build with the relative
path causes the paths to not be set up properly.

Co-Authored-By: David Moreau Simard <dmsimard@redhat.com>
Change-Id: Ie5e2c93f88465f4aa746827ff88a585dbaa44fd5
This commit is contained in:
David Moreau Simard 2017-12-05 16:39:30 -05:00
parent a34de95685
commit 1f8c473765
No known key found for this signature in database
GPG Key ID: 33A07694CBB71ECC
6 changed files with 38 additions and 33 deletions

View File

@ -16,6 +16,11 @@ All pip installs are done with a provided constraints file, if given.
List of python packages to install for building docs. List of python packages to install for building docs.
.. zuul:rolevar:: sphinx_python
:default: python2
Version of python to use, either ``python2`` or ``python3``.
.. zuul:rolevar:: zuul_work_virtualenv .. zuul:rolevar:: zuul_work_virtualenv
:default: ~/.venv :default: ~/.venv

View File

@ -1,4 +1,5 @@
zuul_work_dir: "{{ zuul.project.src_dir }}" zuul_work_dir: "{{ zuul.project.src_dir }}"
zuul_work_virtualenv: "{{ ansible_user_dir }}/.venv" zuul_work_virtualenv: "{{ ansible_user_dir }}/.venv"
sphinx_python: python2
doc_building_packages: doc_building_packages:
- sphinx - sphinx

View File

@ -9,36 +9,27 @@
include_role: include_role:
name: find-constraints name: find-constraints
- name: Install virtualenv and doc requirements files if found # Note (dmsimard): This installs doc/requirements.txt or test-requirements.txt
shell: # if the former is not found. If neither are found, this task is skipped.
executable: /bin/bash # TODO(dmsimard) Don't assume virtualenv is installed
- name: Initialize virtual environment
pip:
requirements: "{{ item }}"
chdir: "{{ zuul_work_dir }}" chdir: "{{ zuul_work_dir }}"
# NOTE(mordred) There is a bug in ansible-lint that mistakenly detects virtualenv: "{{ zuul_work_virtualenv }}"
# setting the VENV variable below as an error if it occurs on the fist virtualenv_python: "{{ sphinx_python }}"
# line. Work around that by putting a comment as the first line until we extra_args: "{{ upper_constraints | default(omit) }}"
# can get a fix upstream. with_first_found:
cmd: | - files:
# Create virtualenv is it does not already exist - "{{ zuul_work_dir }}/doc/requirements.txt"
VENV={{ zuul_work_virtualenv }} - "{{ zuul_work_dir }}/test-requirements.txt"
if [ ! -d $VENV ] ; then skip: true
virtualenv $VENV
fi
source $VENV/bin/activate
# skipping requirements.txt as it gets picked up by installing the
# python package itself
for f in doc/requirements.txt test-requirements.txt ; do
if [ -f $f ] ; then
pip install $CONSTRAINTS -r $f
break
fi
done
environment:
CONSTRAINTS: "{{ upper_constraints|default('') }}"
- name: Install doc building packages - name: Install doc building packages
pip: pip:
name: "{{ item }}" name: "{{ item }}"
chdir: "{{ zuul_work_dir }}" chdir: "{{ zuul_work_dir }}"
virtualenv: "{{ zuul_work_virtualenv }}" virtualenv: "{{ zuul_work_virtualenv }}"
virtualenv_python: "{{ sphinx_python }}"
extra_args: "{{ upper_constraints | default(omit) }}" extra_args: "{{ upper_constraints | default(omit) }}"
with_items: "{{ doc_building_packages }}" with_items: "{{ doc_building_packages }}"

View File

@ -28,7 +28,7 @@
- name: Install requirements if they exist - name: Install requirements if they exist
pip: pip:
chdir: "{{ zuul_work_dir }}" chdir: "{{ zuul_work_dir }}"
virtualenv: "{{ ansible_user_dir }}/.venv" virtualenv: "{{ zuul_work_virtualenv }}"
requirements: requirements.txt requirements: requirements.txt
extra_args: "{{ upper_constraints|default(omit) }}" extra_args: "{{ upper_constraints|default(omit) }}"
register: requirements_install register: requirements_install
@ -45,7 +45,7 @@
# the ChangeLog to have been generated. # the ChangeLog to have been generated.
- name: Make sdist to generate ChangeLog - name: Make sdist to generate ChangeLog
command: command:
cmd: "{{ ansible_user_dir }}/.venv/bin/python setup.py sdist" cmd: "{{ zuul_work_virtualenv }}/bin/python setup.py sdist"
chdir: "{{ zuul_work_dir }}" chdir: "{{ zuul_work_dir }}"
when: when:
- install_package - install_package
@ -61,7 +61,7 @@
- name: Install the project if it is a Python project - name: Install the project if it is a Python project
pip: pip:
chdir: "{{ zuul_work_dir }}" chdir: "{{ zuul_work_dir }}"
virtualenv: "{{ ansible_user_dir }}/.venv" virtualenv: "{{ zuul_work_virtualenv }}"
name: . name: .
extra_args: --no-deps extra_args: --no-deps
when: when:

View File

@ -10,11 +10,14 @@
sphinx_warning_is_error: "{{ check_result.warning_is_error }}" sphinx_warning_is_error: "{{ check_result.warning_is_error }}"
- name: Run sphinx - name: Run sphinx
command: shell:
cmd: > executable: /bin/bash
{{ zuul_work_virtualenv }}/bin/sphinx-build cmd: |
-b {{ item }} # Source the activate file so that sphinx subcommands have the correct
{% if sphinx_warning_is_error %} -W {% endif %} # paths set.
source {{ zuul_work_virtualenv }}/bin/activate
sphinx-build -b {{ item }} \
{% if sphinx_warning_is_error %} -W {% endif %} \
{{ sphinx_source_dir }} {{ sphinx_build_dir }}/{{ item }} {{ sphinx_source_dir }} {{ sphinx_build_dir }}/{{ item }}
chdir: "{{ zuul_work_dir }}" chdir: "{{ zuul_work_dir }}"
with_items: "{{ sphinx_builders }}" with_items: "{{ sphinx_builders }}"

View File

@ -174,6 +174,11 @@
Optional path to a pip constraints file for installing python Optional path to a pip constraints file for installing python
libraries. libraries.
.. zuul:jobvar:: sphinx_python
:default: python2
Version of python to use, either ``python2`` or ``python3``.
.. zuul:jobvar:: zuul_work_dir .. zuul:jobvar:: zuul_work_dir
:default: {{ zuul.project.src_dir }} :default: {{ zuul.project.src_dir }}