puppeteer-ruby 0.0.11 → 0.0.16

Sign up to get free protection for your applications and to get access to all the features.
Files changed (138) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +0 -12
  3. data/.github/workflows/docs.yml +45 -0
  4. data/.github/workflows/reviewdog.yml +15 -0
  5. data/README.md +54 -1
  6. data/lib/puppeteer.rb +39 -13
  7. data/lib/puppeteer/browser.rb +22 -25
  8. data/lib/puppeteer/cdp_session.rb +3 -19
  9. data/lib/puppeteer/concurrent_ruby_utils.rb +12 -2
  10. data/lib/puppeteer/connection.rb +3 -15
  11. data/lib/puppeteer/define_async_method.rb +23 -0
  12. data/lib/puppeteer/dom_world.rb +51 -65
  13. data/lib/puppeteer/element_handle.rb +15 -44
  14. data/lib/puppeteer/emulation_manager.rb +2 -6
  15. data/lib/puppeteer/event_callbackable.rb +11 -0
  16. data/lib/puppeteer/execution_context.rb +1 -6
  17. data/lib/puppeteer/frame.rb +34 -39
  18. data/lib/puppeteer/frame_manager.rb +7 -25
  19. data/lib/puppeteer/js_handle.rb +3 -12
  20. data/lib/puppeteer/keyboard.rb +6 -27
  21. data/lib/puppeteer/launcher.rb +6 -6
  22. data/lib/puppeteer/launcher/chrome.rb +10 -8
  23. data/lib/puppeteer/mouse.rb +5 -25
  24. data/lib/puppeteer/network_manager.rb +163 -5
  25. data/lib/puppeteer/page.rb +230 -177
  26. data/lib/puppeteer/page/pdf_options.rb +166 -0
  27. data/lib/puppeteer/remote_object.rb +2 -5
  28. data/lib/puppeteer/request.rb +336 -0
  29. data/lib/puppeteer/response.rb +113 -0
  30. data/lib/puppeteer/target.rb +1 -1
  31. data/lib/puppeteer/touch_screen.rb +2 -7
  32. data/lib/puppeteer/version.rb +1 -1
  33. data/lib/puppeteer/wait_task.rb +2 -4
  34. data/lib/puppeteer/web_socket_transport.rb +8 -8
  35. data/puppeteer-ruby.gemspec +1 -1
  36. data/puppeteer-ruby.png +0 -0
  37. metadata +11 -105
  38. data/Dockerfile +0 -6
  39. data/docker-compose.yml +0 -15
  40. data/docs/Puppeteer.html +0 -2020
  41. data/docs/Puppeteer/AsyncAwaitBehavior.html +0 -105
  42. data/docs/Puppeteer/Browser.html +0 -2258
  43. data/docs/Puppeteer/BrowserContext.html +0 -809
  44. data/docs/Puppeteer/BrowserFetcher.html +0 -214
  45. data/docs/Puppeteer/BrowserRunner.html +0 -914
  46. data/docs/Puppeteer/BrowserRunner/BrowserProcess.html +0 -477
  47. data/docs/Puppeteer/CDPSession.html +0 -813
  48. data/docs/Puppeteer/CDPSession/Error.html +0 -124
  49. data/docs/Puppeteer/ConcurrentRubyUtils.html +0 -430
  50. data/docs/Puppeteer/Connection.html +0 -964
  51. data/docs/Puppeteer/Connection/MessageCallback.html +0 -434
  52. data/docs/Puppeteer/Connection/ProtocolError.html +0 -216
  53. data/docs/Puppeteer/Connection/RequestDebugPrinter.html +0 -217
  54. data/docs/Puppeteer/Connection/ResponseDebugPrinter.html +0 -244
  55. data/docs/Puppeteer/ConsoleMessage.html +0 -565
  56. data/docs/Puppeteer/ConsoleMessage/Location.html +0 -433
  57. data/docs/Puppeteer/DOMWorld.html +0 -2219
  58. data/docs/Puppeteer/DOMWorld/DetachedError.html +0 -124
  59. data/docs/Puppeteer/DOMWorld/DocumentEvaluationError.html +0 -124
  60. data/docs/Puppeteer/DebugPrint.html +0 -233
  61. data/docs/Puppeteer/Device.html +0 -470
  62. data/docs/Puppeteer/Devices.html +0 -139
  63. data/docs/Puppeteer/ElementHandle.html +0 -2542
  64. data/docs/Puppeteer/ElementHandle/BoundingBox.html +0 -507
  65. data/docs/Puppeteer/ElementHandle/BoxModel.html +0 -404
  66. data/docs/Puppeteer/ElementHandle/ElementNotFoundError.html +0 -206
  67. data/docs/Puppeteer/ElementHandle/ElementNotVisibleError.html +0 -206
  68. data/docs/Puppeteer/ElementHandle/Point.html +0 -492
  69. data/docs/Puppeteer/ElementHandle/ScrollIntoViewError.html +0 -124
  70. data/docs/Puppeteer/EmulationManager.html +0 -454
  71. data/docs/Puppeteer/EventCallbackable.html +0 -433
  72. data/docs/Puppeteer/EventCallbackable/EventListeners.html +0 -435
  73. data/docs/Puppeteer/ExecutionContext.html +0 -998
  74. data/docs/Puppeteer/ExecutionContext/EvaluationError.html +0 -124
  75. data/docs/Puppeteer/ExecutionContext/JavaScriptExpression.html +0 -357
  76. data/docs/Puppeteer/ExecutionContext/JavaScriptFunction.html +0 -389
  77. data/docs/Puppeteer/FileChooser.html +0 -455
  78. data/docs/Puppeteer/Frame.html +0 -3813
  79. data/docs/Puppeteer/FrameManager.html +0 -2410
  80. data/docs/Puppeteer/FrameManager/NavigationError.html +0 -124
  81. data/docs/Puppeteer/IfPresent.html +0 -222
  82. data/docs/Puppeteer/JSHandle.html +0 -1352
  83. data/docs/Puppeteer/Keyboard.html +0 -1557
  84. data/docs/Puppeteer/Keyboard/KeyDefinition.html +0 -831
  85. data/docs/Puppeteer/Keyboard/KeyDescription.html +0 -603
  86. data/docs/Puppeteer/Launcher.html +0 -237
  87. data/docs/Puppeteer/Launcher/Base.html +0 -385
  88. data/docs/Puppeteer/Launcher/Base/ExecutablePathNotFound.html +0 -124
  89. data/docs/Puppeteer/Launcher/BrowserOptions.html +0 -441
  90. data/docs/Puppeteer/Launcher/Chrome.html +0 -669
  91. data/docs/Puppeteer/Launcher/Chrome/DefaultArgs.html +0 -382
  92. data/docs/Puppeteer/Launcher/ChromeArgOptions.html +0 -531
  93. data/docs/Puppeteer/Launcher/LaunchOptions.html +0 -893
  94. data/docs/Puppeteer/LifecycleWatcher.html +0 -834
  95. data/docs/Puppeteer/LifecycleWatcher/ExpectedLifecycle.html +0 -363
  96. data/docs/Puppeteer/LifecycleWatcher/FrameDetachedError.html +0 -206
  97. data/docs/Puppeteer/LifecycleWatcher/TerminatedError.html +0 -124
  98. data/docs/Puppeteer/Mouse.html +0 -1095
  99. data/docs/Puppeteer/Mouse/Button.html +0 -136
  100. data/docs/Puppeteer/NetworkManager.html +0 -901
  101. data/docs/Puppeteer/NetworkManager/Credentials.html +0 -385
  102. data/docs/Puppeteer/Page.html +0 -5970
  103. data/docs/Puppeteer/Page/FileChooserTimeoutError.html +0 -206
  104. data/docs/Puppeteer/Page/ScreenshotOptions.html +0 -845
  105. data/docs/Puppeteer/Page/ScriptTag.html +0 -555
  106. data/docs/Puppeteer/Page/StyleTag.html +0 -448
  107. data/docs/Puppeteer/Page/TargetCrashedError.html +0 -124
  108. data/docs/Puppeteer/RemoteObject.html +0 -1087
  109. data/docs/Puppeteer/Target.html +0 -1336
  110. data/docs/Puppeteer/Target/InitializeFailure.html +0 -124
  111. data/docs/Puppeteer/Target/TargetInfo.html +0 -729
  112. data/docs/Puppeteer/TimeoutError.html +0 -135
  113. data/docs/Puppeteer/TimeoutSettings.html +0 -496
  114. data/docs/Puppeteer/TouchScreen.html +0 -464
  115. data/docs/Puppeteer/Viewport.html +0 -837
  116. data/docs/Puppeteer/WaitTask.html +0 -637
  117. data/docs/Puppeteer/WaitTask/TerminatedError.html +0 -124
  118. data/docs/Puppeteer/WaitTask/TimeoutError.html +0 -206
  119. data/docs/Puppeteer/WebSocket.html +0 -673
  120. data/docs/Puppeteer/WebSocket/DriverImpl.html +0 -412
  121. data/docs/Puppeteer/WebSocket/TransportError.html +0 -124
  122. data/docs/Puppeteer/WebSocketTransport.html +0 -600
  123. data/docs/Puppeteer/WebSocktTransportError.html +0 -124
  124. data/docs/_index.html +0 -816
  125. data/docs/class_list.html +0 -51
  126. data/docs/css/common.css +0 -1
  127. data/docs/css/full_list.css +0 -58
  128. data/docs/css/style.css +0 -496
  129. data/docs/file.README.html +0 -123
  130. data/docs/file_list.html +0 -56
  131. data/docs/frames.html +0 -17
  132. data/docs/index.html +0 -123
  133. data/docs/js/app.js +0 -314
  134. data/docs/js/full_list.js +0 -216
  135. data/docs/js/jquery.js +0 -4
  136. data/docs/method_list.html +0 -4091
  137. data/docs/top-level-namespace.html +0 -126
  138. data/lib/puppeteer/async_await_behavior.rb +0 -38
@@ -3,7 +3,7 @@ require 'json'
3
3
  class Puppeteer::Connection
4
4
  include Puppeteer::DebugPrint
5
5
  include Puppeteer::EventCallbackable
6
- using Puppeteer::AsyncAwaitBehavior
6
+ using Puppeteer::DefineAsyncMethod
7
7
 
8
8
  class ProtocolError < StandardError
9
9
  def initialize(method:, error_message:, error_data: nil)
@@ -210,9 +210,7 @@ class Puppeteer::Connection
210
210
  end
211
211
  end
212
212
 
213
- private async def async_handle_message(message)
214
- handle_message(message)
215
- end
213
+ private define_async_method :async_handle_message
216
214
 
217
215
  private def handle_close
218
216
  return if @closed
@@ -251,16 +249,6 @@ class Puppeteer::Connection
251
249
  def create_session(target_info)
252
250
  result = send_message('Target.attachToTarget', targetId: target_info.target_id, flatten: true)
253
251
  session_id = result['sessionId']
254
-
255
- # Target.attachedToTarget is often notified after the result of Target.attachToTarget.
256
- # D, [2020-04-04T23:04:30.736311 #91875] DEBUG -- : RECV << {"id"=>2, "result"=>{"sessionId"=>"DA002F8A95B04710502CB40D8430B95A"}}
257
- # D, [2020-04-04T23:04:30.736649 #91875] DEBUG -- : RECV << {"method"=>"Target.attachedToTarget", "params"=>{"sessionId"=>"DA002F8A95B04710502CB40D8430B95A", "targetInfo"=>{"targetId"=>"EBAB949A7DE63F12CB94268AD3A9976B", "type"=>"page", "title"=>"about:blank", "url"=>"about:blank", "attached"=>true, "browserContextId"=>"46D23767E9B79DD9E589101121F6DADD"}, "waitingForDebugger"=>false}}
258
- # So we have to wait for "Target.attachedToTarget" a bit.
259
- 20.times do
260
- if @sessions[session_id]
261
- return @sessions[session_id]
262
- end
263
- sleep 0.1
264
- end
252
+ @sessions[session_id]
265
253
  end
266
254
  end
@@ -0,0 +1,23 @@
1
+ module Puppeteer::DefineAsyncMethod
2
+ refine Class do
3
+ def define_async_method(async_method_name)
4
+ unless async_method_name.to_s.start_with?('async_')
5
+ raise ArgumentError.new('async method name should start with "async_"')
6
+ end
7
+
8
+ if method_defined?(async_method_name) || private_method_defined?(async_method_name)
9
+ raise ArgumentError.new("#{async_method_name} is already defined")
10
+ end
11
+
12
+ original_method = instance_method(async_method_name[6..-1])
13
+ define_method(async_method_name) do |*args|
14
+ Concurrent::Promises.future do
15
+ original_method.bind(self).call(*args)
16
+ rescue => err
17
+ Logger.new(STDERR).warn(err)
18
+ raise err
19
+ end
20
+ end
21
+ end
22
+ end
23
+ end
@@ -2,7 +2,7 @@ require 'thread'
2
2
 
3
3
  # https://github.com/puppeteer/puppeteer/blob/master/src/DOMWorld.js
4
4
  class Puppeteer::DOMWorld
5
- using Puppeteer::AsyncAwaitBehavior
5
+ using Puppeteer::DefineAsyncMethod
6
6
 
7
7
  # @param {!Puppeteer.FrameManager} frameManager
8
8
  # @param {!Puppeteer.Frame} frame
@@ -12,7 +12,6 @@ class Puppeteer::DOMWorld
12
12
  @frame = frame
13
13
  @timeout_settings = timeout_settings
14
14
  @context_promise = resolvable_future
15
- @pending_destroy = []
16
15
  @wait_tasks = Set.new
17
16
  @detached = false
18
17
  end
@@ -24,22 +23,12 @@ class Puppeteer::DOMWorld
24
23
  @wait_tasks
25
24
  end
26
25
 
27
- # @param {?Puppeteer.ExecutionContext} context
26
+ # @param context [Puppeteer::ExecutionContext]
28
27
  def context=(context)
29
- # D, [2020-04-12T22:45:03.938754 #46154] DEBUG -- : RECV << {"method"=>"Runtime.executionContextCreated", "params"=>{"context"=>{"id"=>3, "origin"=>"https://github.com", "name"=>"", "auxData"=>{"isDefault"=>true, "type"=>"default", "frameId"=>"3AD7F1E82BCBA88BFE31D03BC49FF6CB"}}}, "sessionId"=>"636CEF0C4FEAFC4FE815E9E7B5F7BA68"}
30
- # D, [2020-04-12T22:45:03.938856 #46154] DEBUG -- : RECV << {"method"=>"Runtime.executionContextCreated", "params"=>{"context"=>{"id"=>4, "origin"=>"://", "name"=>"__puppeteer_utility_world__", "auxData"=>{"isDefault"=>false, "type"=>"isolated", "frameId"=>"3AD7F1E82BCBA88BFE31D03BC49FF6CB"}}}, "sessionId"=>"636CEF0C4FEAFC4FE815E9E7B5F7BA68"}
31
- # D, [2020-04-12T22:45:03.938960 #46154] DEBUG -- : RECV << {"method"=>"Runtime.executionContextDestroyed", "params"=>{"executionContextId"=>1}, "sessionId"=>"636CEF0C4FEAFC4FE815E9E7B5F7BA68"}
32
- # D, [2020-04-12T22:45:03.939110 #46154] DEBUG -- : RECV << {"method"=>"Page.frameNavigated", "params"=>{"frame"=>{"id"=>"3AD7F1E82BCBA88BFE31D03BC49FF6CB", "loaderId"=>"301B349884E582986C502CBE020966DF", "url"=>"https://github.com/", "securityOrigin"=>"https://github.com", "mimeType"=>"text/html"}}, "sessionId"=>"636CEF0C4FEAFC4FE815E9E7B5F7BA68"}
33
- # D, [2020-04-12T22:45:03.939793 #46154] DEBUG -- : RECV << {"method"=>"Runtime.executionContextDestroyed", "params"=>{"executionContextId"=>2}, "sessionId"=>"636CEF0C4FEAFC4FE815E9E7B5F7BA68"}
34
- # executionContextDestroyed is often notified after executionContextCreated.
35
-
36
28
  if context
37
- if @context_promise.fulfilled?
38
- @pending_destroy << context._context_id
39
- @document = nil
40
- @context_promise = resolvable_future
29
+ unless @context_promise.resolved?
30
+ @context_promise.fulfill(context)
41
31
  end
42
- @context_promise.fulfill(context)
43
32
  @wait_tasks.each(&:async_rerun)
44
33
  else
45
34
  raise ArgumentError.new("context should now be nil. Use #delete_context for clearing document.")
@@ -47,12 +36,8 @@ class Puppeteer::DOMWorld
47
36
  end
48
37
 
49
38
  def delete_context(execution_context_id)
50
- if @pending_destroy.include?(execution_context_id)
51
- @pending_destroy.delete(execution_context_id)
52
- else
53
- @document = nil
54
- @context_promise = resolvable_future
55
- end
39
+ @document = nil
40
+ @context_promise = resolvable_future
56
41
  end
57
42
 
58
43
  def has_context?
@@ -147,45 +132,48 @@ class Puppeteer::DOMWorld
147
132
  document.SS(selector)
148
133
  end
149
134
 
150
- # /**
151
- # * @return {!Promise<String>}
152
- # */
153
- # async content() {
154
- # return await this.evaluate(() => {
155
- # let retVal = '';
156
- # if (document.doctype)
157
- # retVal = new XMLSerializer().serializeToString(document.doctype);
158
- # if (document.documentElement)
159
- # retVal += document.documentElement.outerHTML;
160
- # return retVal;
161
- # });
162
- # }
135
+ # @return [String]
136
+ def content
137
+ evaluate <<-JAVASCRIPT
138
+ () => {
139
+ let retVal = '';
140
+ if (document.doctype)
141
+ retVal = new XMLSerializer().serializeToString(document.doctype);
142
+ if (document.documentElement)
143
+ retVal += document.documentElement.outerHTML;
144
+ return retVal;
145
+ }
146
+ JAVASCRIPT
147
+ end
163
148
 
164
- # /**
165
- # * @param {string} html
166
- # * @param {!{timeout?: number, waitUntil?: string|!Array<string>}=} options
167
- # */
168
- # async setContent(html, options = {}) {
169
- # const {
170
- # waitUntil = ['load'],
171
- # timeout = this._timeoutSettings.navigationTimeout(),
172
- # } = options;
173
- # // We rely upon the fact that document.open() will reset frame lifecycle with "init"
174
- # // lifecycle event. @see https://crrev.com/608658
175
- # await this.evaluate(html => {
176
- # document.open();
177
- # document.write(html);
178
- # document.close();
179
- # }, html);
180
- # const watcher = new LifecycleWatcher(this._frameManager, this._frame, waitUntil, timeout);
181
- # const error = await Promise.race([
182
- # watcher.timeoutOrTerminationPromise(),
183
- # watcher.lifecyclePromise(),
184
- # ]);
185
- # watcher.dispose();
186
- # if (error)
187
- # throw error;
188
- # }
149
+ # @param html [String]
150
+ # @param timeout [Integer]
151
+ # @param wait_until [String|Array<String>]
152
+ def set_content(html, timeout: nil, wait_until: nil)
153
+ option_wait_until = [wait_until || 'load'].flatten
154
+ option_timeout = @timeout_settings.navigation_timeout
155
+
156
+ # We rely upon the fact that document.open() will reset frame lifecycle with "init"
157
+ # lifecycle event. @see https://crrev.com/608658
158
+ js = <<-JAVASCRIPT
159
+ (html) => {
160
+ document.open();
161
+ document.write(html);
162
+ document.close();
163
+ }
164
+ JAVASCRIPT
165
+ evaluate(js, html)
166
+
167
+ watcher = Puppeteer::LifecycleWatcher.new(@frame_manager, @frame, option_wait_until, option_timeout)
168
+ begin
169
+ await_any(
170
+ watcher.timeout_or_termination_promise,
171
+ watcher.lifecycle_promise,
172
+ )
173
+ ensure
174
+ watcher.dispose
175
+ end
176
+ end
189
177
 
190
178
  # /**
191
179
  # * @param {!{url?: string, path?: string, content?: string, type?: string}} options
@@ -411,12 +399,10 @@ class Puppeteer::DOMWorld
411
399
  # return new WaitTask(this, pageFunction, 'function', polling, timeout, ...args).promise;
412
400
  # }
413
401
 
414
- # /**
415
- # * @return {!Promise<string>}
416
- # */
417
- # async title() {
418
- # return this.evaluate(() => document.title);
419
- # }
402
+ # @return [String]
403
+ def title
404
+ evaluate('() => document.title')
405
+ end
420
406
 
421
407
  # @param selector_or_xpath [String]
422
408
  # @param is_xpath [Boolean]
@@ -4,7 +4,7 @@ require_relative './element_handle/point'
4
4
 
5
5
  class Puppeteer::ElementHandle < Puppeteer::JSHandle
6
6
  include Puppeteer::IfPresent
7
- using Puppeteer::AsyncAwaitBehavior
7
+ using Puppeteer::DefineAsyncMethod
8
8
 
9
9
  # @param context [Puppeteer::ExecutionContext]
10
10
  # @param client [Puppeteer::CDPSession]
@@ -105,11 +105,11 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
105
105
  end
106
106
  end
107
107
 
108
- # async hover() {
109
- # await this._scrollIntoViewIfNeeded();
110
- # const {x, y} = await this._clickablePoint();
111
- # await this._page.mouse.move(x, y);
112
- # }
108
+ def hover
109
+ scroll_into_view_if_needed
110
+ point = clickable_point
111
+ @page.mouse.move(point.x, point.y)
112
+ end
113
113
 
114
114
  # @param delay [Number]
115
115
  # @param button [String] "left"|"right"|"middle"
@@ -120,12 +120,7 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
120
120
  @page.mouse.click(point.x, point.y, delay: delay, button: button, click_count: click_count)
121
121
  end
122
122
 
123
- # @param delay [Number]
124
- # @param button [String] "left"|"right"|"middle"
125
- # @param click_count [Number]
126
- async def async_click(delay: nil, button: nil, click_count: nil)
127
- click(delay: delay, button: button, click_count: click_count)
128
- end
123
+ define_async_method :async_click
129
124
 
130
125
  # @return [Array<String>]
131
126
  def select(*values)
@@ -195,17 +190,13 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
195
190
  @page.touchscreen.tap(point.x, point.y)
196
191
  end
197
192
 
198
- async def async_tap
199
- tap
200
- end
193
+ define_async_method :async_tap
201
194
 
202
195
  def focus
203
196
  evaluate('element => element.focus()')
204
197
  end
205
198
 
206
- async def async_focus
207
- focus
208
- end
199
+ define_async_method :async_focus
209
200
 
210
201
  # @param text [String]
211
202
  # @param delay [number|nil]
@@ -214,12 +205,7 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
214
205
  @page.keyboard.type_text(text, delay: delay)
215
206
  end
216
207
 
217
- # @param text [String]
218
- # @param delay [number|nil]
219
- # @return [Future]
220
- async def async_type_text(text, delay: nil)
221
- type_text(text, delay: delay)
222
- end
208
+ define_async_method :async_type_text
223
209
 
224
210
  # @param key [String]
225
211
  # @param delay [number|nil]
@@ -228,12 +214,7 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
228
214
  @page.keyboard.press(key, delay: delay)
229
215
  end
230
216
 
231
- # @param key [String]
232
- # @param delay [number|nil]
233
- # @return [Future]
234
- async def async_press(key, delay: nil)
235
- press(key, delay: delay)
236
- end
217
+ define_async_method :async_press
237
218
 
238
219
  # @return [BoundingBox|nil]
239
220
  def bounding_box
@@ -356,13 +337,7 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
356
337
  result
357
338
  end
358
339
 
359
- # `$eval()` in JavaScript. $ is not allowed to use as a method name in Ruby.
360
- # @param selector [String]
361
- # @param page_function [String]
362
- # @return [Object]
363
- async def async_Seval(selector, page_function, *args)
364
- Seval(selector, page_function, *args)
365
- end
340
+ define_async_method :async_Seval
366
341
 
367
342
  # `$$eval()` in JavaScript. $ is not allowed to use as a method name in Ruby.
368
343
  # @param selector [String]
@@ -379,13 +354,7 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
379
354
  result
380
355
  end
381
356
 
382
- # `$$eval()` in JavaScript. $ is not allowed to use as a method name in Ruby.
383
- # @param selector [String]
384
- # @param page_function [String]
385
- # @return [Object]
386
- async def async_SSeval(selector, page_function, *args)
387
- SSeval(selector, page_function, *args)
388
- end
357
+ define_async_method :async_SSeval
389
358
 
390
359
  # `$x()` in JavaScript. $ is not allowed to use as a method name in Ruby.
391
360
  # @param expression [String]
@@ -408,6 +377,8 @@ class Puppeteer::ElementHandle < Puppeteer::JSHandle
408
377
  properties.values.map(&:as_element).compact
409
378
  end
410
379
 
380
+ define_async_method :async_Sx
381
+
411
382
  # /**
412
383
  # * @returns {!Promise<boolean>}
413
384
  # */
@@ -1,5 +1,5 @@
1
1
  class Puppeteer::EmulationManager
2
- using Puppeteer::AsyncAwaitBehavior
2
+ using Puppeteer::DefineAsyncMethod
3
3
 
4
4
  # @param {!Puppeteer.CDPSession} client
5
5
  def initialize(client)
@@ -38,9 +38,5 @@ class Puppeteer::EmulationManager
38
38
  reload_needed
39
39
  end
40
40
 
41
- # @param viewport [Puppeteer::Viewport]
42
- # @return [Future<true|false>]
43
- async def async_emulate_viewport(viewport)
44
- emulate_viewport(viewport)
45
- end
41
+ define_async_method :async_emulate_viewport
46
42
  end
@@ -39,6 +39,17 @@ module Puppeteer::EventCallbackable
39
39
  end
40
40
  end
41
41
 
42
+ def observe_first(event_name, &block)
43
+ listener_id = add_event_listener(event_name) do |*args, **kwargs|
44
+ if kwargs.empty?
45
+ block.call(*args)
46
+ else
47
+ block.call(*args, **kwargs)
48
+ end
49
+ remove_event_listener(listener_id)
50
+ end
51
+ end
52
+
42
53
  def on_event(event_name, &block)
43
54
  @event_callbackable_handlers ||= {}
44
55
  @event_callbackable_handlers[event_name] = block
@@ -1,6 +1,6 @@
1
1
  class Puppeteer::ExecutionContext
2
2
  include Puppeteer::IfPresent
3
- using Puppeteer::AsyncAwaitBehavior
3
+ using Puppeteer::DefineAsyncMethod
4
4
 
5
5
  EVALUATION_SCRIPT_URL = '__puppeteer_evaluation_script__'
6
6
  SOURCE_URL_REGEX = /^[\040\t]*\/\/[@#] sourceURL=\s*(\S*?)\s*$/m
@@ -16,11 +16,6 @@ class Puppeteer::ExecutionContext
16
16
 
17
17
  attr_reader :client, :world
18
18
 
19
- # only used in DomWorld#delete_context
20
- def _context_id
21
- @context_id
22
- end
23
-
24
19
  # @return [Puppeteer::Frame]
25
20
  def frame
26
21
  if_present(@world) do |world|
@@ -1,5 +1,5 @@
1
1
  class Puppeteer::Frame
2
- using Puppeteer::AsyncAwaitBehavior
2
+ using Puppeteer::DefineAsyncMethod
3
3
 
4
4
  # @param {!FrameManager} frameManager
5
5
  # @param {!Puppeteer.CDPSession} client
@@ -39,12 +39,7 @@ class Puppeteer::Frame
39
39
  @frame_manager.wait_for_frame_navigation(self, timeout: timeout, wait_until: wait_until)
40
40
  end
41
41
 
42
- # @param timeout [number|nil]
43
- # @param wait_until [string|nil] 'load' | 'domcontentloaded' | 'networkidle0' | 'networkidle2'
44
- # @return [Future]
45
- async def async_wait_for_navigation(timeout: nil, wait_until: nil)
46
- wait_for_navigation(timeout: timeout, wait_until: wait_until)
47
- end
42
+ define_async_method :async_wait_for_navigation
48
43
 
49
44
  def execution_context
50
45
  @main_world.execution_context
@@ -56,12 +51,16 @@ class Puppeteer::Frame
56
51
  @main_world.evaluate_handle(page_function, *args)
57
52
  end
58
53
 
54
+ define_async_method :async_evaluate_handle
55
+
59
56
  # @param {Function|string} pageFunction
60
57
  # @param {!Array<*>} args
61
58
  def evaluate(page_function, *args)
62
59
  @main_world.evaluate(page_function, *args)
63
60
  end
64
61
 
62
+ define_async_method :async_evaluate
63
+
65
64
  # `$()` in JavaScript. $ is not allowed to use as a method name in Ruby.
66
65
  # @param {string} selector
67
66
  # @return {!Promise<?Puppeteer.ElementHandle>}
@@ -69,6 +68,7 @@ class Puppeteer::Frame
69
68
  @main_world.S(selector)
70
69
  end
71
70
 
71
+ define_async_method :async_S
72
72
 
73
73
  # `$x()` in JavaScript. $ is not allowed to use as a method name in Ruby.
74
74
  # @param {string} expression
@@ -77,6 +77,7 @@ class Puppeteer::Frame
77
77
  @main_world.Sx(expression)
78
78
  end
79
79
 
80
+ define_async_method :async_Sx
80
81
 
81
82
  # `$eval()` in JavaScript. $ is not allowed to use as a method name in Ruby.
82
83
  # @param {string} selector
@@ -87,6 +88,8 @@ class Puppeteer::Frame
87
88
  @main_world.Seval(selector, page_function, *args)
88
89
  end
89
90
 
91
+ define_async_method :async_Seval
92
+
90
93
  # `$$eval()` in JavaScript. $ is not allowed to use as a method name in Ruby.
91
94
  # @param {string} selector
92
95
  # @param {Function|string} pageFunction
@@ -96,6 +99,8 @@ class Puppeteer::Frame
96
99
  @main_world.SSeval(selector, page_function, *args)
97
100
  end
98
101
 
102
+ define_async_method :async_SSeval
103
+
99
104
  # `$$()` in JavaScript. $ is not allowed to use as a method name in Ruby.
100
105
  # @param {string} selector
101
106
  # @return {!Promise<!Array<!Puppeteer.ElementHandle>>}
@@ -103,12 +108,16 @@ class Puppeteer::Frame
103
108
  @main_world.SS(selector)
104
109
  end
105
110
 
111
+ define_async_method :async_SS
112
+
113
+ # @return [String]
106
114
  def content
107
115
  @secondary_world.content
108
116
  end
109
117
 
110
- # @param {string} html
111
- # @param {!{timeout?: number, waitUntil?: string|!Array<string>}=} options
118
+ # @param html [String]
119
+ # @param timeout [Integer]
120
+ # @param wait_until [String|Array<String>]
112
121
  def set_content(html, timeout: nil, wait_until: nil)
113
122
  @secondary_world.set_content(html, timeout: timeout, wait_until: wait_until)
114
123
  end
@@ -152,15 +161,6 @@ class Puppeteer::Frame
152
161
  @main_world.add_style_tag(style_tag)
153
162
  end
154
163
 
155
- # @param selector [String]
156
- # @param delay [Number]
157
- # @param button [String] "left"|"right"|"middle"
158
- # @param click_count [Number]
159
- # @return [Future]
160
- async def async_click(selector, delay: nil, button: nil, click_count: nil)
161
- click(selector, delay: delay, button: button, click_count: click_count)
162
- end
163
-
164
164
  # @param selector [String]
165
165
  # @param delay [Number]
166
166
  # @param button [String] "left"|"right"|"middle"
@@ -169,11 +169,15 @@ class Puppeteer::Frame
169
169
  @secondary_world.click(selector, delay: delay, button: button, click_count: click_count)
170
170
  end
171
171
 
172
+ define_async_method :async_click
173
+
172
174
  # @param {string} selector
173
175
  def focus(selector)
174
176
  @secondary_world.focus(selector)
175
177
  end
176
178
 
179
+ define_async_method :async_focus
180
+
177
181
  # @param {string} selector
178
182
  def hover(selector)
179
183
  @secondary_world.hover(selector)
@@ -186,11 +190,15 @@ class Puppeteer::Frame
186
190
  @secondary_world.select(selector, *values)
187
191
  end
188
192
 
193
+ define_async_method :async_select
194
+
189
195
  # @param {string} selector
190
196
  def tap(selector)
191
197
  @secondary_world.tap(selector)
192
198
  end
193
199
 
200
+ define_async_method :async_tap
201
+
194
202
  # @param selector [String]
195
203
  # @param text [String]
196
204
  # @param delay [Number]
@@ -198,27 +206,7 @@ class Puppeteer::Frame
198
206
  @main_world.type_text(selector, text, delay: delay)
199
207
  end
200
208
 
201
- # /**
202
- # * @param {(string|number|Function)} selectorOrFunctionOrTimeout
203
- # * @param {!Object=} options
204
- # * @param {!Array<*>} args
205
- # * @return {!Promise<?Puppeteer.JSHandle>}
206
- # */
207
- # waitFor(selectorOrFunctionOrTimeout, options = {}, ...args) {
208
- # const xPathPattern = '//';
209
-
210
- # if (helper.isString(selectorOrFunctionOrTimeout)) {
211
- # const string = /** @type {string} */ (selectorOrFunctionOrTimeout);
212
- # if (string.startsWith(xPathPattern))
213
- # return this.waitForXPath(string, options);
214
- # return this.waitForSelector(string, options);
215
- # }
216
- # if (helper.isNumber(selectorOrFunctionOrTimeout))
217
- # return new Promise(fulfill => setTimeout(fulfill, /** @type {number} */ (selectorOrFunctionOrTimeout)));
218
- # if (typeof selectorOrFunctionOrTimeout === 'function')
219
- # return this.waitForFunction(selectorOrFunctionOrTimeout, options, ...args);
220
- # return Promise.reject(new Error('Unsupported target type: ' + (typeof selectorOrFunctionOrTimeout)));
221
- # }
209
+ define_async_method :async_type_text
222
210
 
223
211
  # @param selector [String]
224
212
  # @param visible [Boolean] Wait for element visible (not 'display: none' nor 'visibility: hidden') on true. default to false.
@@ -235,6 +223,8 @@ class Puppeteer::Frame
235
223
  result
236
224
  end
237
225
 
226
+ define_async_method :async_wait_for_selector
227
+
238
228
  # @param xpath [String]
239
229
  # @param visible [Boolean] Wait for element visible (not 'display: none' nor 'visibility: hidden') on true. default to false.
240
230
  # @param hidden [Boolean] Wait for element invisible ('display: none' nor 'visibility: hidden') on true. default to false.
@@ -250,6 +240,8 @@ class Puppeteer::Frame
250
240
  result
251
241
  end
252
242
 
243
+ define_async_method :async_wait_for_xpath
244
+
253
245
  # @param {Function|string} pageFunction
254
246
  # @param {!{polling?: string|number, timeout?: number}=} options
255
247
  # @param {!Array<*>} args
@@ -258,6 +250,9 @@ class Puppeteer::Frame
258
250
  @main_world.wait_for_function(page_function, options, *args)
259
251
  end
260
252
 
253
+ define_async_method :async_wait_for_function
254
+
255
+ # @return [String]
261
256
  def title
262
257
  @secondary_world.title
263
258
  end