blob: e7f1b0c8053db0fedbb37c0a1b528a259591813f [file] [log] [blame]
import pytest
from tests.support.asserts import assert_success
from tests.support.image import png_dimensions
from . import element_dimensions
DEFAULT_CONTENT = "<div id='content'>Lorem ipsum dolor sit amet.</div>"
REFERENCE_CONTENT = "<div id='outer'>{}</div>".format(DEFAULT_CONTENT)
REFERENCE_STYLE = """
<style>
#outer {
display: block;
margin: 0;
border: 0;
width: 200px;
height: 200px;
}
#content {
display: block;
margin: 0;
border: 0;
width: 100px;
height: 100px;
background: green;
}
</style>
"""
OUTER_IFRAME_STYLE = """
<style>
iframe {
display: block;
margin: 0;
border: 0;
width: 200px;
height: 200px;
}
</style>
"""
INNER_IFRAME_STYLE = """
<style>
body {
margin: 0;
}
div {
display: block;
margin: 0;
border: 0;
width: 100px;
height: 100px;
background: green;
}
</style>
"""
def take_element_screenshot(session, element_id):
return session.transport.send(
"GET",
"session/{session_id}/element/{element_id}/screenshot".format(
session_id=session.session_id,
element_id=element_id,
)
)
def test_frame_element(session, inline, iframe):
# Create a reference element which looks exactly like the frame's content
session.url = inline("{0}{1}".format(REFERENCE_STYLE, REFERENCE_CONTENT))
# Capture the inner content as reference image
ref_el = session.find.css("#content", all=False)
ref_screenshot = ref_el.screenshot()
ref_dimensions = element_dimensions(session, ref_el)
assert png_dimensions(ref_screenshot) == ref_dimensions
# Capture the frame's element
iframe_content = "{0}{1}".format(INNER_IFRAME_STYLE, DEFAULT_CONTENT)
session.url = inline("""{0}{1}""".format(OUTER_IFRAME_STYLE, iframe(iframe_content)))
frame = session.find.css("iframe", all=False)
session.switch_frame(frame)
div = session.find.css("div", all=False)
div_dimensions = element_dimensions(session, div)
assert div_dimensions == ref_dimensions
response = take_element_screenshot(session, div.id)
div_screenshot = assert_success(response)
assert png_dimensions(div_screenshot) == ref_dimensions
assert div_screenshot == ref_screenshot
@pytest.mark.parametrize("domain", ["", "alt"], ids=["same_origin", "cross_origin"])
def test_source_origin(session, inline, iframe, domain):
# Create a reference element which looks exactly like the iframe
session.url = inline("{0}{1}".format(REFERENCE_STYLE, REFERENCE_CONTENT))
div = session.find.css("div", all=False)
div_dimensions = element_dimensions(session, div)
response = take_element_screenshot(session, div.id)
reference_screenshot = assert_success(response)
assert png_dimensions(reference_screenshot) == div_dimensions
iframe_content = "{0}{1}".format(INNER_IFRAME_STYLE, DEFAULT_CONTENT)
session.url = inline("""{0}{1}""".format(
OUTER_IFRAME_STYLE, iframe(iframe_content, domain=domain)))
frame_element = session.find.css("iframe", all=False)
frame_dimensions = element_dimensions(session, frame_element)
response = take_element_screenshot(session, frame_element.id)
screenshot = assert_success(response)
assert png_dimensions(screenshot) == frame_dimensions
assert screenshot == reference_screenshot