org.openqa.selenium.devtools.v120.headlessexperimental.HeadlessExperimental Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of selenium-devtools-v120 Show documentation
Show all versions of selenium-devtools-v120 Show documentation
Selenium automates browsers. That's it! What you do with that power is entirely up to you.
package org.openqa.selenium.devtools.v120.headlessexperimental;
import org.openqa.selenium.Beta;
import org.openqa.selenium.devtools.Command;
import org.openqa.selenium.devtools.Event;
import org.openqa.selenium.devtools.ConverterFunctions;
import java.util.Map;
import java.util.LinkedHashMap;
import org.openqa.selenium.json.JsonInput;
/**
* This domain provides experimental commands only supported in headless mode.
*/
@Beta()
public class HeadlessExperimental {
public static class BeginFrameResponse {
private final java.lang.Boolean hasDamage;
private final java.util.Optional screenshotData;
public BeginFrameResponse(java.lang.Boolean hasDamage, java.util.Optional screenshotData) {
this.hasDamage = java.util.Objects.requireNonNull(hasDamage, "hasDamage is required");
this.screenshotData = screenshotData;
}
/**
* Whether the BeginFrame resulted in damage and, thus, a new frame was committed to the
* display. Reported for diagnostic uses, may be removed in the future.
*/
public java.lang.Boolean getHasDamage() {
return hasDamage;
}
/**
* Base64-encoded image data of the screenshot, if one was requested and successfully taken.
*/
public java.util.Optional getScreenshotData() {
return screenshotData;
}
private static BeginFrameResponse fromJson(JsonInput input) {
java.lang.Boolean hasDamage = false;
java.util.Optional screenshotData = java.util.Optional.empty();
input.beginObject();
while (input.hasNext()) {
switch(input.nextName()) {
case "hasDamage":
hasDamage = input.nextBoolean();
break;
case "screenshotData":
screenshotData = java.util.Optional.ofNullable(input.nextString());
break;
default:
input.skipValue();
break;
}
}
input.endObject();
return new BeginFrameResponse(hasDamage, screenshotData);
}
}
/**
* Sends a BeginFrame to the target and returns when the frame was completed. Optionally captures a
* screenshot from the resulting frame. Requires that the target was created with enabled
* BeginFrameControl. Designed for use with --run-all-compositor-stages-before-draw, see also
* https://goo.gle/chrome-headless-rendering for more background.
*/
public static Command beginFrame(java.util.Optional frameTimeTicks, java.util.Optional interval, java.util.Optional noDisplayUpdates, java.util.Optional screenshot) {
LinkedHashMap params = new LinkedHashMap<>();
frameTimeTicks.ifPresent(p -> params.put("frameTimeTicks", p));
interval.ifPresent(p -> params.put("interval", p));
noDisplayUpdates.ifPresent(p -> params.put("noDisplayUpdates", p));
screenshot.ifPresent(p -> params.put("screenshot", p));
return new Command<>("HeadlessExperimental.beginFrame", Map.copyOf(params), input -> input.read(org.openqa.selenium.devtools.v120.headlessexperimental.HeadlessExperimental.BeginFrameResponse.class));
}
/**
* Disables headless events for the target.
*/
@Deprecated()
public static Command disable() {
LinkedHashMap params = new LinkedHashMap<>();
return new Command<>("HeadlessExperimental.disable", Map.copyOf(params));
}
/**
* Enables headless events for the target.
*/
@Deprecated()
public static Command enable() {
LinkedHashMap params = new LinkedHashMap<>();
return new Command<>("HeadlessExperimental.enable", Map.copyOf(params));
}
}