Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add scripts for doc versioning #2749

Merged
merged 12 commits into from
Jun 15, 2020
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 12 additions & 3 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ env:
- GIT_CI_USER=TravisCI
- GIT_CI_EMAIL=TravisCI@mdanalysis.org
- MDA_DOCDIR=${TRAVIS_BUILD_DIR}/package/doc/html/html
- MAINTAIN_DIR=${TRAVIS_BUILD_DIR}/maintainer
# Set default python version to avoid repetition later
- PYTHON_VERSION=3.6
- BUILD_DOCS=false
Expand Down Expand Up @@ -54,7 +55,7 @@ matrix:
BUILD_DOCS=true
BUILD_CMD="cd ${TRAVIS_BUILD_DIR}/package && python setup.py build_ext --inplace"
INSTALL_HOLE="false"
PIP_DEPENDENCIES="${PIP_DEPENDENCIES} sphinx==1.8.5 sphinx-sitemap sphinx_rtd_theme"
PIP_DEPENDENCIES="${PIP_DEPENDENCIES} sphinx==1.8.5 sphinx-sitemap sphinx_rtd_theme msmb_theme==1.2.0"

- env: NAME="Lint"
PYLINTRC="${TRAVIS_BUILD_DIR}/package/.pylintrc"
Expand Down Expand Up @@ -131,6 +132,14 @@ after_success:
codecov; \
fi
# can't use test here since this leads to travis fails even though the build passes
- if [[ ${TRAVIS_PULL_REQUEST} == "false" ]] && [[ ${BUILD_DOCS} == "true" ]] && [[ ${TRAVIS_BRANCH} == ${GH_DOC_BRANCH} ]]; then
bash ${TRAVIS_BUILD_DIR}/maintainer/deploy_docs.sh;
# turn off blocking as it causes large writes to stdout to fail
# (see https://github.com/travis-ci/travis-ci/issues/4704)
- |
if [[ ${TRAVIS_PULL_REQUEST} == "false" ]] && [[ ${BUILD_DOCS} == "true" ]] && [[ ${TRAVIS_BRANCH} == ${GH_DOC_BRANCH} ]]; then
python -c 'import os,sys,fcntl; flags = fcntl.fcntl(sys.stdout, fcntl.F_GETFL); fcntl.fcntl(sys.stdout, fcntl.F_SETFL, flags&~os.O_NONBLOCK);'
lilyminium marked this conversation as resolved.
Show resolved Hide resolved
cd ${TRAVIS_BUILD_DIR}/package/MDAnalysis
export VERSION=$(python -c "import version; print(version.__version__)")
cd -
bash ${TRAVIS_BUILD_DIR}/maintainer/deploy_docs_via_travis.sh;
fi

22 changes: 20 additions & 2 deletions maintainer/deploy_docs.sh → maintainer/deploy_docs_via_travis.sh
100755 → 100644
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@
# GIT_CI_USER name of the user to push docs as
# GIT_CI_EMAIL email of the user to push docs as
# MDA_DOCDIR path to the docdir from top of repo
# MAINTAIN_DIR path to maintainer/
# VERSION version of MDAnalysis
#
# NOTE: If any of these environment variables are not set or
# empty then the script will exit with and error (-o nounset).
Expand All @@ -32,24 +34,40 @@ rev=$(git rev-parse --short HEAD)
test -n "${GH_TOKEN}" || die "GH_TOKEN is empty: need OAuth GitHub token to continue" 100
test -n "${GH_REPOSITORY}" || die "GH_REPOSITORY must be set in .travis.yml" 100
test -n "${MDA_DOCDIR}" || die "MDA_DOCDIR must be set in .travis.yml" 100
test -n "${MAINTAIN_DIR}" || die "MAINTAIN_DIR must be set in .travis.yml" 100
test -n "${VERSION}" || die "VERSION must be set in .travis.yml" 100


cd ${MDA_DOCDIR} || die "Failed to 'cd ${MDA_DOCDIR}'. Run from the top level of the repository"

# move into $version subdirectory
mkdir ../${VERSION} && mv * ../${VERSION}

git init
git config user.name "${GIT_CI_USER}"
git config user.email "${GIT_CI_EMAIL}"

mv ../${VERSION} $VERSION

git remote add upstream "https://${GH_TOKEN}@${GH_REPOSITORY}"
git fetch --depth 50 upstream ${GH_DOC_BRANCH} gh-pages
git reset upstream/gh-pages

# for dev, latest, home redirects
mkdir dev latest
export URL="https://mdanalysis.github.io/mdanalysis/"
python ${MAINTAIN_DIR}/update_json_stubs_sitemap.py
touch .
touch .nojekyll

git add -A .
git add -A ${VERSION}/
git add .nojekyll versions.json
git add index.html dev latest
git add *.xml

# check for anything to commit
# https://stackoverflow.com/questions/3878624/how-do-i-programmatically-determine-if-there-are-uncommited-changes
git diff-index --quiet HEAD -- || git commit -m "rebuilt html docs from branch ${GH_DOC_BRANCH} with sphinx at ${rev}"
git diff-index --quiet HEAD -- || git commit -m "rebuilt html docs for version ${VERSION} from branch ${GH_DOC_BRANCH} with sphinx at ${rev}"
git push -q upstream HEAD:gh-pages


91 changes: 0 additions & 91 deletions maintainer/deploy_master_docs.sh

This file was deleted.

139 changes: 139 additions & 0 deletions maintainer/update_json_stubs_sitemap.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,139 @@
# Adapted from mdtraj/devtools/travis-ci/update_versions_json.py,
# by Robert T McGibbon, under the LGPLv2.1 license
# Similarly by the terms of LGPL this is also in the public domain
# Lily Wang, 2020
#
# This script is called by deploy_docs_via_travis.sh to:
# 1. update versions.json
# 2. Write some redirect stubs
# 3. Write a sitemap.xml file for the root directory
#

import json
import os
import shutil
import xml.etree.ElementTree as ET

try:
from urllib.request import Request, urlopen
except ImportError:
from urllib2 import Request, urlopen

URL = os.environ['URL']
VERSION = os.environ['VERSION']


def get_web_file(filename, callback):
url = os.path.join(URL, filename)
try:
page = Request(url, headers={'User-Agent': 'Mozilla/5.0'})
data = urlopen(page).read().decode()
except Exception as e:
print(e)
try:
with open(filename, 'r') as f:
return callback(f)
except IOError as e:
print(e)
versions = []
else:
return callback(data)


# ========= WRITE JSON =========
# Update $root/versions.json with links to the right version
versions = get_web_file('versions.json', json.loads)
existing = [item['version'] for item in versions]
already_exists = VERSION in existing

if not already_exists:
latest = 'dev' not in VERSION
if latest:
for ver in versions:
ver['latest'] = False

versions.append({
'version': VERSION,
'display': VERSION,
'url': os.path.join(URL, VERSION),
'latest': latest
})

with open("versions.json", 'w') as f:
json.dump(versions, f, indent=2)

# ========= WRITE HTML STUBS =========
# Add HTML files to redirect:
# index.html -> latest release
# latest/index.html -> latest release
# dev/index.html -> dev docs

REDIRECT = """
<!DOCTYPE html>
<meta charset="utf-8">
<title>Redirecting to {url}</title>
<meta http-equiv="refresh" content="0; URL={url}">
<link rel="canonical" href="{url}">
"""

for ver in versions[::-1]:
if ver['latest']:
latest_url = ver['url']
else:
try:
latest_url = versions[-1]['url']
except IndexError:
latest_url = None

for ver in versions[::-1]:
if 'dev' in ver['version']:
dev_url = ver['url']
break
else:
try:
dev_url = versions[-1]['url']
except IndexError:
dev_url = None

if latest_url:
with open('index.html', 'w') as f:
f.write(REDIRECT.format(url=latest_url))

with open('latest/index.html', 'w') as f:
f.write(REDIRECT.format(url=latest_url))

if dev_url:
with open('dev/index.html', 'w') as f:
f.write(REDIRECT.format(url=dev_url))

# ========= WRITE SUPER SITEMAP.XML =========
# make one big sitemap.xml
ET.register_namespace('xhtml', "http://www.w3.org/1999/xhtml")

# so we could make 1 big sitemap as commented
# below, but they must be max 50 MB / 50k URL.
# Yes, this is 100+ releases, but who knows when
# that'll happen and who'll look at this then?
# bigroot = ET.Element("urlset")
# bigroot.set("xmlns", "http://www.sitemaps.org/schemas/sitemap/0.9")
# for ver in versions:
# tree = get_web_file(ver['version']+'/sitemap.xml', ET.fromstring)
# root = tree.getroot()
# bigroot.extend(root.getchildren())
# ET.ElementTree(bigroot).write('sitemap.xml',
# xml_declaration=True,
# encoding='utf-8',
# method="xml")

# so instead we make a sitemap of sitemaps.
bigroot = ET.Element("sitemapindex")
bigroot.set("xmlns", "http://www.sitemaps.org/schemas/sitemap/0.9")
for ver in versions:
path = os.path.join(URL, '{}/sitemap.xml'.format(ver['version']))
sitemap = ET.SubElement(bigroot, 'sitemap')
ET.SubElement(sitemap, 'loc').text = path

ET.ElementTree(bigroot).write('sitemap_index.xml',
xml_declaration=True,
encoding='utf-8',
method="xml")
25 changes: 17 additions & 8 deletions package/doc/sphinx/source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
import os
import platform
import datetime
import msmb_theme # for little versions pop-up
# https://sphinx-rtd-theme.readthedocs.io/en/stable/
import sphinx_rtd_theme

Expand Down Expand Up @@ -46,7 +47,7 @@
# are served from https://www.mdanalysis.org/docs/ and the sitemap.xml
# is manually fixed when deploying the release docs with the
# maintainer/deploy_master_docs.sh script
lilyminium marked this conversation as resolved.
Show resolved Hide resolved
site_url = "https://www.mdanalysis.org/mdanalysis/"
site_url = "https://docs.mdanalysis.org/"
lilyminium marked this conversation as resolved.
Show resolved Hide resolved

# Add any paths that contain templates here, relative to this directory.
templates_path = ['_templates']
Expand Down Expand Up @@ -78,7 +79,8 @@
# Dynamically calculate the version
packageversion = __import__('MDAnalysis').__version__
# The short X.Y version.
version = '.'.join(packageversion.split('.')[:2])
# version = '.'.join(packageversion.split('.')[:2])
version = packageversion # needed for right sitemap.xml URLs
# The full version, including alpha/beta/rc tags.
release = packageversion

Expand Down Expand Up @@ -116,14 +118,14 @@
# A list of ignored prefixes for module index sorting.
#modindex_common_prefix = []

#to include decorated objects like __init__
# to include decorated objects like __init__
autoclass_content = 'both'

# -- Options for HTML output ---------------------------------------------------

# The theme to use for HTML and HTML Help pages. See the documentation for
# a list of builtin themes.
html_theme = 'sphinx_rtd_theme'
html_theme = 'msmb_theme'

# Theme options are theme-specific and customize the look and feel of a theme
# further. For a list of options available for each theme, see the
Expand All @@ -139,7 +141,7 @@
color = {'orange': '#FF9200',
'gray': '#808080',
'white': '#FFFFFF',
'black': '#000000',}
'black': '#000000', }

html_theme_options = {
'canonical_url': '',
Expand All @@ -156,8 +158,15 @@
'titles_only': False,
}

html_context = {
'versions_json_url': 'https://mdanalysis.github.io/mdanalysis/versions.json'
lilyminium marked this conversation as resolved.
Show resolved Hide resolved
}

# Add any paths that contain custom themes here, relative to this directory.
# html_theme_path = ['_themes',]
html_theme_path = [
msmb_theme.get_html_theme_path(),
sphinx_rtd_theme.get_html_theme_path()
]

# The name for this set of Sphinx documents. If None, it defaults to
# "<project> v<release> documentation".
Expand Down Expand Up @@ -246,8 +255,8 @@
# Grouping the document tree into LaTeX files. List of tuples
# (source start file, target name, title, author, documentclass [howto/manual]).
latex_documents = [
('MDAnalysis.tex', u'MDAnalysis Documentation',
authors, 'manual'),
('MDAnalysis.tex', u'MDAnalysis Documentation',
authors, 'manual'),
]

# The name of an image file (relative to this directory) to place at the top of
Expand Down
Loading