2008-02-06 23:06:40 +03:00
|
|
|
#!/bin/bash -e
|
2007-05-11 08:11:39 +04:00
|
|
|
# -*- Mode: Shell-script; tab-width: 4; indent-tabs-mode: nil; -*-
|
|
|
|
|
2007-10-01 23:10:41 +04:00
|
|
|
# ***** BEGIN LICENSE BLOCK *****
|
|
|
|
# Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
#
|
|
|
|
# The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
# 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
# the License. You may obtain a copy of the License at
|
|
|
|
# http://www.mozilla.org/MPL/
|
|
|
|
#
|
|
|
|
# Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
# for the specific language governing rights and limitations under the
|
|
|
|
# License.
|
|
|
|
#
|
|
|
|
# The Original Code is Mozilla JavaScript Testing Utilities
|
|
|
|
#
|
|
|
|
# The Initial Developer of the Original Code is
|
|
|
|
# Mozilla Corporation.
|
|
|
|
# Portions created by the Initial Developer are Copyright (C) 2007
|
|
|
|
# the Initial Developer. All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Contributor(s): Bob Clary <bclary@bclary.com>
|
|
|
|
#
|
|
|
|
# Alternatively, the contents of this file may be used under the terms of
|
|
|
|
# either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
# the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
# in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
# of those above. If you wish to allow use of your version of this file only
|
|
|
|
# under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
# use your version of this file under the terms of the MPL, indicate your
|
|
|
|
# decision by deleting the provisions above and replace them with the notice
|
|
|
|
# and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
# the provisions above, a recipient may use your version of this file under
|
|
|
|
# the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
#
|
|
|
|
# ***** END LICENSE BLOCK *****
|
|
|
|
|
2007-05-11 08:11:39 +04:00
|
|
|
TEST_DIR=${TEST_DIR:-/work/mozilla/mozilla.com/test.mozilla.com/www}
|
|
|
|
TEST_BIN=${TEST_BIN:-$TEST_DIR/bin}
|
2007-07-12 21:49:32 +04:00
|
|
|
TEST_JSDIR=${TEST_JSDIR:-$TEST_DIR/tests/mozilla.org/js}
|
|
|
|
|
2007-10-01 23:10:41 +04:00
|
|
|
if [[ ! -e $TEST_BIN/library.sh ]]; then
|
|
|
|
echo "TEST_DIR=$TEST_DIR"
|
|
|
|
echo ""
|
|
|
|
echo "This script requires the Sisyphus testing framework. Please "
|
|
|
|
echo "cvs check out the Sisyphys framework from mozilla/testing/sisyphus"
|
|
|
|
echo "and set the environment variable TEST_DIR to the directory where it"
|
|
|
|
echo "located."
|
|
|
|
echo ""
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ ! -e $TEST_JSDIR/runtests.sh ]]; then
|
|
|
|
echo "TEST_JSDIR=$TEST_JSDIR"
|
|
|
|
echo ""
|
|
|
|
echo "If the TEST_JSDIR environment variable is not set, this script "
|
|
|
|
echo "assumes the JavaScript Tests live in \${TEST_DIR}/www/tests/mozilla.org/js"
|
|
|
|
echo "If this is not correct, please set the TEST_JSDIR environment variable"
|
|
|
|
echo "to point to the directory containing the JavaScript Test Library."
|
|
|
|
echo ""
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ ! -e $TEST_BIN/library.sh || ! -e $TEST_JSDIR/runtests.sh ]]; then
|
|
|
|
exit 2
|
|
|
|
fi
|
|
|
|
|
|
|
|
source ${TEST_BIN}/library.sh
|
|
|
|
|
2007-05-11 08:11:39 +04:00
|
|
|
#
|
|
|
|
# options processing
|
|
|
|
#
|
2007-10-23 20:54:53 +04:00
|
|
|
options="d:"
|
2007-05-11 08:11:39 +04:00
|
|
|
usage()
|
|
|
|
{
|
|
|
|
cat <<EOF
|
|
|
|
usage: $SCRIPT -d datafiles
|
|
|
|
|
|
|
|
This script is used to dispatch to either test-browser.sh
|
|
|
|
for browser based JavaScript tests or test-shell.js for
|
|
|
|
shell based JavaScript tests. It ignores all input arguments
|
|
|
|
except -d datafiles which it uses to pass data to the
|
|
|
|
appropriate script.
|
|
|
|
|
|
|
|
variable description
|
|
|
|
=============== ============================================================
|
|
|
|
-d datafiles optional. one or more filenames of files containing
|
|
|
|
environment variable definitions to be included.
|
|
|
|
if an argument contains more than one value, it must be quoted.
|
|
|
|
EOF
|
|
|
|
exit 2
|
|
|
|
}
|
|
|
|
|
|
|
|
unset datafiles
|
|
|
|
|
|
|
|
while getopts $options optname ;
|
|
|
|
do
|
|
|
|
case $optname in
|
|
|
|
d) datafiles=$OPTARG;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
if [[ -z "$datafiles" ]]; then
|
|
|
|
usage
|
|
|
|
fi
|
|
|
|
|
|
|
|
for data in $datafiles; do
|
|
|
|
source $data
|
|
|
|
done
|
|
|
|
|
|
|
|
case "$product" in
|
2007-07-12 21:49:32 +04:00
|
|
|
firefox) testscript=$TEST_JSDIR/test-browser.sh;;
|
|
|
|
js) testscript=$TEST_JSDIR/test-shell.sh;;
|
2007-05-11 08:11:39 +04:00
|
|
|
*) echo "unknown product [$product]"
|
|
|
|
exit 2
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2008-02-06 23:06:40 +03:00
|
|
|
$testscript -d "$datafiles"
|