# Copyright (c) IPython Development Team. # Distributed under the terms of the Modified BSD License. import json import os import warnings from unittest import mock import pytest from IPython import display from IPython.core.getipython import get_ipython from IPython.utils.io import capture_output from IPython.utils.tempdir import NamedFileInTemporaryDirectory from IPython import paths as ipath from IPython.testing.tools import AssertNotPrints import IPython.testing.decorators as dec def test_image_size(): """Simple test for display.Image(args, width=x,height=y)""" thisurl = "http://www.google.fr/images/srpr/logo3w.png" img = display.Image(url=thisurl, width=200, height=200) assert '' % (thisurl) == img._repr_html_() img = display.Image(url=thisurl, metadata={"width": 200, "height": 200}) assert '' % (thisurl) == img._repr_html_() img = display.Image(url=thisurl, width=200) assert '' % (thisurl) == img._repr_html_() img = display.Image(url=thisurl) assert '' % (thisurl) == img._repr_html_() img = display.Image(url=thisurl, unconfined=True) assert '' % (thisurl) == img._repr_html_() def test_image_mimes(): fmt = get_ipython().display_formatter.format for format in display.Image._ACCEPTABLE_EMBEDDINGS: mime = display.Image._MIMETYPES[format] img = display.Image(b"garbage", format=format) data, metadata = fmt(img) assert sorted(data) == sorted([mime, "text/plain"]) def test_geojson(): gj = display.GeoJSON( data={ "type": "Feature", "geometry": {"type": "Point", "coordinates": [-81.327, 296.038]}, "properties": {"name": "Inca City"}, }, url_template="http://s3-eu-west-1.amazonaws.com/whereonmars.cartodb.net/{basemap_id}/{z}/{x}/{y}.png", layer_options={ "basemap_id": "celestia_mars-shaded-16k_global", "attribution": "Celestia/praesepe", "minZoom": 0, "maxZoom": 18, }, ) assert "" == str(gj) def test_retina_png(): here = os.path.dirname(__file__) img = display.Image(os.path.join(here, "2x2.png"), retina=True) assert img.height == 1 assert img.width == 1 data, md = img._repr_png_() assert md["width"] == 1 assert md["height"] == 1 def test_embed_svg_url(): import gzip from io import BytesIO svg_data = b'' url = "http://test.com/circle.svg" gzip_svg = BytesIO() with gzip.open(gzip_svg, "wb") as fp: fp.write(svg_data) gzip_svg = gzip_svg.getvalue() def mocked_urlopen(*args, **kwargs): class MockResponse: def __init__(self, svg): self._svg_data = svg self.headers = {"content-type": "image/svg+xml"} def read(self): return self._svg_data if args[0] == url: return MockResponse(svg_data) elif args[0] == url + "z": ret = MockResponse(gzip_svg) ret.headers["content-encoding"] = "gzip" return ret return MockResponse(None) with mock.patch("urllib.request.urlopen", side_effect=mocked_urlopen): svg = display.SVG(url=url) assert svg._repr_svg_().startswith("" assert p.data == "This is a simple test" p._show_mem_addr = True assert repr(p) == object.__repr__(p) def test_displayobject_repr(): h = display.HTML("
") assert repr(h) == "" h._show_mem_addr = True assert repr(h) == object.__repr__(h) h._show_mem_addr = False assert repr(h) == "" j = display.Javascript("") assert repr(j) == "" j._show_mem_addr = True assert repr(j) == object.__repr__(j) j._show_mem_addr = False assert repr(j) == "" @mock.patch("warnings.warn") def test_encourage_iframe_over_html(m_warn): display.HTML() m_warn.assert_not_called() display.HTML("
") m_warn.assert_not_called() display.HTML( '

Lots of content here

' ) m_warn.assert_not_called() display.HTML('') m_warn.assert_called_with("Consider using IPython.display.IFrame instead") m_warn.reset_mock() display.HTML('') m_warn.assert_called_with("Consider using IPython.display.IFrame instead") def test_progress(): p = display.ProgressBar(10) assert "0/10" in repr(p) p.html_width = "100%" p.progress = 5 assert ( p._repr_html_() == "" ) def test_progress_iter(): with capture_output(display=False) as captured: for i in display.ProgressBar(5): out = captured.stdout assert "{0}/5".format(i) in out out = captured.stdout assert "5/5" in out def test_json(): d = {"a": 5} lis = [d] metadata = [ {"expanded": False, "root": "root"}, {"expanded": True, "root": "root"}, {"expanded": False, "root": "custom"}, {"expanded": True, "root": "custom"}, ] json_objs = [ display.JSON(d), display.JSON(d, expanded=True), display.JSON(d, root="custom"), display.JSON(d, expanded=True, root="custom"), ] for j, md in zip(json_objs, metadata): assert j._repr_json_() == (d, md) with warnings.catch_warnings(record=True) as w: warnings.simplefilter("always") j = display.JSON(json.dumps(d)) assert len(w) == 1 assert j._repr_json_() == (d, metadata[0]) json_objs = [ display.JSON(lis), display.JSON(lis, expanded=True), display.JSON(lis, root="custom"), display.JSON(lis, expanded=True, root="custom"), ] for j, md in zip(json_objs, metadata): assert j._repr_json_() == (lis, md) with warnings.catch_warnings(record=True) as w: warnings.simplefilter("always") j = display.JSON(json.dumps(lis)) assert len(w) == 1 assert j._repr_json_() == (lis, metadata[0]) def test_video_embedding(): """use a tempfile, with dummy-data, to ensure that video embedding doesn't crash""" v = display.Video("http://ignored") assert not v.embed html = v._repr_html_() assert 'src="data:' not in html assert 'src="http://ignored"' in html with pytest.raises(ValueError): v = display.Video(b"abc") with NamedFileInTemporaryDirectory("test.mp4", "wb") as f: f.write(b"abc") f.close() v = display.Video(f.name) assert not v.embed html = v._repr_html_() assert 'src="data:' not in html v = display.Video(f.name, embed=True) html = v._repr_html_() assert 'src="data:video/mp4;base64,YWJj"' in html v = display.Video(f.name, embed=True, mimetype="video/other") html = v._repr_html_() assert 'src="data:video/other;base64,YWJj"' in html v = display.Video(b"abc", embed=True, mimetype="video/mp4") html = v._repr_html_() assert 'src="data:video/mp4;base64,YWJj"' in html v = display.Video("YWJj", embed=True, mimetype="video/xyz") html = v._repr_html_() assert 'src="data:video/xyz;base64,YWJj"' in html def test_html_metadata(): s = "

Test

" h = display.HTML(s, metadata={"isolated": True}) assert h._repr_html_() == (s, {"isolated": True}) def test_display_id(): ip = get_ipython() with mock.patch.object(ip.display_pub, "publish") as pub: handle = display.display("x") assert handle is None handle = display.display("y", display_id="secret") assert isinstance(handle, display.DisplayHandle) handle2 = display.display("z", display_id=True) assert isinstance(handle2, display.DisplayHandle) assert handle.display_id != handle2.display_id assert pub.call_count == 3 args, kwargs = pub.call_args_list[0] assert args == () assert kwargs == { "data": {"text/plain": repr("x")}, "metadata": {}, } args, kwargs = pub.call_args_list[1] assert args == () assert kwargs == { "data": {"text/plain": repr("y")}, "metadata": {}, "transient": { "display_id": handle.display_id, }, } args, kwargs = pub.call_args_list[2] assert args == () assert kwargs == { "data": {"text/plain": repr("z")}, "metadata": {}, "transient": { "display_id": handle2.display_id, }, } def test_update_display(): ip = get_ipython() with mock.patch.object(ip.display_pub, "publish") as pub: with pytest.raises(TypeError): display.update_display("x") display.update_display("x", display_id="1") display.update_display("y", display_id="2") args, kwargs = pub.call_args_list[0] assert args == () assert kwargs == { "data": {"text/plain": repr("x")}, "metadata": {}, "transient": { "display_id": "1", }, "update": True, } args, kwargs = pub.call_args_list[1] assert args == () assert kwargs == { "data": {"text/plain": repr("y")}, "metadata": {}, "transient": { "display_id": "2", }, "update": True, } def test_display_handle(): ip = get_ipython() handle = display.DisplayHandle() assert isinstance(handle.display_id, str) handle = display.DisplayHandle("my-id") assert handle.display_id == "my-id" with mock.patch.object(ip.display_pub, "publish") as pub: handle.display("x") handle.update("y") args, kwargs = pub.call_args_list[0] assert args == () assert kwargs == { "data": {"text/plain": repr("x")}, "metadata": {}, "transient": { "display_id": handle.display_id, }, } args, kwargs = pub.call_args_list[1] assert args == () assert kwargs == { "data": {"text/plain": repr("y")}, "metadata": {}, "transient": { "display_id": handle.display_id, }, "update": True, } def test_image_alt_tag(): """Simple test for display.Image(args, alt=x,)""" thisurl = "http://example.com/image.png" img = display.Image(url=thisurl, alt="an image") assert 'an image' % (thisurl) == img._repr_html_() img = display.Image(url=thisurl, unconfined=True, alt="an image") assert ( 'an image' % (thisurl) == img._repr_html_() ) img = display.Image(url=thisurl, alt='>"& <') assert '>"& <' % (thisurl) == img._repr_html_() img = display.Image(url=thisurl, metadata={"alt": "an image"}) assert img.alt == "an image" here = os.path.dirname(__file__) img = display.Image(os.path.join(here, "2x2.png"), alt="an image") assert img.alt == "an image" _, md = img._repr_png_() assert md["alt"] == "an image" def test_image_bad_filename_raises_proper_exception(): with pytest.raises(FileNotFoundError): display.Image("/this/file/does/not/exist/")._repr_png_()