pytest is not correctly auto-installed
[WebKit-https.git] / Tools / Scripts / run-webkit-tests
index abe3425..fd87e87 100755 (executable)
@@ -1,5 +1,5 @@
-#!/usr/bin/perl
-# Copyright (C) 2010 Google Inc. All rights reserved.
+#!/usr/bin/env python
+# Copyright (C) 2011 Google Inc. All rights reserved.
 #
 # Redistribution and use in source and binary forms, with or without
 # modification, are permitted provided that the following conditions are
 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
-# This file is a temporary hack.
-# It will be removed as soon as all platforms are are ready to move to
-# new-run-webkit-tests and we can then update the buildbots to explicitly
-# call old-run-webkit-tests for any platforms which will never support
-# a Python run-webkit-tests.
+"""Wrapper around webkitpy/layout_tests/run_webkit_tests.py"""
+import os
+import sys
 
-# This is intentionally written in Perl to guarantee support on
-# the same set of platforms as old-run-webkit-tests currently supports.
-# The buildbot master.cfg also currently passes run-webkit-tests to
-# perl directly instead of executing it in a shell.
+from webkitpy.common import multiprocessing_bootstrap
 
-use strict;
-use warnings;
+top_level_directory = os.path.normpath(os.path.join(os.path.dirname(__file__), '..', '..'))
+sys.path.insert(0, os.path.join(top_level_directory, 'Tools', 'flatpak'))
+import flatpakutils
+flatpakutils.run_in_sandbox_if_available(sys.argv)
 
-use File::Spec;
-use FindBin;
-use lib $FindBin::Bin;
-use webkitdirs;
-
-sub runningOnBuildBot()
-{
-    # This is a hack to detect if we're running on the buildbot so we can
-    # pass --verbose to new-run-webkit-tests.  This will be removed when we
-    # update the buildbot config to call new-run-webkit-tests explicitly.
-    my %isBuildBotUser = ("apple" => 1, "buildbot" => 1, "webkitbuildbot" => 1, "slave" => 1);
-    return $isBuildBotUser{$ENV{"USER"}};
-}
-
-# We could use isWebKit2() instead of our own custom usingWebKit2(), but then
-# we'd have to be careful to add -2 or --webkit-test-runner back into @ARGV below.
-sub usingWebKit2()
-{
-    # If either -2 or --webkit-test-runner is passed, we're supposed to use WebKit2.
-    # NRWT's WebKit2 support is still a work in progress:
-    # https://bugs.webkit.org/show_bug.cgi?id=56729
-    return grep(/(-2|--webkit-test-runner)/, @ARGV);
-}
-
-sub usingLeaks()
-{
-    # NRWT doesn't support --leaks yet.
-    # https://bugs.webkit.org/show_bug.cgi?id=63832
-    return grep(/--leaks/, @ARGV);
-}
-
-sub useNewRunWebKitTests()
-{
-    # Change this check to control which platforms use new-run-webkit-tests by default.
-    # Example: return runningOnBuildBot() && isLeopard();
-    # would enable new-run-webkit-tests on only the leopard buildbots.
-
-    # Note: We use a whitelist here to avoid calling isPORT() for ports
-    # for which we haven't explicitly added support.  Calling isPORT()
-    # will remove the --PORT argument from @ARGV, causing us to fail to pass it to the test harness.
-
-    # NRWT Windows support still needs work: https://bugs.webkit.org/show_bug.cgi?id=38756
-    return ((isLeopard() or isSnowLeopard() or isQt() or isGtk()) and !usingWebKit2() and !usingLeaks());
-}
-
-my $harnessName = "old-run-webkit-tests";
-
-if (useNewRunWebKitTests()) {
-    $harnessName = "new-run-webkit-tests";
-    push(@ARGV, "--child-processes=1");
-    print "Running new-run-webkit-tests with one child process.\n";
-    print "For more parallelism, run new-run-webkit-tests directly.\n";
-    if (runningOnBuildBot()) {
-        push(@ARGV, "--verbose");
-    }
-
-    # FIXME: We need a cleaner way to do --platform handling.
-    # webkitdirs.pm strips --qt and --gtk from @ARGV when we call isQt/isGtk.
-    # Unfortunately new-run-webkit-tests wouldn't understand --qt/--gtk if we passed it to it anyway,
-    # so we have to convert it to --platform=PORT equivalents.
-    # https://bugs.webkit.org/show_bug.cgi?id=63970
-    if (isQt()) {
-        push(@ARGV, "--platform=qt");
-    } elsif (isGtk()) {
-        push(@ARGV, "--platform=gtk");
-    }
-} else {
-    # We have to add back any --PORT arguments which may have been removed by isPort() checks above.
-    if (isQt()) {
-        push(@ARGV, "--qt");
-    } elsif (isGtk()) {
-        push(@ARGV, "--gtk");
-    }
-}
-
-my $harnessPath = File::Spec->catfile(relativeScriptsDir(), $harnessName);
-exec $harnessPath ($harnessPath, @ARGV) or die "Failed to execute $harnessPath";
+multiprocessing_bootstrap.run('webkitpy', 'layout_tests', 'run_webkit_tests.py')
\ No newline at end of file