##// END OF EJS Templates
Option to spew subprocess streams during tests...
Option to spew subprocess streams during tests This supersedes PR #4268. Run the tests with '--subproc-streams show' to show output from subprocesses (kernels, IPython.parallel components) in the terminal, or with '--subproc-streams discard' to send it to /dev/null. By default (or with '--subproc-streams capture') the output is piped, captured and displayed only when tests fail. But in some situations, a test fails because of an error which actually occurred earlier, so you have to see all the output.

File last commit:

r13697:dcc9c441
r13824:d77e2f51
Show More
serve.py
112 lines | 4.1 KiB | text/x-python | PythonLexer
MinRK
add proxying tornado server in Serve post-processor
r12442 """PostProcessor for serving reveal.js HTML slideshows."""
Thomas Kluyver
Convert print statements to print function calls...
r13348 from __future__ import print_function
damianavila
Added serve option as a post processor.
r11773 #-----------------------------------------------------------------------------
#Copyright (c) 2013, the IPython Development Team.
#
#Distributed under the terms of the Modified BSD License.
#
#The full license is in the file COPYING.txt, distributed with this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
import os
damianavila
Added webbroser to auto open the slideshow.
r11804 import webbrowser
MinRK
add proxying tornado server in Serve post-processor
r12442 from tornado import web, ioloop, httpserver
from tornado.httpclient import AsyncHTTPClient
damianavila
Added serve option as a post processor.
r11773
MinRK
add proxying tornado server in Serve post-processor
r12442 from IPython.utils.traitlets import Bool, Unicode, Int
damianavila
Added serve option as a post processor.
r11773
from .base import PostProcessorBase
#-----------------------------------------------------------------------------
# Classes
#-----------------------------------------------------------------------------
MinRK
add proxying tornado server in Serve post-processor
r12442
class ProxyHandler(web.RequestHandler):
"""handler the proxies requests from a local prefix to a CDN"""
@web.asynchronous
def get(self, prefix, url):
"""proxy a request to a CDN"""
proxy_url = "/".join([self.settings['cdn'], url])
client = self.settings['client']
client.fetch(proxy_url, callback=self.finish_get)
def finish_get(self, response):
"""finish the request"""
# copy potentially relevant headers
for header in ["Content-Type", "Cache-Control", "Date", "Last-Modified", "Expires"]:
if header in response.headers:
self.set_header(header, response.headers[header])
self.finish(response.body)
damianavila
Added serve option as a post processor.
r11773 class ServePostProcessor(PostProcessorBase):
MinRK
add proxying tornado server in Serve post-processor
r12442 """Post processor designed to serve files
Proxies reveal.js requests to a CDN if no local reveal.js is present
"""
damianavila
Added serve option as a post processor.
r11773
damianavila
Made open_in_browser configurable.
r11807 open_in_browser = Bool(True, config=True,
MinRK
add proxying tornado server in Serve post-processor
r12442 help="""Should the browser be opened automatically?"""
)
damianavila
Update reveal.js CDN to 2.5.0.
r13697 reveal_cdn = Unicode("https://cdn.jsdelivr.net/reveal.js/2.5.0", config=True,
MinRK
add proxying tornado server in Serve post-processor
r12442 help="""URL for reveal.js CDN."""
)
reveal_prefix = Unicode("reveal.js", config=True, help="URL prefix for reveal.js")
ip = Unicode("127.0.0.1", config=True, help="The IP address to listen on.")
port = Int(8000, config=True, help="port for the server to listen on.")
damianavila
Added serve option as a post processor.
r11773
Paul Ivanov
rename call methods to transform and postprocess...
r12218 def postprocess(self, input):
MinRK
add proxying tornado server in Serve post-processor
r12442 """Serve the build directory with a webserver."""
dirname, filename = os.path.split(input)
handlers = [
(r"/(.+)", web.StaticFileHandler, {'path' : dirname}),
(r"/", web.RedirectHandler, {"url": "/%s" % filename})
]
if ('://' in self.reveal_prefix or self.reveal_prefix.startswith("//")):
# reveal specifically from CDN, nothing to do
pass
elif os.path.isdir(os.path.join(dirname, self.reveal_prefix)):
# reveal prefix exists
self.log.info("Serving local %s", self.reveal_prefix)
else:
self.log.info("Redirecting %s requests to %s", self.reveal_prefix, self.reveal_cdn)
handlers.insert(0, (r"/(%s)/(.*)" % self.reveal_prefix, ProxyHandler))
app = web.Application(handlers,
cdn=self.reveal_cdn,
client=AsyncHTTPClient(),
)
# hook up tornado logging to our logger
MinRK
don't require tornado 3 in `--post serve`...
r12821 try:
from tornado import log
log.app_log = self.log
except ImportError:
# old tornado (<= 3), ignore
pass
MinRK
add proxying tornado server in Serve post-processor
r12442
http_server = httpserver.HTTPServer(app)
http_server.listen(self.port, address=self.ip)
url = "http://%s:%i/%s" % (self.ip, self.port, filename)
Thomas Kluyver
Clean up converted code....
r13386 print("Serving your slides at %s" % url)
MinRK
add proxying tornado server in Serve post-processor
r12442 print("Use Control-C to stop this server")
if self.open_in_browser:
webbrowser.open(url, new=2)
damianavila
Capturing Keyboard interrupt.
r11775 try:
MinRK
add proxying tornado server in Serve post-processor
r12442 ioloop.IOLoop.instance().start()
damianavila
Capturing Keyboard interrupt.
r11775 except KeyboardInterrupt:
MinRK
add proxying tornado server in Serve post-processor
r12442 print("\nInterrupted")
def main(path):
"""allow running this module to serve the slides"""
server = ServePostProcessor()
server(path)
if __name__ == '__main__':
import sys
main(sys.argv[1])