| 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 | 
|  |