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

test scripts to compare mdbook version output #778

Closed
Closed
Show file tree
Hide file tree
Changes from all 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
155 changes: 155 additions & 0 deletions tests/mdbook_version_validator/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
# Testing Upstream Books for Breakage from mdbook

- Theory - when mdbook changes, we should be able to coarsely tell if building a book with the new version fails
- In Practice - Build the book twice and compare


1. Build two binaries of mdbook, some "current" (master) and some "new" branch
(Building dependent binaries - mdbook-linkcheck for example from https://github.com/Michael-F-Bryan/mdbook-linkcheck - are not supported "per build"
but rather the same binary is executed for both. Should not be hard to change that)

This is it's own BASH shell script

`tests/mdbook_version_validator/build_mdbook_branches.sh ${MDBOOK_BRANCH_1},${MDBOOK_BRANCH_2} ${G_TMPDIR} ${PWD}/target`

**Now we have two mdbook binaries**

2. Use the github API and find all repos under known orgs on github.com (and support extras via the command line)

2. Checkout the master branch of each one
3. Build each book twice
4. Compare the output directories

Comparison is difficult, but the following applies

`OK` - if the two output directories are identical
`WARN` - status==OK, if the two directories are not identical, but the size of the second is +/- 5% of the first.
`FAIL` - if the size of the second is greater than +/- 5% of the first.

Not bullet proof - but it works.

## Quick Start Guide

`sh tests/mdbook_version_validator/test_mdbook_book_builds.sh <branch1> <branch2>`
- This will build both versions of mdbook
- Search Github for `book.toml` files in repos
- Download each book, build them with both binaries, compare and report

## Output - Failure

Showing a tolerance failure (within +/- 5%)

```
$ sh tests/mdbook_version_validator/test_mdbook_book_builds.sh master smart-preprocessor
:: We have both binaries [/home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master, /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor]
:: Collecting the test book repos
:: https://github.com/rust-lang-nursery/mdBook
:: https://github.com/rust-lang/rust-by-example
:: https://github.com/rust-lang-nursery/api-guidelines
:: https://github.com/rust-lang-nursery/rustc-guide
:: https://github.com/rust-lang-nursery/rust-cookbook
:: Building https://github.com/rust-lang-nursery/mdBook
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.018quaRm/https___github_com_rust_lang_nursery_mdBook'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang-nursery/mdBook with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:50:38 [INFO] (mdbook::book): Book building has started
2018-09-03 23:50:38 [INFO] (mdbook::book): Running the html backend
:: Building rust-lang-nursery/mdBook with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
2018-09-03 23:50:40 [INFO] (mdbook::book): Book building has started
2018-09-03 23:50:40 [INFO] (mdbook::book): Running the html backend
:: /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.018quaRm/https___github_com_rust_lang_nursery_mdBook/book-example/book.toml the directories differ
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.018quaRm/generated_books/https___github_com_rust_lang_nursery_mdBook/mdbook-master
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.018quaRm/generated_books/https___github_com_rust_lang_nursery_mdBook/mdbook-smart-preprocessor
:: WARN differed, but inside tolerance +/- 5%
:: Building https://github.com/rust-lang/rust-by-example
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.018quaRm/https___github_com_rust_lang_rust_by_example'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang/rust-by-example with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:50:45 [INFO] (mdbook::book): Book building has started
2018-09-03 23:50:45 [INFO] (mdbook::book): Running the html backend
...
```

## Output - Success

```
23:42 $ sh tests/mdbook_version_validator/test_mdbook_book_builds.sh master smart-preprocessor
:: We have both binaries [/home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master, /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor]
:: Collecting the test book repos
:: https://github.com/rust-lang-nursery/mdBook
:: https://github.com/rust-lang/rust-by-example
:: https://github.com/rust-lang-nursery/api-guidelines
:: https://github.com/rust-lang-nursery/rustc-guide
:: https://github.com/rust-lang-nursery/rust-cookbook
:: Building https://github.com/rust-lang-nursery/mdBook
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_mdBook'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang-nursery/mdBook with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:42:40 [INFO] (mdbook::book): Book building has started
2018-09-03 23:42:40 [INFO] (mdbook::book): Running the html backend
:: Building rust-lang-nursery/mdBook with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
2018-09-03 23:42:42 [INFO] (mdbook::book): Book building has started
2018-09-03 23:42:42 [INFO] (mdbook::book): Running the html backend
:: OK /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_mdBook/book-example/book.toml is identical
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_mdBook/mdbook-master
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_mdBook/mdbook-smart-preprocessor
:: Building https://github.com/rust-lang/rust-by-example
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_rust_by_example'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang/rust-by-example with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:42:48 [INFO] (mdbook::book): Book building has started
2018-09-03 23:42:48 [INFO] (mdbook::book): Running the html backend
:: Building rust-lang/rust-by-example with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
2018-09-03 23:43:02 [INFO] (mdbook::book): Book building has started
2018-09-03 23:43:02 [INFO] (mdbook::book): Running the html backend
:: OK /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_rust_by_example/book.toml is identical
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_rust_by_example/mdbook-master
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_rust_by_example/mdbook-smart-preprocessor
:: Building https://github.com/rust-lang-nursery/api-guidelines
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_api_guidelines'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang-nursery/api-guidelines with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:43:20 [INFO] (mdbook::book): Book building has started
2018-09-03 23:43:20 [INFO] (mdbook::book): Running the html backend
:: Building rust-lang-nursery/api-guidelines with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
2018-09-03 23:43:23 [INFO] (mdbook::book): Book building has started
2018-09-03 23:43:23 [INFO] (mdbook::book): Running the html backend
:: OK /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_api_guidelines/book.toml is identical
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_api_guidelines/mdbook-master
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_api_guidelines/mdbook-smart-preprocessor
:: Building https://github.com/rust-lang-nursery/rustc-guide
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_rustc_guide'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang-nursery/rustc-guide with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:43:29 [INFO] (mdbook::book): Book building has started
2018-09-03 23:43:29 [INFO] (mdbook::book): Running the html backend
2018-09-03 23:43:40 [INFO] (mdbook::book): Running the linkcheck backend
2018-09-03 23:43:40 [INFO] (mdbook::renderer): Invoking the "linkcheck" renderer
:: Building rust-lang-nursery/rustc-guide with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
2018-09-03 23:43:40 [INFO] (mdbook::book): Book building has started
2018-09-03 23:43:40 [INFO] (mdbook::book): Running the html backend
2018-09-03 23:43:50 [INFO] (mdbook::book): Running the linkcheck backend
2018-09-03 23:43:50 [INFO] (mdbook::renderer): Invoking the "linkcheck" renderer
:: OK /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_rustc_guide/book.toml is identical
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_rustc_guide/mdbook-master
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_rustc_guide/mdbook-smart-preprocessor
:: Building https://github.com/rust-lang-nursery/rust-cookbook
Cloning into '/var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_rust_cookbook'...
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
:: /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
:: Building rust-lang-nursery/rust-cookbook with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-master
2018-09-03 23:43:54 [INFO] (mdbook::book): Book building has started
2018-09-03 23:43:54 [INFO] (mdbook::book): Running the html backend
:: Building rust-lang-nursery/rust-cookbook with /home/rbuckland/projects/github.com/rust-lang-nursery/mdBook/target/mdbook-smart-preprocessor
2018-09-03 23:44:01 [INFO] (mdbook::book): Book building has started
2018-09-03 23:44:01 [INFO] (mdbook::book): Running the html backend
:: OK /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/https___github_com_rust_lang_nursery_rust_cookbook/book.toml is identical
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_rust_cookbook/mdbook-master
- /var/folders/cy/m597b3cj1s71904cxdtxk8dnlthn4x/T/tmp.wtHqLOnn/generated_books/https___github_com_rust_lang_nursery_rust_cookbook/mdbook-smart-preprocessor
```
124 changes: 124 additions & 0 deletions tests/mdbook_version_validator/build_books_and_compare.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
#!/bin/bash

red=$'\e[1;31m'
grn=$'\e[1;32m'
yel=$'\e[0;33m'
blu=$'\e[1;34m'
mag=$'\e[1;35m'
cyn=$'\e[1;36m'
white=$'\e[0m'


#--------------------------
function help() {

echo "Usage:"
echo ""


echo " $0"
awk -F ')' '/\|--.*shift/ && ! /awk/ { print $1} ' $0

cat <<HELP

This shell script takes the path to two mdbook binaries;
and a third parameter of the book directory where one or more book.toml's live.

It will then build every "book.toml" book in the directory, twice, with the two mdbook versions.
once complete, it will compare the two directories.

Comparison is difficult, but the following applies

OK - if the two output directories are identical
WARN - status==OK, if the two directories are not identical, but the size of the second is +/- 5% of the first.
FAIL - if the size of the second is greater than +/- 5% of the first.

HELP

}
#--------------------------

if [[ $# -eq 0 ]]; then
$0 --help
exit 1
fi

if [[ $# -ne 10 && $# -ne 1 ]]; then
$0 --help
exit 1
fi


while [[ $# -ge 1 ]]; do
case "$1" in
-v1|--version1) VERSION1="${2}"; shift 2 ;;
-v2|--version2) VERSION2="${2}"; shift 2 ;;
-p|--book-path) BOOK_PATH="${2}"; shift 2 ;;
-n|--book-name) BOOK_NAME="${2}"; shift 2 ;;
-d|--working-dir) WORKING_DIR="${2}"; shift 2 ;;
-h|--help) help ; exit 0 ;;
*) echo "Unknown arg [$1]. Error parsing arguments" ; exit 1 ;;
esac
done

function build_book_and_check() {
binary=$1
book_toml=$2
output_dir=$3

dir=$(dirname $book_toml)
mkdir -p ${output_dir} 2> /dev/null

echo "$blu:: Building $BOOK_NAME with $binary${white}"

(cd $dir && $binary build --dest-dir ${output_dir} )

retVal=$?
if [ $retVal -ne 0 ]; then
echo "$red:: Failed to build $book_toml with $binary"
fi
return

}

#--------------------------

books=$(find ${BOOK_PATH} -type f -name book.toml)
basename_1=$(basename $VERSION1)
basename_2=$(basename $VERSION2)

echo :: $VERSION1
echo :: $VERSION2

for book_toml in $books
do

build_book_and_check $VERSION1 $book_toml ${WORKING_DIR}/${basename_1}
build_book_and_check $VERSION2 $book_toml ${WORKING_DIR}/${basename_2}

DIFF=$(diff -rq ${WORKING_DIR}/${basename_1} ${WORKING_DIR}/${basename_2} )
if [ "$DIFF" != "" ]
then
echo "$red:: $book_toml the directories differ$white"
echo $mag - ${WORKING_DIR}/${basename_1}$white
echo $mag - ${WORKING_DIR}/${basename_2}$white

dir_1_size=$(du -s ${WORKING_DIR}/${basename_1} | awk '{print $1*512}' )
dir_2_size=$(du -s ${WORKING_DIR}/${basename_2} | awk '{print $1*512}' )

if (( dir_2_size / dir_1_size * 100 > 105 || dir_2_size / dir_1_size * 100 < 95 )); then
echo $red:: FAIL outside Tolerance +/- 5% $white
FAIL=1
else
echo $yel:: WARN differed, but inside tolerance +/- 5% $white
fi
else
echo $grn:: OK $book_toml is identical$white
echo $cyn - ${WORKING_DIR}/${basename_1}$white
echo $cyn - ${WORKING_DIR}/${basename_2}$white
fi
done

if [[ $FAIL -eq 1 ]];then
exit 1
fi
29 changes: 29 additions & 0 deletions tests/mdbook_version_validator/build_mdbook_branches.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
#!/bin/sh

#
# Example:
# sh tests/mdbook_version_validator/build_branches.sh master,smart-preprocessor /tmp/fff `pwd`/target
#
# This will generate two binaries, mdbook_master and mdbook_smart-preprocessor
# We can then use both these binaries, to check the "build" of other books to see if they differ.
#

BRANCHES=$1
WORKING_DIR=$2
OUT_PATH=$3
REPO=${4:-"https://github.com/rust-lang-nursery/mdbook"}

for branch in $(echo $BRANCHES | sed "s/,/ /g")
do
safe_branch=$(echo $branch | sed "s/[^A-Za-z0-9-]/_/g")
workdir_for_branch=${WORKING_DIR}_${safe_branch}
binary_name=mdbook-${safe_branch}

git clone --depth=1 --branch=${branch} ${REPO} ${workdir_for_branch}
rm -rf ${workdir_for_branch}/.git
cd ${workdir_for_branch} && \
cargo build && \
mv target/debug/mdbook ${OUT_PATH}/${binary_name} && \
echo "${safe_branch}=${OUT_PATH}/${binary_name}"
done

Loading