Chrome v132 and later no longer support old
headless mode. As such, chromote
no longer defaults to
using --headless=old
and now uses --headless
when running Chrome. You can still use the
chromote.headless
option or CHROMOTE_HEADLESS
environment variable to configure the --headless
flag if
you’re using an older version of Chrome. (#187)
Added chromote_info()
, a new utility function to
print out key information about chromote and Chrome. Useful when
debugging chromote or reporting an issue. (#190)
chromote now uses a consistent prefix for logs, e.g
{tempdir}/chrome-{id}-stdout.log
and
{tempdir}/chrome-{id}-stderr.log
. chromote also now uses
--crash-dumps-dir
to set a session-specific temp directory.
(#194)
launch_chrome()
to throw an
error. (#175)The headless mode used by Chrome can now be selected with the
chromote.headless
option or CHROMOTE_HEADLESS
environment variable.
In Chrome v128, a new headless mode became the default. The new mode uses the same browser engine as the regular Chrome browser, whereas the old headless mode is built on a separate architecture. The old headless mode may be faster to launch and is still well-suited to many of the tasks for which chromote is used.
For now, to avoid disruption, chromote defaults to using the old
headless mode. In the future, chromote will follow Chrome and default to
"new"
headless mode. (And at some point, Chrome intends to
remove the old headless mode which is now offered as a
separate binary.) To test the new headless mode, use
options(chromote.headless = "new")
or
CHROMOTE_HEADLESS="new"
(in .Renviron
or via
Sys.setenv()
). (#172)
Chromote$is_active()
method now
reports if there is an active connection to the underlying chrome
instance, rather than whether or not that instance is alive (#94).Chromote
and ChromoteSession
gain print
methods to give you a snapshot of the most important values
(#140).
Chromote
gains a new is_alive()
method
equivalent to the old is_active()
method; i.e. it reports
on if there is an active chrome process running in the background
(#136).
ChromoteSession
now records the
targetId
. This eliminates one round-trip to the browser
when viewing or closing a session. You can now call the
$respawn()
method if a session terminates and you want to
reconnect to the same target (#94).
ChromoteSession$screenshot()
gains an
options
argument that accepts a list of additional options
to be passed to the Chrome Devtools Protocol’s Page.captureScreenshot
method (#129).
ChromoteSession$screenshot()
will now infer the
image format from the filename
extension. Alternatively,
you can specify the format
in the list passed to
options
(#130).
--disable-gpu
is no longer included in the default
Chrome arguments, except on windows where empirically it appears to be
necessary (otherwise GHA check runs never terminate) (#142).
Fixed #109: An error would occur when a Chromote
object’s $close()
method was called. (#110)
Fixed #99: When the $view()
method was called,
recent versions of Chrome would display
"Debugging connection was closed. Reason: WebSocket disconnected"
.
(#101)
Fixed #89, #91: find_chrome()
now checks more
possible binary names for Chrome or Chromium on Linux and Mac. (thanks
@brianmsm and @rossellhayes,
#117)
Fixed #22: Added a new chromote.timeout
global
option that can be used to set the timeout (in seconds) for establishing
connections with the Chrome session. (#120)