mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-30 00:01:50 +00:00
026abf6d83
Now log in a single file given by the MOZ_JAR_LOG_FILE environment variable. Log entries contain the URI of the Zip archive, followed by the path in the archive. * * * Bug 840094 - Fixup for debug builds failure because of nsZipArchive::CloseArchive being called several times
60 lines
1.9 KiB
Python
60 lines
1.9 KiB
Python
#literal #!/usr/bin/python
|
|
#
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
import SimpleHTTPServer
|
|
import SocketServer
|
|
import socket
|
|
import threading
|
|
import os
|
|
import sys
|
|
import shutil
|
|
from datetime import datetime
|
|
|
|
SCRIPT_DIR = os.path.abspath(os.path.realpath(os.path.dirname(sys.argv[0])))
|
|
sys.path.insert(0, SCRIPT_DIR)
|
|
from automation import Automation
|
|
from automationutils import getDebuggerInfo, addCommonOptions
|
|
|
|
PORT = 8888
|
|
PROFILE_DIRECTORY = os.path.abspath(os.path.join(SCRIPT_DIR, "./pgoprofile"))
|
|
MOZ_JAR_LOG_FILE = os.path.abspath(os.getenv("JARLOG_FILE"))
|
|
os.chdir(SCRIPT_DIR)
|
|
|
|
class EasyServer(SocketServer.TCPServer):
|
|
allow_reuse_address = True
|
|
|
|
if __name__ == '__main__':
|
|
from optparse import OptionParser
|
|
automation = Automation()
|
|
|
|
parser = OptionParser()
|
|
addCommonOptions(parser)
|
|
|
|
options, args = parser.parse_args()
|
|
|
|
debuggerInfo = getDebuggerInfo(".", options.debugger, options.debuggerArgs,
|
|
options.debuggerInteractive)
|
|
|
|
httpd = EasyServer(("", PORT), SimpleHTTPServer.SimpleHTTPRequestHandler)
|
|
t = threading.Thread(target=httpd.serve_forever)
|
|
t.setDaemon(True) # don't hang on exit
|
|
t.start()
|
|
|
|
automation.setServerInfo("localhost", PORT)
|
|
automation.initializeProfile(PROFILE_DIRECTORY)
|
|
browserEnv = automation.environment()
|
|
browserEnv["XPCOM_DEBUG_BREAK"] = "warn"
|
|
browserEnv["MOZ_JAR_LOG_FILE"] = MOZ_JAR_LOG_FILE
|
|
|
|
url = "http://localhost:%d/index.html" % PORT
|
|
appPath = os.path.join(SCRIPT_DIR, automation.DEFAULT_APP)
|
|
status = automation.runApp(url, browserEnv, appPath, PROFILE_DIRECTORY, {},
|
|
debuggerInfo=debuggerInfo,
|
|
# the profiling HTML doesn't output anything,
|
|
# so let's just run this without a timeout
|
|
timeout = None)
|
|
sys.exit(status)
|