Index: tools/test-push-to-trunk.sh |
diff --git a/tools/test-push-to-trunk.sh b/tools/test-push-to-trunk.sh |
deleted file mode 100755 |
index 6c201e46288514c75d9d07cd0db92602e66b97e6..0000000000000000000000000000000000000000 |
--- a/tools/test-push-to-trunk.sh |
+++ /dev/null |
@@ -1,246 +0,0 @@ |
-#!/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 |