FrameEnvironment

A FrameEnvironment represents a browsing context which allows you to interact with a Document in the page just like an iFrame or Frame in a normal HTML Document. A FrameEnvironment is one of many in a Tab that controls a document with its own page lifecycle and resources. Many of the FrameEnvironment methods for the "main" document are available from the Tab object.

Constructor

Frames cannot be constructed in SecretAgent. They're made available through the tab.frameEnvironments array.

Properties

frameEnvironment.children

Returns child FrameEnvironments for this frame.

Type: Promise<FrameEnvironment[]>

Returns a CookieStorage instance to get/set/delete cookies.

Type: CookieStorage

frameEnvironment.document
W3C

Returns a reference to the document of the frameEnvironment.

Type: SuperDocument

frameEnvironment.frameId

An identifier for the frameEnvironment.

Type: Promise<string>

frameEnvironment.lastCommandId

An execution point that refers to a command run on this Agent instance (waitForElement, click, type, etc). Command ids can be passed to select waitFor* functions to indicate a starting point to listen for changes.

Type: Promise<number>

frameEnvironment.localStorage
W3C

Returns a reference to the Storage object managing localStorage for the frameEnvironment.

Type: Storage

frameEnvironment.parentFrameId

An identifier for the parent frame, if it exists. null for the main FrameEnvironment.

Type: Promise<string>

frameEnvironment.name

Returns the name given to the frame DOM element. NOTE: this name is not populated until the frame has navigated to the destination url.

Type: Promise<string>

frameEnvironment.sessionStorage
W3C

Returns a reference to the Storage object managing sessionStorage for the frameEnvironment.

Type: Storage

frameEnvironment.url

The url of the active frameEnvironment.

Type: Promise<string>

frameEnvironment.Request
W3C

Returns a constructor for a Request object that can be sent to frameEnvironment.fetch(request).

const { Request, fetch } = agent;
const url = 'https://dataliberationfoundation.org';
const request = new Request(url, {
  headers: {
    'X-From': 'https://secretagent.dev',
  },
});
const response = await fetch(request);

Type: Request

Methods

frameEnvironment.fetch(requestInput, requestInit)
W3C

Perform a native "fetch" request in the current frame environment.

Arguments:

  • requestInput IRequestInput A Request object or url.
  • requestInit IRequestInit? Optional request initialization parameters. Follows w3c specification.
    • Inbound Body currently supports: string, ArrayBuffer, null.
    • Not supported: Blob, FormData, ReadableStream, URLSearchParams

Returns: Promise<Response>

const origin = 'https://dataliberationfoundation.org/';
const getUrl = 'https://dataliberationfoundation.org/mission';

await agent.goto(origin);
const mainFrame = agent.mainFrameEnvironment;
const response = await mainFrame.fetch(getUrl);

Http Post example with a body:

const origin = 'https://dataliberationfoundation.org/';
const postUrl = 'https://dataliberationfoundation.org/nopost';

await agent.goto(origin);
const mainFrame = agent.mainFrameEnvironment;
const response = await mainFrame.fetch(postUrl, {
  method: 'post',
  headers: {
    Authorization: 'Basic ZWx1c3VhcmlvOnlsYWNsYXZl',
  },
  body: JSON.stringify({
    ...params,
  }),
});

frameEnvironment.getFrameEnvironment(frameElement)

Get the FrameEnvironment object corresponding to the provided HTMLFrameElement or HTMLIFrameElement. Use this function to attach to the full environment of the given DOM element.

Arguments:

  • element SuperElement A frame or iframe element loaded in this frame environment (ie, a direct child element of this frame document).

Returns: Promise<Frame>

await agent.goto('https://developer.mozilla.org/en-US/docs/Web/HTML/Element/iframe');
const { document } = agent.activeTab;
const iframeElement = document.querySelector('iframe.interactive');

const iframe = await agent.getFrameEnvironment(iframeElement);

const h4 = await iframe.document.querySelector('h4').textContent; // should be something like HTML demo: <iframe>

frameEnvironment.getComputedStyle(element, pseudoElement)
W3C

Perform a native Window.getComputedStyle request in the current frame context - it returns an object containing the values of all CSS properties of an element, after applying active stylesheets and resolving any basic computation those values may contain. Individual CSS property values are accessed through APIs provided by the object, or by indexing with CSS property names.

Arguments:

  • element SuperElement An element loaded in this frame environment.
  • pseudoElement string? Optional string specifying the pseudo-element to match (eg, ::before, ::after, etc). More information can be found on w3c.

Returns: Promise<CssStyleDeclaration>

await agent.goto('https://dataliberationfoundation.org');
const { document, getComputedStyle } = agent.activeTab;
const selector = document.querySelector('h1');
const style = await getComputedStyle(selector);
const opacity = await style.getProperty('opacity');

frameEnvironment.getComputedVisibility(element)

Determines if a node from the mainFrameEnvironment is visible to an end user. This method checks whether a node (or containing element) has:

  • layout: width, height, x and y.
  • opacity: non-zero opacity.
  • css visibility: the element does not have a computed style where visibility=hidden.
  • no overlay: no other element which overlays more than one fourth of this element and has at least 1 pixel over the center of the element.
  • on the visible screen (not beyond the horizontal or vertical viewport)

Alias for tab.mainFrameEnvironment.getComputedVisibility.

Arguments:

  • node SuperNode. The node to compute visibility.

Returns: Promise<INodeVisibility> Boolean values indicating if the node (or closest element) is visible to an end user.

  • INodeVisibility object
    • isVisible boolean. Is the node ultimately visible (convenience sum of other properties).
    • isFound boolean. Was the node found in the DOM.
    • isOnscreenVertical boolean. The node is on-screen vertically.
    • isOnscreenHorizontal boolean. The node is on-screen horizontally.
    • hasContainingElement boolean. The node is an element or has a containing Element providing layout.
    • isConnected boolean. The node is connected to the DOM.
    • hasCssOpacity boolean. The display opacity property is not "0".
    • hasCssDisplay boolean. The display display property is not "none".
    • hasCssVisibility boolean. The visibility style property is not "hidden".
    • hasDimensions boolean. The node has width and height.
    • isUnobstructedByOtherElements boolean. The node is not hidden or obscured > 50% by another element.

frameEnvironment.getJsValue(path)

Extract any publicly accessible javascript value from the FrameEnvironment.

Arguments:

  • path string

Returns: Promise<SerializedValue>

await agent.goto('https://dataliberationfoundation.org');
const navigatorAgent = await agent.activeFrame.getJsValue(`navigator.userAgent`);

frameEnvironment.isElementVisible(element)

Determines if an element is visible to an end user. This method checks whether an element has:

  • layout: width, height, x and y.
  • opacity: non-zero opacity.
  • css visibility: the element does not have a computed style where visibility=hidden.
  • no overlay: no other element which overlays more than one fourth of this element and has at least 1 pixel over the center of the element.

Arguments:

Returns: Promise<boolean> Whether the element is visible to an end user.

frameEnvironment.waitForPaintingStable(options)

Wait for the page to be loaded such that a user can see the main content above the fold, including on javascript-rendered pages (eg, Single Page Apps). This load event works around deficiencies in using the Document "load" event, which does not always trigger, and doesn't work for Single Page Apps.

NOTE: this method should NOT be called in a Frame Document that has no visible elements.

Arguments:

  • options object Optional
    • timeoutMs number. Timeout in milliseconds. Default 30,000.
    • sinceCommandId number. A commandId from which to look for load status changes.

Returns: Promise<void>

frameEnvironment.waitForElement(element, options)

Wait until a specific element is present in the dom.

Arguments:

  • element SuperElement
  • options object Accepts any of the following:
    • timeoutMs number. Timeout in milliseconds. Default 30,000.
    • waitForVisible boolean. Wait until this element is visible to a user (see getComputedVisibility.

Returns: Promise

If at the moment of calling this method, the selector already exists, the method will return immediately.

const { activeTab, document } = agent;

const elem = document.querySelector('a.visible');
await activeFrame.waitForElement(elem, {
  waitForVisible: true,
});

frameEnvironment.waitForLoad(status, options)

Wait for the load status to occur on a page.

Arguments:

  • status NavigationRequested | HttpRequested | HttpResponsed | HttpRedirected | DomContentLoaded | PaintingStable The load status event to wait for.
  • options object
    • timeoutMs number. Timeout in milliseconds. Default 30,000.
    • sinceCommandId number. A commandId from which to look for status changed.

Returns: Promise<void>

The following are possible statuses and their meanings:

StatusDescription
NavigationRequestedA navigation request is initiated by the page or user
HttpRequestedThe http request for the document has been initiated
HttpRespondedThe http response has been retrieved
HttpRedirectedThe original http request was redirected
DomContentLoadedThe dom content has been received and loaded into the document
AllContentLoadedThe page load event has triggered. NOTE: this does not ALWAYS trigger in browser.
PaintingStableThe page has loaded the main content above the fold. Works on javascript-rendered pages.

frameEnvironment.waitForLocation(trigger, options)

Waits for a navigational change to document.location either because of a reload event or changes to the URL.

Arguments:

  • trigger change | reload The same url has been reloaded, or it's a new url.
  • options object
    • timeoutMs number. Timeout in milliseconds. Default 30,000.
    • sinceCommandId number. A commandId from which to look for changes.

Returns: Promise<Resource>

Location changes are triggered in one of two ways:

TriggerDescription
changeA navigational change to document.location has been triggered.
reloadA reload of the current document.location has been triggered.

The following example waits for a new page to load after clicking on an anchor tag:

const { user, activeTab, document } = agent;
await activeFrame.goto('http://example.com');

await user.click(document.querySelector('a'));
await activeFrame.waitForLocation('change');

const newUrl = await activeFrame.url;

Edit this page on GitHub