PuppeteerSharp.Contrib.PageObjects
7.0.0
dotnet add package PuppeteerSharp.Contrib.PageObjects --version 7.0.0
NuGet\Install-Package PuppeteerSharp.Contrib.PageObjects -Version 7.0.0
<PackageReference Include="PuppeteerSharp.Contrib.PageObjects" Version="7.0.0" />
paket add PuppeteerSharp.Contrib.PageObjects --version 7.0.0
#r "nuget: PuppeteerSharp.Contrib.PageObjects, 7.0.0"
// Install PuppeteerSharp.Contrib.PageObjects as a Cake Addin #addin nuget:?package=PuppeteerSharp.Contrib.PageObjects&version=7.0.0 // Install PuppeteerSharp.Contrib.PageObjects as a Cake Tool #tool nuget:?package=PuppeteerSharp.Contrib.PageObjects&version=7.0.0
PuppeteerSharp.Contrib.PageObjects
PuppeteerSharp.Contrib.PageObjects
is a library for writing browser tests using the page object pattern with the Puppeteer Sharp API.
Content
- Page Objects
- Element Objects
- Selector Attributes
- Extensions for
IPage
- Extensions for
IElementHandle
- Samples
- Further Reading
Page Objects
A page object wraps an PuppeteerSharp.IPage
and should encapsulate the way tests interact with a web page.
Create page objects by inheriting PageObject
and declare properties decorated with [Selector]
attributes.
public class GitHubStartPage : PageObject
{
[Selector("main h1")]
public virtual Task<IElementHandle> Heading { get; }
[Selector("header")]
public virtual Task<GitHubHeader> Header { get; }
public async Task<GitHubSearchPage> SearchAsync(string text)
{
var task = Page.WaitForNavigationAsync<GitHubSearchPage>();
await (await Header).SearchAsync(text);
return await task;
}
}
Element Objects
An element object wraps an PuppeteerSharp.IElementHandle
and should encapsulate the way tests interact with an element of a web page.
Create element objects by inheriting ElementObject
and declare properties decorated with [Selector]
attributes.
public class GitHubHeader : ElementObject
{
[Selector("#query-builder-test")]
public virtual Task<IElementHandle> SearchInput { get; }
public async Task SearchAsync(string text)
{
var input = await SearchInput;
if (await input.IsHiddenAsync())
{
await Page.ClickAsync("[aria-label=\"Toggle navigation\"][data-view-component=\"true\"]");
await Page.ClickAsync("[data-target=\"qbsearch-input.inputButtonText\"]");
}
await input.TypeAsync(text);
await input.PressAsync(Key.Enter);
await Page.WaitForSelectorAsync("[data-testid=\"results-list\"]");
}
}
Selector Attributes
[Selector]
attributes can be applied to properties on a PageObject
or ElementObject
.
Properties decorated with a [Selector]
attribute must be a:
- public
- virtual
- asynchronous
- getter
that returns:
Task<IElementHandle>
Task<IElementHandle[]>
Task<ElementObject>
orTask<ElementObject[]>
Example:
[Selector("#foo")]
public virtual Task<IElementHandle> SelectorForElementHandle { get; }
[Selector(".bar")]
public virtual Task<IElementHandle[]> SelectorForElementHandleArray { get; }
[Selector("#foo")]
public virtual Task<FooElementObject> SelectorForElementObject { get; }
[Selector(".bar")]
public virtual Task<BarElementObject[]> SelectorForElementObjectArray { get; }
Extensions for IPage
Where T
is a PageObject
:
GoBackAsync<T>
GoForwardAsync<T>
GoToAsync<T>
ReloadAsync<T>
To<T>
WaitForNavigationAsync<T>
WaitForResponseAsync<T>
Where T
is an ElementObject
:
QuerySelectorAllAsync<T>
QuerySelectorAsync<T>
WaitForSelectorAsync<T>
WaitForXPathAsync<T>
XPathAsync<T>
Extensions for IElementHandle
Where T
is an ElementObject
:
QuerySelectorAllAsync<T>
QuerySelectorAsync<T>
To<T>
WaitForSelectorAsync<T>
XPathAsync<T>
Samples
A sample project with NUnit
is located in the samples
folder:
PageObjects.cs
contains the page and element objectsPuppeteerSharpRepoPageObjectTests.cs
contains the tests using the page object pattern
Further Reading
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- Castle.Core (>= 5.1.1)
- PuppeteerSharp (>= 20.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
🎯 Change TargetFramework to net8.0
⬆️ Bump PuppeteerSharp to 20.0.0