REGRESSION (r236481): Move soft-linking of LocalAuthentication.framework out of Local...
[WebKit-https.git] / Tools / Scripts / run-sunspider
1 #!/usr/bin/env perl
2
3 # Copyright (C) 2007 Apple Inc. All rights reserved.
4 # Copyright (C) 2007 Eric Seidel <eric@webkit.org>
5 #
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions
8 # are met:
9 # 1. Redistributions of source code must retain the above copyright
10 #    notice, this list of conditions and the following disclaimer.
11 # 2. Redistributions in binary form must reproduce the above copyright
12 #    notice, this list of conditions and the following disclaimer in the
13 #    documentation and/or other materials provided with the distribution.
14 #
15 # THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
16 # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
18 # PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
19 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
20 # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
21 # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
22 # PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
23 # OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
26
27 use strict;
28 use warnings;
29 use FindBin;
30 use Getopt::Long qw(:config pass_through);
31 use lib $FindBin::Bin;
32 use webkitdirs;
33 use POSIX;
34
35 # determine configuration, but default to "Release" instead of last-used configuration
36 setConfiguration("Release");
37 setConfiguration();
38 my $configuration = configuration();
39
40 my $root;
41 my $testRuns = 10; # This number may be different from what sunspider defaults to (that's OK)
42 my $runInstruments = 0;
43 my $suite = "";
44 my $ubench = 0;
45 my $v8suite = 0;
46 my $parseonly = 0;
47 my $setBaseline = 0;
48 my $showHelp = 0;
49 my $testsPattern;
50 my $output = "";
51 my $noBuild = 0;
52 my $jsShellArgs="";
53
54 my $programName = basename($0);
55 my $usage = <<EOF;
56 Usage: $programName [options] [options to pass to build system]
57   --help            Show this help message
58   --set-baseline    Set baseline for future comparisons
59   --args            Arguments to pass to JavaScript shell
60   --root            Path to root tools build
61   --runs            Number of times to run tests (default: $testRuns)
62   --tests           Only run tests matching provided pattern
63   --instruments     Sample with the Mac OS X "Instruments" tool (Time Profile) (implies --runs=1)
64   --suite           Select a specific benchmark suite. The default is sunspider-0.9.1
65   --ubench          Use microbenchmark suite instead of regular tests. Same as --suite=ubench
66   --v8-suite        Use the V8 benchmark suite. Same as --suite=v8-v4
67   --parse-only      Use the parse-only benchmark suite. Same as --suite=parse-only
68   --output          Override the default output path and filename
69   --no-build        Do not try to build JSC before running the tests.
70 EOF
71
72 GetOptions('root=s' => sub { my ($x, $value) = @_; $root = $value; setConfigurationProductDir(Cwd::abs_path($root)); },
73            'runs=i' => \$testRuns,
74            'set-baseline' => \$setBaseline,
75            'args=s' => \$jsShellArgs,
76            'instruments' => \$runInstruments,
77            'suite=s' => \$suite,
78            'ubench' => \$ubench,
79            'v8-suite' => \$v8suite,
80            'parse-only' => \$parseonly,
81            'tests=s' => \$testsPattern,
82            'output=s' => \$output,
83            'help' => \$showHelp,
84            'no-build' => \$noBuild);
85
86 if ($showHelp) {
87    print STDERR $usage;
88    exit 1;
89 }
90
91 sub buildJSC
92 {
93     if (!defined($root)){
94         push(@ARGV,  "--" . $configuration);
95         
96         chdirWebKit();
97         my $buildResult = system currentPerlPath(), "Tools/Scripts/build-jsc", @ARGV;
98         if ($buildResult) {
99             print STDERR "Compiling jsc failed!\n";
100             exit exitStatus($buildResult);
101         }
102     }
103 }
104
105 sub setupEnvironmentForExecution($)
106 {
107     my ($productDir) = @_;
108     print "Starting sunspider with DYLD_FRAMEWORK_PATH set to point to built JavaScriptCore in $productDir.\n";
109     $ENV{DYLD_FRAMEWORK_PATH} = $productDir;
110     # FIXME: Other platforms may wish to augment this method to use LD_LIBRARY_PATH, etc.
111 }
112
113 unless ($noBuild) {
114     buildJSC();
115 }
116
117 chdirWebKit();
118 chdir("PerformanceTests/SunSpider");
119
120 my $productDir = jscProductDir();
121
122 setupEnvironmentForExecution($productDir);
123 my @args = ("--shell", jscPath($productDir), "--runs", $testRuns);
124 # This code could be removed if we chose to pass extra args to sunspider instead of Xcode
125 push @args, "--set-baseline" if $setBaseline;
126 push @args, "--instruments" if $runInstruments;
127 push @args, "--suite=${suite}" if $suite;
128 push @args, "--ubench" if $ubench;
129 push @args, "--v8-suite" if $v8suite;
130 push @args, "--parse-only" if $parseonly;
131 push @args, "--tests", $testsPattern if $testsPattern;
132 push @args, "--args", $jsShellArgs if $jsShellArgs;
133 push @args, "--output", $output if $output;
134
135 exec currentPerlPath(), "./sunspider", @args;