1#!/usr/bin/perl
2#
3# Copyright (C) 2009 Chris Jerdonek (chris.jerdonek@gmail.com)
4#
5# Redistribution and use in source and binary forms, with or without
6# modification, are permitted provided that the following conditions are
7# met:
8# 
9#     * Redistributions of source code must retain the above copyright
10# notice, this list of conditions and the following disclaimer.
11#     * Redistributions in binary form must reproduce the above
12# copyright notice, this list of conditions and the following disclaimer
13# in the documentation and/or other materials provided with the
14# distribution.
15#     * Neither the name of Google Inc. nor the names of its
16# contributors may be used to endorse or promote products derived from
17# this software without specific prior written permission.
18# 
19# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31# Runs unit tests of WebKit Perl code.
32
33use strict;
34use warnings;
35
36use File::Spec;
37use FindBin;
38use Test::Harness;
39use lib $FindBin::Bin; # so this script can be run from any directory.
40use VCSUtils;
41
42# Change the working directory so that we can pass shorter, relative
43# paths to runtests(), rather than longer, absolute paths.
44#
45# We change to the source root so the paths can be relative to the
46# source root. These paths display on the screen, and their meaning
47# will be clearer to the user if relative to the root, rather than to
48# the Scripts directory, say.
49#
50# Source root is two levels up from the Scripts directory.
51my $sourceRootDir = File::Spec->catfile($FindBin::Bin, "../..");
52chdir($sourceRootDir);
53
54# Relative to root
55my $pattern = "Tools/Scripts/webkitperl/*_unittest/*.pl";
56
57my @files = <${pattern}>; # lists files alphabetically
58
59runtests(@files);
60