本文整理汇总了Python中marionette_driver.wait.Wait.until方法的典型用法代码示例。如果您正苦于以下问题:Python Wait.until方法的具体用法?Python Wait.until怎么用?Python Wait.until使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类marionette_driver.wait.Wait
的用法示例。
在下文中一共展示了Wait.until方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: hold_active_call
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def hold_active_call(self, user_initiate_hold=True):
self.marionette.execute_async_script("""
let active = window.wrappedJSObject.active_call;
var user_initiate_hold = arguments[0];
window.wrappedJSObject.received_statechange = false;
active.onstatechange = function onstatechange(event) {
console.log("Received TelephonyCall 'onstatechange' event.");
if (event.call.state == "held") {
window.wrappedJSObject.received_statechange = true;
};
};
window.wrappedJSObject.onheld_call_ok = false;
active.onheld = function ondisconnected(event) {
console.log("Received 'onheld' call event.");
if (event.call.state == "held") {
window.wrappedJSObject.onheld_call_ok = true;
};
};
if (user_initiate_hold) {
active.hold();
}
marionetteScriptFinished(1);
""", script_args=[user_initiate_hold])
if user_initiate_hold == True:
# should have received both events associated with a call on hold
wait = Wait(self.marionette, timeout=90, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.onheld_call_ok"))
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.received_statechange"))
except:
# failed to hold
self.fail("Failed to put call on hold initiated by user")
示例2: test_telephony_outgoing_busy
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def test_telephony_outgoing_busy(self):
self.instruct("Make a call to second non firefox OS phone from third non firefox "
"OS phone, answer the call on second phone and press OK")
# keep a short delay before making an outgoing call to second phone
time.sleep(2)
# use the webapi to make an outgoing call to user-specified number
self.user_guided_outgoing_call()
# verify one outgoing call
self.calls = self.marionette.execute_script("return window.wrappedJSObject.get_returnable_calls()")
self.assertEqual(self.calls['length'], 1, "There should be 1 call")
self.assertEqual(self.calls['0'], self.outgoing_call)
# should have received busy event associated with an outgoing call
wait = Wait(self.marionette, timeout=30, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.received_busy"))
except:
self.fail("Busy event is not found, but should have been, since the outgoing call "
"is initiated to busy line")
# keep call ringing for a while
time.sleep(1)
# disconnect the outgoing call
self.hangup_call(call_type="Outgoing")
self.calls = self.marionette.execute_script("return window.wrappedJSObject.get_returnable_calls()")
self.assertEqual(self.calls['length'], 0, "There should be 0 calls")
示例3: wait_for_antenna_change
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def wait_for_antenna_change(self):
# wait for radio to change state
wait = Wait(self.marionette, timeout=10, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.antenna_change"))
except:
self.fail("Failed to receive mozFMRadio.onantennaavailablechange event")
示例4: set_bt_enabled
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def set_bt_enabled(self, enable):
self.get_default_bt_adapter()
if enable:
self.marionette.execute_async_script("""
window.wrappedJSObject.bt_adapter.enable();
marionetteScriptFinished(1);
""")
else:
self.marionette.execute_async_script("""
window.wrappedJSObject.bt_adapter.disable();
marionetteScriptFinished(1);
""")
# wait for enabled/disabled event
wait = Wait(self.marionette, timeout=30, interval=0.5)
try:
if enable:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.bt_adapter.state == 'enabled';"))
else:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.bt_adapter.state == 'disabled';"))
except:
if enable:
self.fail("Failed to enable bluetooth")
else:
self.fail("Failed to disable bluetooth")
示例5: assert_message_sent
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def assert_message_sent(self):
"""
After sending an SMS/MMS, call this method to wait for the message to be sent.
Verify that a mobile message was sent by checking if the expected events were triggered.
Once verified, set the out_msg attribute to point to the message that has been sent.
"""
wait = Wait(self.marionette, timeout=90, interval=0.5)
try:
wait.until(lambda m: self.marionette.execute_script("return window.wrappedJSObject.rcvd_req_success"))
except errors.TimeoutException:
# msg wasn't sent; either the api is broken or mobile network signal is insufficient
self.fail(
"Failed to send message. The API is broken -or- "
"perhaps there is no mobile network signal. Please try again"
)
# verify the remaining msg send events
rcvd_failed = self.marionette.execute_script("return window.wrappedJSObject.rcvd_on_failed")
self.assertFalse(rcvd_failed, "Failed to send message; received mozMobileMessage.onfailed event")
rcvd_sending = self.marionette.execute_script("return window.wrappedJSObject.rcvd_on_sending")
self.assertTrue(rcvd_sending, "Failed to send message; mozMobileMessage.onsending event not received")
rcvd_sent = self.marionette.execute_script("return window.wrappedJSObject.rcvd_on_sent")
self.assertTrue(rcvd_sent, "Failed to send message; mozMobileMessage.onsent event not received")
# get message event
self.out_msg = self.marionette.execute_script("return window.wrappedJSObject.out_msg")
示例6: set_geolocation_enabled
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def set_geolocation_enabled(self, enable):
# turn on geolocation via the device settings
self.marionette.execute_async_script("""
var enable = arguments[0];
window.wrappedJSObject.rcvd_success = false;
window.wrappedJSObject.rcvd_error = false;
if (enable) {
console.log("Enabling geolocation via settings");
} else {
console.log("Disabling geolocation via settings");
}
var lock = window.navigator.mozSettings.createLock();
var result = lock.set({
'geolocation.enabled': enable
});
result.onsuccess = function() {
console.log("Success changing geolocation.enabled setting");
window.wrappedJSObject.rcvd_success = true;
};
result.onerror = function(error) {
console.log("Failed to change geolocation.enabled setting " + error);
window.wrappedJSObject.rcvd_error = true;
};
marionetteScriptFinished(1);
""", script_args=[enable])
# wait for enabled/disabled event
wait = Wait(self.marionette, timeout=30, interval=0.5)
try:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.rcvd_success"))
except:
if self.marionette.execute_script("return window.wrappedJSObject.rcvd_error;"):
self.fail("Error received while changing the geolocation enabled setting")
else:
self.fail("Failed to change the geolocation.enabled setting")
示例7: test_active_state
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def test_active_state(self):
self.instruct("About to test active state. Please click OK and then watch the screen")
self.marionette.execute_script("""
window.wrappedJSObject.testActiveObserver = {
time : 5,
onidle : function() {
window.navigator.mozPower.screenBrightness = 0.1;
window.wrappedJSObject.rcvd_idle = true;
},
onactive : function() {
window.navigator.mozPower.screenBrightness = 0.5;
window.wrappedJSObject.rcvd_active = true;
}
};
navigator.addIdleObserver(window.wrappedJSObject.testActiveObserver);
""")
wait = Wait(self.marionette, timeout=10, interval=0.5)
try:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.rcvd_idle;"))
except:
self.fail("Failed to attain idle state")
self.confirm("Did you notice decrease in brightness?")
self.instruct("Touch on the screen to wake up the device")
wait = Wait(self.marionette, timeout=10, interval=0.5)
try:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.rcvd_active;"))
except:
self.fail("Failed to attain active state")
self.confirm("Did you notice increase in brightness?")
示例8: set_bt_discoverable_mode
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def set_bt_discoverable_mode(self, set_discoverable):
self.set_bt_enabled(True)
if set_discoverable:
self.marionette.execute_async_script("""
window.wrappedJSObject.bt_adapter.setDiscoverable(true);
marionetteScriptFinished(1);
""")
else:
self.marionette.execute_async_script("""
window.wrappedJSObject.bt_adapter.disable(false);
marionetteScriptFinished(1);
""")
# wait for enabled/disabled event
wait = Wait(self.marionette, timeout=30, interval=0.5)
try:
if set_discoverable:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.bt_adapter.discoverable == true;"))
else:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.bt_adapter.discoverable == false;"))
except:
if set_discoverable:
self.fail("Failed to enable bluetooth discoverable")
else:
self.fail("Failed to disable bluetooth discoverable")
示例9: resume_held_call
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def resume_held_call(self):
self.marionette.execute_async_script("""
let active = window.wrappedJSObject.active_call;
window.wrappedJSObject.received_statechange = false;
active.onstatechange = function onstatechange(event) {
console.log("Received TelephonyCall 'onstatechange' event.");
if (event.call.state == "resuming") {
window.wrappedJSObject.received_statechange = true;
};
};
window.wrappedJSObject.onresuming_call_ok = false;
active.onresuming = function onresuming(event) {
console.log("Received 'onresuming' call event.");
if (event.call.state == "resuming") {
window.wrappedJSObject.onresuming_call_ok = true;
};
};
active.resume();
marionetteScriptFinished(1);
""")
# should have received event associated with a resumed call
wait = Wait(self.marionette, timeout=90, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.onresuming_call_ok"))
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.received_statechange"))
except:
# failed to resume
self.fail("Failed to resume the held call")
示例10: set_wifi_enabled
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def set_wifi_enabled(self, enable):
self.marionette.execute_async_script("""
var enable = arguments[0];
window.wrappedJSObject.rcvd_enabled_event = false;
window.wrappedJSObject.rcvd_disabled_event = false;
window.wrappedJSObject.rcvd_error = false;
var mozWifi = window.navigator.mozWifiManager;
mozWifi.onenabled = function() {
console.log("Received mozWifiManager.onenabled event");
window.wrappedJSObject.rcvd_enabled_event = true;
};
mozWifi.ondisabled = function() {
console.log("Received mozWifiManager.ondisabled event");
window.wrappedJSObject.rcvd_disabled_event = true;
};
if (enable) {
console.log("Turning on Wifi via settings");
} else {
console.log("Turning off Wifi via settings");
}
var lock = window.navigator.mozSettings.createLock();
var result = lock.set({
'wifi.enabled': enable
});
result.onerror = function() {
if (enable) {
console.log("Failed to changed Wifi setting to ON");
} else {
console.log("Failed to changed Wifi setting to OFF");
}
window.wrappedJSObject.rcvd_error = true;
};
marionetteScriptFinished(1);
""", script_args=[enable])
# wait for enabled/disabled event
wait = Wait(self.marionette, timeout=30, interval=0.5)
try:
if enable:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.rcvd_enabled_event;"))
else:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.rcvd_disabled_event;"))
except:
if self.marionette.execute_script("return window.wrappedJSObject.rcvd_error;"):
self.fail("Error received while changing the wifi enabled setting")
else:
if enable:
self.fail("Failed to enable wifi via mozSettings")
else:
self.fail("Failed to disable wifi via mozSettings")
示例11: answer_call
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def answer_call(self, incoming=True):
# answer incoming call via the webapi; have user answer outgoing call on target
self.marionette.execute_async_script("""
let incoming = arguments[0];
if (incoming) {
var call_to_answer = window.wrappedJSObject.incoming_call;
} else {
var call_to_answer = window.wrappedJSObject.outgoing_call;
};
window.wrappedJSObject.received_statechange = false;
call_to_answer.onstatechange = function onstatechange(event) {
console.log("Received TelephonyCall 'onstatechange' event.");
if (event.call.state == "connected") {
window.wrappedJSObject.received_statechange = true;
};
};
window.wrappedJSObject.connected_call_ok = false;
call_to_answer.onconnected = function onconnected(event) {
console.log("Received 'onconnected' call event.");
if (event.call.state == "connected") {
window.wrappedJSObject.active_call = window.navigator.mozTelephony.active;
window.wrappedJSObject.returnable_active_call = {
state: window.navigator.mozTelephony.active.state,
number: window.navigator.mozTelephony.active.number
};
window.wrappedJSObject.connected_call_ok = true;
};
};
// answer incoming call via webapi; outgoing will be by user interaction
if (incoming) {
call_to_answer.answer();
};
marionetteScriptFinished(1);
""", script_args=[incoming])
# answer outgoing call via user answering on target
if not incoming:
self.instruct("Please answer the call on the target phone, then click 'OK'")
# should have received both events associated with answering a call
wait = Wait(self.marionette, timeout=90, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.connected_call_ok"))
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.received_statechange"))
except:
self.fail("Failed to answer call")
# append new call to the active call list
self.active_call_list.append(self.marionette.execute_script("return window.wrappedJSObject.returnable_active_call"))
示例12: bt_discovery
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def bt_discovery(self, set_discovering):
self.set_bt_enabled(True)
if set_discovering:
self.marionette.execute_async_script("""
window.wrappedJSObject.found_device_count = 0;
var discoveryHandle;
window.wrappedJSObject.bt_adapter.startDiscovery().then ( function onResolve(handle) {
console.log("Resolved with discoveryHandle");
// Keep reference to handle in order to listen to ondevicefound event handler
discoveryHandle = handle;
discoveryHandle.ondevicefound = function onDeviceFound(evt) {
var device = evt.device;
console.log("Discovered remote device. Address:", device.address);
window.wrappedJSObject.found_device_count++;
};
}, function onReject(aReason) {
console.log("Rejected with this reason: " + aReason);
});
marionetteScriptFinished(1);
""")
else:
self.marionette.execute_async_script("""
window.wrappedJSObject.bt_adapter.stopDiscovery().then ( function onResolve() {
console.log("Resolved with void value");
}, function onReject(aReason) {
console.log("Rejected with this reason: " + aReason);
});
marionetteScriptFinished(1);
""")
# wait for request success
wait = Wait(self.marionette, timeout=30, interval=0.5)
try:
if set_discovering:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.bt_adapter.discovering == true;"))
else:
wait.until(lambda m: m.execute_script("return window.wrappedJSObject.bt_adapter.discovering == false;"))
except:
if set_discovering:
self.fail("Failed to enable bluetooth discovering")
else:
self.fail("Failed to disable bluetooth discovering")
示例13: setup_incoming_call
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def setup_incoming_call(self):
self.marionette.execute_script(self.returnable_calls)
# listen for and answer incoming call
self.marionette.execute_async_script("""
var telephony = window.navigator.mozTelephony;
window.wrappedJSObject.received_incoming = false;
telephony.onincoming = function onincoming(event) {
console.log("Received 'incoming' call event.");
window.wrappedJSObject.received_incoming = true;
window.wrappedJSObject.incoming_call = event.call;
window.wrappedJSObject.returnable_incoming_call = {
number: event.call.number,
state: event.call.state
};
window.wrappedJSObject.calls = telephony.calls;
};
window.wrappedJSObject.received_callschanged = false;
telephony.oncallschanged = function oncallschanged(event) {
console.log("Received Telephony 'oncallschanged' event.");
window.wrappedJSObject.received_callschanged = true;
};
window.wrappedJSObject.received_ready = false;
telephony.ready.then(
function() {
console.log("Telephony got ready");
window.wrappedJSObject.received_ready = true;
},
function() {
console.log("Telephony not ready");
window.wrappedJSObject.received_ready = false;
}
);
marionetteScriptFinished(1);
""")
wait = Wait(self.marionette, timeout=90, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.received_ready"))
except:
self.fail("Telephony.oncallschanged event not found, but should have been "
"since initiated incoming call to firefox OS device")
示例14: mark_message_status
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def mark_message_status(self, msg_id, is_read=False):
self.marionette.execute_async_script(
"""
var msg_id = arguments[0];
var is_read = arguments[1];
var requestRet = null;
var mm = window.navigator.mozMobileMessage;
// Bug 952875
mm.getThreads();
requestRet = mm.markMessageRead(msg_id, is_read);
window.wrappedJSObject.rcvd_req_success_read = false;
window.wrappedJSObject.rcvd_req_success_unread = false;
requestRet.onsuccess = function(event) {
log("Received 'onsuccess' event.");
if (event.target.result) {
window.wrappedJSObject.rcvd_req_success_read = true;
} else {
window.wrappedJSObject.rcvd_req_success_unread = true;
log("request returned false for manager.markMessageRead");
}
}
requestRet.onerror = function() {
log("Failed to mark message read status, received error: %s" % requestRet.error.name);
};
marionetteScriptFinished(1);
""",
script_args=[msg_id, is_read],
)
wait = Wait(self.marionette, timeout=15, interval=0.5)
try:
if is_read is True:
wait.until(
lambda m: self.marionette.execute_script("return window.wrappedJSObject.rcvd_req_success_read")
)
else:
wait.until(
lambda m: self.marionette.execute_script("return window.wrappedJSObject.rcvd_req_success_unread")
)
except errors.TimeoutException:
# msg read status wasn't marked
self.fail("Failed to update the read status of message.")
示例15: change_radio_state
# 需要导入模块: from marionette_driver.wait import Wait [as 别名]
# 或者: from marionette_driver.wait.Wait import until [as 别名]
def change_radio_state(self, turning_on):
# turn on or off radio and verify request
self.marionette.execute_async_script("""
var turning_on = arguments[0];
var fm = window.navigator.mozFMRadio;
window.wrappedJSObject.rcvd_success = false;
window.wrappedJSObject.rcvd_error = false;
// turn on or off accordingly
if (turning_on) {
var request = fm.enable(99.9);
} else {
var request = fm.disable();
};
// verify request
request.onsuccess = function() {
window.wrappedJSObject.rcvd_success = true;
};
request.onerror = function() {
window.wrappedJSObject.rcvd_error = true;
};
marionetteScriptFinished(1);
""", script_args=[turning_on])
# wait for radio to change state
wait = Wait(self.marionette, timeout=10, interval=0.5)
try:
wait.until(lambda x: x.execute_script("return window.wrappedJSObject.rcvd_success"))
except:
if self.marionette.execute_script("return window.wrappedJSObject.rcvd_error"):
if turning_on:
self.fail("MozFMRadio.enable returned error")
else:
self.fail("MozFMRadio.disable returned error")
else:
if turning_on:
self.fail("Failed to turn on the fm radio")
else:
self.fail("Failed to turn off the fm radio")