mirror of
https://github.com/servo/servo.git
synced 2025-06-23 08:34:42 +01:00
102 lines
3.2 KiB
Python
102 lines
3.2 KiB
Python
import json
|
|
import pytest
|
|
import types
|
|
|
|
from support.inline import inline
|
|
from support.asserts import assert_error, assert_success
|
|
|
|
alert_doc = inline("<script>window.alert()</script>")
|
|
frame_doc = inline("<p>frame")
|
|
one_frame_doc = inline("<iframe src='%s'></iframe>" % frame_doc)
|
|
two_frames_doc = inline("<iframe src='%s'></iframe>" % one_frame_doc)
|
|
|
|
|
|
# TODO(ato): 7.1 Get
|
|
|
|
|
|
def test_get_current_url_no_browsing_context(session, create_window):
|
|
# 7.2 step 1
|
|
session.window_handle = create_window()
|
|
session.close()
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert_error(result, "no such window")
|
|
|
|
|
|
def test_get_current_url_alert_prompt(session):
|
|
# 7.2 step 2
|
|
session.url = alert_doc
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert_error(result, "unexpected alert open")
|
|
|
|
def test_get_current_url_matches_location(session):
|
|
# 7.2 step 3
|
|
url = session.execute_script("return window.location.href")
|
|
assert session.url == url
|
|
|
|
def test_get_current_url_payload(session):
|
|
# 7.2 step 4-5
|
|
session.start()
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert result.status == 200
|
|
assert isinstance(result.body["value"], basestring)
|
|
|
|
def test_get_current_url_special_pages(session):
|
|
session.url = "about:blank"
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert_success(result, "about:blank")
|
|
|
|
# TODO(ato): This test requires modification to pass on Windows
|
|
def test_get_current_url_file_protocol(session):
|
|
# tests that the browsing context remains the same
|
|
# when navigated privileged documents
|
|
session.url = "file:///"
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert_success(result, "file:///")
|
|
|
|
# TODO(ato): Test for http:// and https:// protocols.
|
|
# We need to expose a fixture for accessing
|
|
# documents served by wptserve in order to test this.
|
|
|
|
def test_set_malformed_url(session):
|
|
result = session.transport.send("POST",
|
|
"session/%s/url" % session.session_id,
|
|
{"url": "foo"})
|
|
|
|
assert_error(result, "invalid argument")
|
|
|
|
def test_get_current_url_after_modified_location(session):
|
|
session.execute_script("window.location.href = 'about:blank#wd_test_modification'")
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert_success(result, "about:blank#wd_test_modification")
|
|
|
|
def test_get_current_url_nested_browsing_context(session, create_frame):
|
|
session.url = "about:blank#wd_from_within_frame"
|
|
session.switch_frame(create_frame())
|
|
|
|
result = session.transport.send("GET", "session/%s/url" % session.session_id)
|
|
|
|
assert_success(result, "about:blank#wd_from_within_frame")
|
|
|
|
def test_get_current_url_nested_browsing_contexts(session):
|
|
session.url = two_frames_doc
|
|
top_level_url = session.url
|
|
|
|
outer_frame = session.find.css("iframe", all=False)
|
|
session.switch_frame(outer_frame)
|
|
|
|
inner_frame = session.find.css("iframe", all=False)
|
|
session.switch_frame(inner_frame)
|
|
|
|
assert session.url == top_level_url
|