--- /dev/null
+<!DOCTYPE html><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no"><meta http-equiv="Content-Language" content="en"><meta http-equiv="X-UA-Compatible" content="IE=edge"><title>util.js</title><link href="../../dossier.css" rel="stylesheet" type="text/css"><header><div><form><div><input type="search" placeholder="Search"></div></form></div></header><main><article class="srcfile"><h1>http/util.js</h1><div><table><tr><td><a id="l1"></a><a href="#l1">1</a><td>// Copyright 2013 Selenium committers<tr><td><a id="l2"></a><a href="#l2">2</a><td>// Copyright 2013 Software Freedom Conservancy<tr><td><a id="l3"></a><a href="#l3">3</a><td>//<tr><td><a id="l4"></a><a href="#l4">4</a><td>// Licensed under the Apache License, Version 2.0 (the "License");<tr><td><a id="l5"></a><a href="#l5">5</a><td>// you may not use this file except in compliance with the License.<tr><td><a id="l6"></a><a href="#l6">6</a><td>// You may obtain a copy of the License at<tr><td><a id="l7"></a><a href="#l7">7</a><td>//<tr><td><a id="l8"></a><a href="#l8">8</a><td>// http://www.apache.org/licenses/LICENSE-2.0<tr><td><a id="l9"></a><a href="#l9">9</a><td>//<tr><td><a id="l10"></a><a href="#l10">10</a><td>// Unless required by applicable law or agreed to in writing, software<tr><td><a id="l11"></a><a href="#l11">11</a><td>// distributed under the License is distributed on an "AS IS" BASIS,<tr><td><a id="l12"></a><a href="#l12">12</a><td>// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.<tr><td><a id="l13"></a><a href="#l13">13</a><td>// See the License for the specific language governing permissions and<tr><td><a id="l14"></a><a href="#l14">14</a><td>// limitations under the License.<tr><td><a id="l15"></a><a href="#l15">15</a><td><tr><td><a id="l16"></a><a href="#l16">16</a><td>/**<tr><td><a id="l17"></a><a href="#l17">17</a><td> * @fileoverview Various HTTP utilities.<tr><td><a id="l18"></a><a href="#l18">18</a><td> */<tr><td><a id="l19"></a><a href="#l19">19</a><td><tr><td><a id="l20"></a><a href="#l20">20</a><td>var base = require('../_base'),<tr><td><a id="l21"></a><a href="#l21">21</a><td> HttpClient = require('./index').HttpClient,<tr><td><a id="l22"></a><a href="#l22">22</a><td> checkResponse = base.require('bot.response').checkResponse,<tr><td><a id="l23"></a><a href="#l23">23</a><td> Executor = base.require('webdriver.http.Executor'),<tr><td><a id="l24"></a><a href="#l24">24</a><td> HttpRequest = base.require('webdriver.http.Request'),<tr><td><a id="l25"></a><a href="#l25">25</a><td> Command = base.require('webdriver.Command'),<tr><td><a id="l26"></a><a href="#l26">26</a><td> CommandName = base.require('webdriver.CommandName'),<tr><td><a id="l27"></a><a href="#l27">27</a><td> promise = base.require('webdriver.promise');<tr><td><a id="l28"></a><a href="#l28">28</a><td><tr><td><a id="l29"></a><a href="#l29">29</a><td><tr><td><a id="l30"></a><a href="#l30">30</a><td><tr><td><a id="l31"></a><a href="#l31">31</a><td>/**<tr><td><a id="l32"></a><a href="#l32">32</a><td> * Queries a WebDriver server for its current status.<tr><td><a id="l33"></a><a href="#l33">33</a><td> * @param {string} url Base URL of the server to query.<tr><td><a id="l34"></a><a href="#l34">34</a><td> * @param {function(Error, *=)} callback The function to call with the<tr><td><a id="l35"></a><a href="#l35">35</a><td> * response.<tr><td><a id="l36"></a><a href="#l36">36</a><td> */<tr><td><a id="l37"></a><a href="#l37">37</a><td>function getStatus(url, callback) {<tr><td><a id="l38"></a><a href="#l38">38</a><td> var client = new HttpClient(url);<tr><td><a id="l39"></a><a href="#l39">39</a><td> var executor = new Executor(client);<tr><td><a id="l40"></a><a href="#l40">40</a><td> var command = new Command(CommandName.GET_SERVER_STATUS);<tr><td><a id="l41"></a><a href="#l41">41</a><td> executor.execute(command, function(err, responseObj) {<tr><td><a id="l42"></a><a href="#l42">42</a><td> if (err) return callback(err);<tr><td><a id="l43"></a><a href="#l43">43</a><td> try {<tr><td><a id="l44"></a><a href="#l44">44</a><td> checkResponse(responseObj);<tr><td><a id="l45"></a><a href="#l45">45</a><td> } catch (ex) {<tr><td><a id="l46"></a><a href="#l46">46</a><td> return callback(ex);<tr><td><a id="l47"></a><a href="#l47">47</a><td> }<tr><td><a id="l48"></a><a href="#l48">48</a><td> callback(null, responseObj['value']);<tr><td><a id="l49"></a><a href="#l49">49</a><td> });<tr><td><a id="l50"></a><a href="#l50">50</a><td>}<tr><td><a id="l51"></a><a href="#l51">51</a><td><tr><td><a id="l52"></a><a href="#l52">52</a><td><tr><td><a id="l53"></a><a href="#l53">53</a><td>// PUBLIC API<tr><td><a id="l54"></a><a href="#l54">54</a><td><tr><td><a id="l55"></a><a href="#l55">55</a><td><tr><td><a id="l56"></a><a href="#l56">56</a><td>/**<tr><td><a id="l57"></a><a href="#l57">57</a><td> * Queries a WebDriver server for its current status.<tr><td><a id="l58"></a><a href="#l58">58</a><td> * @param {string} url Base URL of the server to query.<tr><td><a id="l59"></a><a href="#l59">59</a><td> * @return {!webdriver.promise.Promise.<!Object>} A promise that resolves with<tr><td><a id="l60"></a><a href="#l60">60</a><td> * a hash of the server status.<tr><td><a id="l61"></a><a href="#l61">61</a><td> */<tr><td><a id="l62"></a><a href="#l62">62</a><td>exports.getStatus = function(url) {<tr><td><a id="l63"></a><a href="#l63">63</a><td> return promise.checkedNodeCall(getStatus.bind(null, url));<tr><td><a id="l64"></a><a href="#l64">64</a><td>};<tr><td><a id="l65"></a><a href="#l65">65</a><td><tr><td><a id="l66"></a><a href="#l66">66</a><td><tr><td><a id="l67"></a><a href="#l67">67</a><td>/**<tr><td><a id="l68"></a><a href="#l68">68</a><td> * Waits for a WebDriver server to be healthy and accepting requests.<tr><td><a id="l69"></a><a href="#l69">69</a><td> * @param {string} url Base URL of the server to query.<tr><td><a id="l70"></a><a href="#l70">70</a><td> * @param {number} timeout How long to wait for the server.<tr><td><a id="l71"></a><a href="#l71">71</a><td> * @return {!webdriver.promise.Promise} A promise that will resolve when the<tr><td><a id="l72"></a><a href="#l72">72</a><td> * server is ready.<tr><td><a id="l73"></a><a href="#l73">73</a><td> */<tr><td><a id="l74"></a><a href="#l74">74</a><td>exports.waitForServer = function(url, timeout) {<tr><td><a id="l75"></a><a href="#l75">75</a><td> var ready = promise.defer(),<tr><td><a id="l76"></a><a href="#l76">76</a><td> start = Date.now(),<tr><td><a id="l77"></a><a href="#l77">77</a><td> checkServerStatus = getStatus.bind(null, url, onResponse);<tr><td><a id="l78"></a><a href="#l78">78</a><td> checkServerStatus();<tr><td><a id="l79"></a><a href="#l79">79</a><td> return ready.promise;<tr><td><a id="l80"></a><a href="#l80">80</a><td><tr><td><a id="l81"></a><a href="#l81">81</a><td> function onResponse(err) {<tr><td><a id="l82"></a><a href="#l82">82</a><td> if (!ready.isPending()) return;<tr><td><a id="l83"></a><a href="#l83">83</a><td> if (!err) return ready.fulfill();<tr><td><a id="l84"></a><a href="#l84">84</a><td><tr><td><a id="l85"></a><a href="#l85">85</a><td> if (Date.now() - start > timeout) {<tr><td><a id="l86"></a><a href="#l86">86</a><td> ready.reject(<tr><td><a id="l87"></a><a href="#l87">87</a><td> Error('Timed out waiting for the WebDriver server at ' + url));<tr><td><a id="l88"></a><a href="#l88">88</a><td> } else {<tr><td><a id="l89"></a><a href="#l89">89</a><td> setTimeout(function() {<tr><td><a id="l90"></a><a href="#l90">90</a><td> if (ready.isPending()) {<tr><td><a id="l91"></a><a href="#l91">91</a><td> checkServerStatus();<tr><td><a id="l92"></a><a href="#l92">92</a><td> }<tr><td><a id="l93"></a><a href="#l93">93</a><td> }, 50);<tr><td><a id="l94"></a><a href="#l94">94</a><td> }<tr><td><a id="l95"></a><a href="#l95">95</a><td> }<tr><td><a id="l96"></a><a href="#l96">96</a><td>};<tr><td><a id="l97"></a><a href="#l97">97</a><td><tr><td><a id="l98"></a><a href="#l98">98</a><td><tr><td><a id="l99"></a><a href="#l99">99</a><td>/**<tr><td><a id="l100"></a><a href="#l100">100</a><td> * Polls a URL with GET requests until it returns a 2xx response or the<tr><td><a id="l101"></a><a href="#l101">101</a><td> * timeout expires.<tr><td><a id="l102"></a><a href="#l102">102</a><td> * @param {string} url The URL to poll.<tr><td><a id="l103"></a><a href="#l103">103</a><td> * @param {number} timeout How long to wait, in milliseconds.<tr><td><a id="l104"></a><a href="#l104">104</a><td> * @return {!webdriver.promise.Promise} A promise that will resolve when the<tr><td><a id="l105"></a><a href="#l105">105</a><td> * URL responds with 2xx.<tr><td><a id="l106"></a><a href="#l106">106</a><td> */<tr><td><a id="l107"></a><a href="#l107">107</a><td>exports.waitForUrl = function(url, timeout) {<tr><td><a id="l108"></a><a href="#l108">108</a><td> var client = new HttpClient(url),<tr><td><a id="l109"></a><a href="#l109">109</a><td> request = new HttpRequest('GET', ''),<tr><td><a id="l110"></a><a href="#l110">110</a><td> testUrl = client.send.bind(client, request, onResponse),<tr><td><a id="l111"></a><a href="#l111">111</a><td> ready = promise.defer(),<tr><td><a id="l112"></a><a href="#l112">112</a><td> start = Date.now();<tr><td><a id="l113"></a><a href="#l113">113</a><td> testUrl();<tr><td><a id="l114"></a><a href="#l114">114</a><td> return ready.promise;<tr><td><a id="l115"></a><a href="#l115">115</a><td><tr><td><a id="l116"></a><a href="#l116">116</a><td> function onResponse(err, response) {<tr><td><a id="l117"></a><a href="#l117">117</a><td> if (!ready.isPending()) return;<tr><td><a id="l118"></a><a href="#l118">118</a><td> if (!err && response.status > 199 && response.status < 300) {<tr><td><a id="l119"></a><a href="#l119">119</a><td> return ready.fulfill();<tr><td><a id="l120"></a><a href="#l120">120</a><td> }<tr><td><a id="l121"></a><a href="#l121">121</a><td><tr><td><a id="l122"></a><a href="#l122">122</a><td> if (Date.now() - start > timeout) {<tr><td><a id="l123"></a><a href="#l123">123</a><td> ready.reject(Error(<tr><td><a id="l124"></a><a href="#l124">124</a><td> 'Timed out waiting for the URL to return 2xx: ' + url));<tr><td><a id="l125"></a><a href="#l125">125</a><td> } else {<tr><td><a id="l126"></a><a href="#l126">126</a><td> setTimeout(function() {<tr><td><a id="l127"></a><a href="#l127">127</a><td> if (ready.isPending()) {<tr><td><a id="l128"></a><a href="#l128">128</a><td> testUrl();<tr><td><a id="l129"></a><a href="#l129">129</a><td> }<tr><td><a id="l130"></a><a href="#l130">130</a><td> }, 50);<tr><td><a id="l131"></a><a href="#l131">131</a><td> }<tr><td><a id="l132"></a><a href="#l132">132</a><td> }<tr><td><a id="l133"></a><a href="#l133">133</a><td>};</table></div></article><nav><h3><a href="../../index.html">Overview</a></h3><div><input type="checkbox" id="nav-modules" checked/><label for="nav-modules"><h3>Modules</h3></label><div><ul><li><a href="../../module_selenium-webdriver.html">selenium-webdriver</a><li><a href="../../module_selenium-webdriver__base.html">selenium-webdriver/_base</a><li><a href="../../module_selenium-webdriver_builder.html">selenium-webdriver/builder</a><li><a href="../../module_selenium-webdriver_chrome.html">selenium-webdriver/chrome</a><li><a href="../../module_selenium-webdriver_error.html">selenium-webdriver/error</a><li><a href="../../module_selenium-webdriver_executors.html">selenium-webdriver/executors</a><li><a href="../../module_selenium-webdriver_firefox.html">selenium-webdriver/firefox</a><li><a href="../../module_selenium-webdriver_firefox_binary.html">selenium-webdriver/firefox/binary</a><li><a href="../../module_selenium-webdriver_firefox_extension.html">selenium-webdriver/firefox/extension</a><li><a href="../../module_selenium-webdriver_firefox_profile.html">selenium-webdriver/firefox/profile</a><li><a href="../../module_selenium-webdriver_http.html">selenium-webdriver/http</a><li><a href="../../module_selenium-webdriver_http_util.html">selenium-webdriver/http/util</a><li><a href="../../module_selenium-webdriver_ie.html">selenium-webdriver/ie</a><li><a href="../../module_selenium-webdriver_io.html">selenium-webdriver/io</a><li><a href="../../module_selenium-webdriver_io_exec.html">selenium-webdriver/io/exec</a><li><a href="../../module_selenium-webdriver_net.html">selenium-webdriver/net</a><li><a href="../../module_selenium-webdriver_net_portprober.html">selenium-webdriver/net/portprober</a><li><a href="../../module_selenium-webdriver_opera.html">selenium-webdriver/opera</a><li><a href="../../module_selenium-webdriver_phantomjs.html">selenium-webdriver/phantomjs</a><li><a href="../../module_selenium-webdriver_proxy.html">selenium-webdriver/proxy</a><li><a href="../../module_selenium-webdriver_remote.html">selenium-webdriver/remote</a><li><a href="../../module_selenium-webdriver_safari.html">selenium-webdriver/safari</a><li><a href="../../module_selenium-webdriver_testing.html">selenium-webdriver/testing</a><li><a href="../../module_selenium-webdriver_testing_assert.html">selenium-webdriver/testing/assert</a></ul></div></div><div><input type="checkbox" id="nav-types" checked/><label for="nav-types"><h3>Types</h3></label><div><ul><li><a href="../../namespace_bot.html">bot</a><li><a href="../../class_bot_Error.html">bot.Error</a><li><a href="../../enum_bot_Error_State.html">bot.Error.State</a><li><a href="../../enum_bot_ErrorCode.html">bot.ErrorCode</a><li><a href="../../namespace_bot_json.html">bot.json</a><li><a href="../../namespace_bot_response.html">bot.response</a><li><a href="../../namespace_bot_userAgent.html">bot.userAgent</a><li><a href="../../namespace_webdriver.html">webdriver</a><li><a href="../../class_webdriver_ActionSequence.html">webdriver.ActionSequence</a><li><a href="../../class_webdriver_Alert.html">webdriver.Alert</a><li><a href="../../class_webdriver_AlertPromise.html">webdriver.AlertPromise</a><li><a href="../../enum_webdriver_Browser.html">webdriver.Browser</a><li><a href="../../enum_webdriver_Button.html">webdriver.Button</a><li><a href="../../namespace_webdriver_By.html">webdriver.By</a><li><a href="../../class_webdriver_Capabilities.html">webdriver.Capabilities</a><li><a href="../../enum_webdriver_Capability.html">webdriver.Capability</a><li><a href="../../class_webdriver_Command.html">webdriver.Command</a><li><a href="../../interface_webdriver_CommandExecutor.html">webdriver.CommandExecutor</a><li><a href="../../enum_webdriver_CommandName.html">webdriver.CommandName</a><li><a href="../../class_webdriver_EventEmitter.html">webdriver.EventEmitter</a><li><a href="../../class_webdriver_FileDetector.html">webdriver.FileDetector</a><li><a href="../../enum_webdriver_Key.html">webdriver.Key</a><li><a href="../../class_webdriver_Locator.html">webdriver.Locator</a><li><a href="../../class_webdriver_Serializable.html">webdriver.Serializable</a><li><a href="../../class_webdriver_Session.html">webdriver.Session</a><li><a href="../../class_webdriver_TouchSequence.html">webdriver.TouchSequence</a><li><a href="../../class_webdriver_UnhandledAlertError.html">webdriver.UnhandledAlertError</a><li><a href="../../class_webdriver_WebDriver.html">webdriver.WebDriver</a><li><a href="../../class_webdriver_WebDriver_Logs.html">webdriver.WebDriver.Logs</a><li><a href="../../class_webdriver_WebDriver_Navigation.html">webdriver.WebDriver.Navigation</a><li><a href="../../class_webdriver_WebDriver_Options.html">webdriver.WebDriver.Options</a><li><a href="../../class_webdriver_WebDriver_TargetLocator.html">webdriver.WebDriver.TargetLocator</a><li><a href="../../class_webdriver_WebDriver_Timeouts.html">webdriver.WebDriver.Timeouts</a><li><a href="../../class_webdriver_WebDriver_Window.html">webdriver.WebDriver.Window</a><li><a href="../../class_webdriver_WebElement.html">webdriver.WebElement</a><li><a href="../../class_webdriver_WebElementPromise.html">webdriver.WebElementPromise</a><li><a href="../../namespace_webdriver_http.html">webdriver.http</a><li><a href="../../interface_webdriver_http_Client.html">webdriver.http.Client</a><li><a href="../../class_webdriver_http_Executor.html">webdriver.http.Executor</a><li><a href="../../class_webdriver_http_Request.html">webdriver.http.Request</a><li><a href="../../class_webdriver_http_Response.html">webdriver.http.Response</a><li><a href="../../namespace_webdriver_logging.html">webdriver.logging</a><li><a href="../../class_webdriver_logging_Entry.html">webdriver.logging.Entry</a><li><a href="../../enum_webdriver_logging_Level.html">webdriver.logging.Level</a><li><a href="../../class_webdriver_logging_Preferences.html">webdriver.logging.Preferences</a><li><a href="../../enum_webdriver_logging_Type.html">webdriver.logging.Type</a><li><a href="../../namespace_webdriver_promise.html">webdriver.promise</a><li><a href="../../class_webdriver_promise_Callback_.html">webdriver.promise.Callback_</a><li><a href="../../class_webdriver_promise_CancellationError.html">webdriver.promise.CancellationError</a><li><a href="../../class_webdriver_promise_ControlFlow.html">webdriver.promise.ControlFlow</a><li><a href="../../enum_webdriver_promise_ControlFlow_EventType.html">webdriver.promise.ControlFlow.EventType</a><li><a href="../../class_webdriver_promise_Deferred.html">webdriver.promise.Deferred</a><li><a href="../../class_webdriver_promise_Frame_.html">webdriver.promise.Frame_</a><li><a href="../../class_webdriver_promise_MicroTask_.html">webdriver.promise.MicroTask_</a><li><a href="../../class_webdriver_promise_Promise.html">webdriver.promise.Promise</a><li><a href="../../enum_webdriver_promise_Promise_State_.html">webdriver.promise.Promise.State_</a><li><a href="../../class_webdriver_promise_Task_.html">webdriver.promise.Task_</a><li><a href="../../interface_webdriver_promise_Thenable.html">webdriver.promise.Thenable</a><li><a href="../../namespace_webdriver_stacktrace.html">webdriver.stacktrace</a><li><a href="../../class_webdriver_stacktrace_Frame.html">webdriver.stacktrace.Frame</a><li><a href="../../class_webdriver_stacktrace_Snapshot.html">webdriver.stacktrace.Snapshot</a><li><a href="../../namespace_webdriver_testing.html">webdriver.testing</a><li><a href="../../class_webdriver_testing_Assertion.html">webdriver.testing.Assertion</a><li><a href="../../class_webdriver_testing_Assertion_DelegatingMatcher_.html">webdriver.testing.Assertion.DelegatingMatcher_</a><li><a href="../../class_webdriver_testing_ContainsMatcher.html">webdriver.testing.ContainsMatcher</a><li><a href="../../class_webdriver_testing_NegatedAssertion.html">webdriver.testing.NegatedAssertion</a><li><a href="../../namespace_webdriver_testing_assert.html">webdriver.testing.assert</a><li><a href="../../namespace_webdriver_testing_asserts.html">webdriver.testing.asserts</a><li><a href="../../namespace_webdriver_until.html">webdriver.until</a><li><a href="../../class_webdriver_until_Condition.html">webdriver.until.Condition</a></ul></div></div><h3><a href="../../Changes.html">Changes</a></h3></nav></main><div class="pre-footer"><div></div></div><footer><div><a href="https://github.com/jleyba/js-dossier">Generated by dossier</a></div></footer><script src="../../types.js"></script><script src="../../dossier.js"></script>
\ No newline at end of file