| Index: tools/test-push-to-trunk.sh
|
| diff --git a/tools/test-push-to-trunk.sh b/tools/test-push-to-trunk.sh
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..6c201e46288514c75d9d07cd0db92602e66b97e6
|
| --- /dev/null
|
| +++ b/tools/test-push-to-trunk.sh
|
| @@ -0,0 +1,246 @@
|
| +#!/bin/bash
|
| +# Copyright 2013 the V8 project authors. All rights reserved.
|
| +# Redistribution and use in source and binary forms, with or without
|
| +# modification, are permitted provided that the following conditions are
|
| +# met:
|
| +#
|
| +# * Redistributions of source code must retain the above copyright
|
| +# notice, this list of conditions and the following disclaimer.
|
| +# * Redistributions in binary form must reproduce the above
|
| +# copyright notice, this list of conditions and the following
|
| +# disclaimer in the documentation and/or other materials provided
|
| +# with the distribution.
|
| +# * Neither the name of Google Inc. nor the names of its
|
| +# contributors may be used to endorse or promote products derived
|
| +# from this software without specific prior written permission.
|
| +#
|
| +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
| +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
| +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
| +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
| +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
| +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
| +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
| +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
| +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
| +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
| +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
| +
|
| +# Tests the push-to-trunk.sh script. Needs to be run in V8 base dir:
|
| +# ./tools/test-push-to-trunk.sh
|
| +
|
| +# TODO(machenbach): Check automatically if expectations match.
|
| +# TODO(machenbach): Mock out version number retrieval.
|
| +# TODO(machenbach): Allow multiple different test cases.
|
| +# TODO(machenbach): Allow multi line mock output.
|
| +# TODO(machenbach): Represent test expectations/mock output without an array
|
| +# index increment.
|
| +
|
| +########## Stdin for push-to-trunk.sh
|
| +
|
| +# Confirm push to trunk commit ID
|
| +INPUT[0]="Y"
|
| +# Open editor
|
| +INPUT[1]=""
|
| +# Confirm increment version number
|
| +INPUT[2]="Y"
|
| +# Reviewer for V8 CL
|
| +INPUT[3]="reviewer@chromium.org"
|
| +# Enter LGTM for V8 CL
|
| +INPUT[4]="LGTM"
|
| +# Confirm checkout sanity
|
| +INPUT[5]="Y"
|
| +# Manually type in trunk revision
|
| +INPUT[6]="12345"
|
| +# Reviewer for Chromium CL
|
| +INPUT[7]="reviewer@chromium.org"
|
| +
|
| +########## Expected commands and mock output
|
| +
|
| +EXP[0]="git status -s -uno"
|
| +OUT[0]=""
|
| +EXP[1]="git status -s -b -uno"
|
| +OUT[1]="## some_branch"
|
| +EXP[2]="git svn fetch"
|
| +OUT[2]=""
|
| +EXP[3]="git branch"
|
| +OUT[3]="not the temp branch"
|
| +EXP[4]="git checkout -b prepare-push-temporary-branch-created-by-script"
|
| +OUT[4]=""
|
| +EXP[5]="git branch"
|
| +OUT[5]="not the branch"
|
| +EXP[6]="git branch"
|
| +OUT[6]="not the trunk branch"
|
| +EXP[7]="git checkout -b prepare-push svn/bleeding_edge"
|
| +OUT[7]=""
|
| +EXP[8]="git log -1 --format=%H ChangeLog"
|
| +OUT[8]="hash1"
|
| +EXP[9]="git log -1 hash1"
|
| +OUT[9]=""
|
| +EXP[10]="git log hash1..HEAD --format=%H"
|
| +OUT[10]="hash2"
|
| +EXP[11]="git log -1 hash2 --format=\"%w(80,8,8)%s\""
|
| +OUT[11]="Log line..."
|
| +EXP[12]="git log -1 hash2 --format=\"%B\""
|
| +OUT[12]="BUG=6789"
|
| +EXP[13]="git log -1 hash2 --format=\"%w(80,8,8)(%an)\""
|
| +OUT[13]=" (author@chromium.org)"
|
| +EXP[14]="git commit -a -m \"Prepare push to trunk. Now working on version 3.4.5.\""
|
| +OUT[14]=""
|
| +EXP[15]="git cl upload -r reviewer@chromium.org --send-mail"
|
| +OUT[15]=""
|
| +EXP[16]="git cl dcommit"
|
| +OUT[16]=""
|
| +EXP[17]="git svn fetch"
|
| +OUT[17]=""
|
| +EXP[18]="git checkout svn/bleeding_edge"
|
| +OUT[18]=""
|
| +EXP[19]="git log -1 --format=%H --grep=Prepare push to trunk. Now working on version 3.4.5."
|
| +OUT[19]="hash3"
|
| +EXP[20]="git diff svn/trunk"
|
| +OUT[20]="patch1"
|
| +EXP[21]="git checkout -b trunk-push svn/trunk"
|
| +OUT[21]=""
|
| +EXP[22]="git apply --index --reject /tmp/v8-push-to-trunk-tempfile-patch"
|
| +OUT[22]=""
|
| +EXP[23]="git add src/version.cc"
|
| +OUT[23]=""
|
| +EXP[24]="git commit -F /tmp/v8-push-to-trunk-tempfile-commitmsg"
|
| +OUT[24]=""
|
| +EXP[25]="git svn dcommit"
|
| +OUT[25]="r1234"
|
| +EXP[26]="git svn tag 3.4.5 -m \"Tagging version 3.4.5\""
|
| +OUT[26]=""
|
| +EXP[27]="git status -s -uno"
|
| +OUT[27]=""
|
| +EXP[28]="git checkout master"
|
| +OUT[28]=""
|
| +EXP[29]="git pull"
|
| +OUT[29]=""
|
| +EXP[30]="git checkout -b v8-roll-12345"
|
| +OUT[30]=""
|
| +EXP[31]="git commit -am Update V8 to version 3.4.5."
|
| +OUT[31]=""
|
| +EXP[32]="git cl upload --send-mail"
|
| +OUT[32]=""
|
| +EXP[33]="git checkout -f some_branch"
|
| +OUT[33]=""
|
| +EXP[34]="git branch -D prepare-push-temporary-branch-created-by-script"
|
| +OUT[34]=""
|
| +EXP[35]="git branch -D prepare-push"
|
| +OUT[35]=""
|
| +EXP[36]="git branch -D trunk-push"
|
| +OUT[36]=""
|
| +
|
| +########## Global temp files for test input/output
|
| +
|
| +export TEST_OUTPUT=$(mktemp)
|
| +export INDEX=$(mktemp)
|
| +export MOCK_OUTPUT=$(mktemp)
|
| +export EXPECTED_COMMANDS=$(mktemp)
|
| +
|
| +########## Command index
|
| +
|
| +inc_index() {
|
| + local I="$(command cat $INDEX)"
|
| + let "I+=1"
|
| + echo "$I" > $INDEX
|
| + echo $I
|
| +}
|
| +
|
| +echo "-1" > $INDEX
|
| +export -f inc_index
|
| +
|
| +########## Mock output accessor
|
| +
|
| +get_mock_output() {
|
| + local I=$1
|
| + let "I+=1"
|
| + command sed "${I}q;d" $MOCK_OUTPUT
|
| +}
|
| +
|
| +export -f get_mock_output
|
| +
|
| +for E in "${OUT[@]}"; do
|
| + echo $E
|
| +done > $MOCK_OUTPUT
|
| +
|
| +########## Expected commands accessor
|
| +
|
| +get_expected_command() {
|
| + local I=$1
|
| + let "I+=1"
|
| + command sed "${I}q;d" $EXPECTED_COMMANDS
|
| +}
|
| +
|
| +export -f get_expected_command
|
| +
|
| +for E in "${EXP[@]}"; do
|
| + echo $E
|
| +done > $EXPECTED_COMMANDS
|
| +
|
| +########## Mock commands
|
| +
|
| +git() {
|
| + # All calls to git are mocked out. Expected calls and mock output are stored
|
| + # in the EXP/OUT arrays above.
|
| + local I=$(inc_index)
|
| + local OUT=$(get_mock_output $I)
|
| + local EXP=$(get_expected_command $I)
|
| + echo "#############################" >> $TEST_OUTPUT
|
| + echo "Com. Index: $I" >> $TEST_OUTPUT
|
| + echo "Expected: ${EXP}" >> $TEST_OUTPUT
|
| + echo "Actual: git $@" >> $TEST_OUTPUT
|
| + echo "Mock Output: ${OUT}" >> $TEST_OUTPUT
|
| + echo "${OUT}"
|
| +}
|
| +
|
| +mv() {
|
| + echo "#############################" >> $TEST_OUTPUT
|
| + echo "mv $@" >> $TEST_OUTPUT
|
| +}
|
| +
|
| +sed() {
|
| + # Only calls to sed * -i * are mocked out.
|
| + echo "#############################" >> $TEST_OUTPUT
|
| + local arr=$@
|
| + if [[ "${arr[@]}" =~ "-i" || "${arr[${#arr[@]}-1]}" == "-i" ]]; then
|
| + echo "sed $@" >> $TEST_OUTPUT
|
| + else
|
| + echo "sed $@" >> $TEST_OUTPUT
|
| + command sed "$@"
|
| + fi
|
| +}
|
| +
|
| +editor() {
|
| + echo "#############################" >> $TEST_OUTPUT
|
| + echo "editor $@" >> $TEST_OUTPUT
|
| +}
|
| +
|
| +cd() {
|
| + echo "#############################" >> $TEST_OUTPUT
|
| + echo "cd $@" >> $TEST_OUTPUT
|
| +}
|
| +
|
| +export -f git
|
| +export -f mv
|
| +export -f sed
|
| +export -f cd
|
| +export -f editor
|
| +export EDITOR=editor
|
| +
|
| +########## Invoke script with test stdin
|
| +
|
| +for i in "${INPUT[@]}"; do
|
| + echo $i
|
| +done | tools/push-to-trunk.sh -c "path/to/chromium"
|
| +
|
| +echo "Collected output:"
|
| +command cat $TEST_OUTPUT
|
| +
|
| +########## Clean up
|
| +
|
| +rm -rf $TEST_OUTPUT
|
| +rm -rf $INDEX
|
| +rm -rf $MOCK_OUTPUT
|
| +rm -rf $EXPECTED_COMMANDS
|
|
|