Skip to content

Doc release update process

David Kinder edited this page Apr 5, 2021 · 24 revisions

The ACRN release process starts when the code is frozen on the candidate release branch, such as release_2.4. Documentation changes continue on the master branch while developers are validating and testing the release candidate. Once the release candidate branch is declared ready, we need to propagate all the documentation changes that were done on the master branch back into this release candidate branch as well. In the past, doc changes were cherry-picked from the master branch to the release candidate branch, but for a while now we simplified this process (and reduced the chance of missing a documentation change) by essentially merging all the documentation changes made on the master branch since the release candidate branch was made. We do this by making a working directory with content from the master branch, checking out the release candidate branch, and then copying that working directory content onto the checked-out release candidate to create a single pull-request with all the changes. Here's the process:

# create a "master" working directory
rm -rf ~/acrn-master && mkdir ~/acrn-master
cd ~/projectacrn/acrn-hypervisor/doc

# get the latest upstream/master branch content 
git checkout master
git fetch upstream
git merge upstream/master
git push origin master

# clean out doc build artifacts
make clean

# copy all the doc directory to our master working directory
cp -r . ~/acrn-master/doc

# and copy doc material from the misc directory too
cd ../misc
mkdir ~/acrn-master/misc

# the --parents option maintains the directory structure in the destination directory
cp --parents *.rst ~/acrn-master/misc
cp --parents */*.rst ~/acrn-master/misc
cp --parents */*/*.rst ~/acrn-master/misc
cp --parents */*/*/*.rst ~/acrn-master/misc
# until the copy fails, then get the schema files that contain configuration option documentation
cp --parents config_tools/schema/*.xsd ~/acrn-master/misc

cd ..

# get the release candidate doc contents and make a branch for updating
git checkout upstream/release_2.4
git checkout -b update-docs-2.4

# and copy all the master working directory doc contents over the release candidate contents
cp -r ~/acrn-master/* .

# do a "make html" here to verify CI doc build will work... and we can publish these as the 2.4 release docs
cd doc
make clean
make DOC_TAG=release RELEASE=2.4 html 
make DOC_TAG=release RELEASE=2.4 publish

# add changed staged files, commit, and do the PR
cd ..
git add .
git status 
# verify all staged files are added (from the /doc and /misc directories)

git commit -s
# in the commit message add "Tracked-On: #5692" to allow the .xsd file changes to get through CI checks

git push origin update-docs-2.4

From here, head over to https://github.com/projectacrn/acrn-hypervisor and create a PR, changing the base to be the release_2.4 branch (not master). You should see only the changed documents listed as changed files, and there should be no merge conflicts. Submit the PR and wait for the CI system to pass before merging.

While that's going, we can head back to the master branch, and make the changes to incorporate the 2.4 release docs into the latest doc version status by editing the conf.py file, as documented in Document Versioning.

cd ~/projectacrn/acrn-hypervisor/doc

git checkout master
git checkout -b add-v2.4-menu


# edit the conf.py to add the v2.4 release docs to the menu choice after /latest/

git add .
git commit -s
git push origin add-v2.4-menu

make html
make publish

# head over to github and submit the PR to update the conf.py