Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Iris 1289 - java, js native fps #3025

Merged
merged 16 commits into from
Dec 5, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 0 additions & 13 deletions docs/visual-testing/_partials/_fullpage-description.md

This file was deleted.

74 changes: 69 additions & 5 deletions docs/visual-testing/_partials/_fullpage-js.md
Original file line number Diff line number Diff line change
@@ -1,18 +1,33 @@
import FullPageDescription from './_fullpage-description.md';
import FullPageLimit from './_fullpage-limit.md';

<FullPageDescription />
By default, only the current viewport is captured when `.sauceVisualCheck` is used. You can opt in to capturing the entire page by using the `fullPage` option. It will capture everything by scrolling and stitching multiple screenshots together.
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved

<FullPageLimit />

#### Web

Options:

- `delayAfterScrollMs`: Delay in ms after scrolling and before taking screenshots. The default value is 0. We recommend using this option for lazy loading content.
- `disableCSSAnimation`: Disable CSS animations and the input caret in the app. The default value is true.
- `hideAfterFirstScroll`: One or more CSS selectors that we should remove from the page after the first scroll. Useful for hiding fixed elements such as headers, cookie banners, etc.

Check warning on line 13 in docs/visual-testing/_partials/_fullpage-js.md

View workflow job for this annotation

GitHub Actions / vale

[vale] docs/visual-testing/_partials/_fullpage-js.md#L13

[sauce.Simplicity] Remove 'Useful'. Be precise instead of subjective.
Raw output
{"message": "[sauce.Simplicity] Remove 'Useful'. Be precise instead of subjective.", "location": {"path": "docs/visual-testing/_partials/_fullpage-js.md", "range": {"start": {"line": 13, "column": 113}}}, "severity": "WARNING"}
- `hideScrollBars`: Hide all scrollbars in the app. The default value is true.
- `scrollLimit`: Limit the number of screenshots taken for scrolling and stitching. The default value is 10. The value needs to be between 1 and 10.

:::note
It's recommended to use the `hideAfterFirstScroll` option for fixed or sticky position elements such as sticky headers or consent banners.
:::

Example:

```ts
await browser.sauceVisualCheck('Long content page', {
// Enable full page screenshots using the default options
// Enable full page screenshot using the default options
fullPage: true,
});

await browser.sauceVisualCheck('Long content page', {
// Enable full page screenshots and customize the behavior
// Enable full page screenshot and customize the behavior
fullPage: {
delayAfterScrollMs: 500,
disableCSSAnimation: false,
Expand All @@ -23,4 +38,53 @@
});
```

<FullPageLimit />
#### Mobile Native (beta)

Check warning on line 41 in docs/visual-testing/_partials/_fullpage-js.md

View workflow job for this annotation

GitHub Actions / vale

[vale] docs/visual-testing/_partials/_fullpage-js.md#L41

[sauce.Headings] 'Mobile Native (beta)' should use title case capitalization.
Raw output
{"message": "[sauce.Headings] 'Mobile Native (beta)' should use title case capitalization.", "location": {"path": "docs/visual-testing/_partials/_fullpage-js.md", "range": {"start": {"line": 41, "column": 6}}}, "severity": "WARNING"}
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved

Options:

- `delayAfterScrollMs`: Delay in ms after scrolling and before taking screenshots. The default value is 0. We recommend using this option for lazy loading content.
- `nativeClipSelector`: Selector used to identify the first element to which clipping will be applied.
- `scrollElement`: Scrollable element used for scrolling. The default is root element.
- `scrollLimit`: Limit the number of screenshots taken for scrolling and stitching. The default value is 10. The value needs to be between 1 and 10.

:::note
It is recommended to define the `scrollElement` as the appropriate scrollable container.
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
:::

```ts
await browser.sauceVisualCheck('Long content page', {
// Enable full page screenshot and customize the behavior
fullPage: {
scrollElement: $('//XCUIElementTypeCollectionView'),
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
scrollLimit: 5
},
});
```

Use only XPath selectors for ignore regions and clipping to an element.

:::note
On iOS, selectors must be contained within the `scrollElement`.

Check warning on line 67 in docs/visual-testing/_partials/_fullpage-js.md

View workflow job for this annotation

GitHub Actions / vale

[vale] docs/visual-testing/_partials/_fullpage-js.md#L67

[sauce.WordList] Use 'in' instead of 'within'.
Raw output
{"message": "[sauce.WordList] Use 'in' instead of 'within'.", "location": {"path": "docs/visual-testing/_partials/_fullpage-js.md", "range": {"start": {"line": 67, "column": 37}}}, "severity": "WARNING"}
:::

```ts
await browser.sauceVisualCheck('Ignore regions - Long content page', {
// Enable full page screenshot and ignore elements
ignore: [
{ selector: { value: '//XCUIElementTypeCollectionView/XCUIElementTypeCell', type: 'XPATH' }}
],
fullPage: {
scrollElement: $('//XCUIElementTypeCollectionView'),
},
});
```

```ts
await browser.sauceVisualCheck('Clip - Long content page', {
// Enable full page screenshot and clip to an element
fullPage: {
scrollElement: $('//XCUIElementTypeCollectionView'),
nativeClipSelector: { value: '//XCUIElementTypeCollectionView/XCUIElementTypeOther', type: 'XPATH' }
},
});
```
94 changes: 89 additions & 5 deletions docs/visual-testing/integrations/java.md
Original file line number Diff line number Diff line change
Expand Up @@ -394,12 +394,12 @@

By default, only the current viewport is captured when `.sauceVisualCheck` is used. You can opt in to capturing the entire page by using the `enableFullPageScreenshots` option. It will capture everything by scrolling and stitching multiple screenshots together.

:::note
It's recommended to use the `withHideAfterFirstScroll` method for fixed or sticky position elements such as sticky headers or consent banners.
:::

Configuration should be specified using the `FullPageScreenshotConfig.Builder` object.

<FullPageLimit />

#### Web

Methods available:
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved

- `withDelayAfterScrollMs(int delayAfterScrollMs)`: Delay in ms after scrolling and before taking screenshots. The default value is 0. We recommend using this option for lazy loading content.
Expand All @@ -408,6 +408,10 @@
- `withHideScrollBars(Boolean hideScrollBars)`: Hide all scrollbars in the app. The default value is true.
- `withScrollLimit(int scrollLimit)`: Limit the number of screenshots taken for scrolling and stitching. The default value is 10. The value needs to be between 1 and 10.

:::note
It's recommended to use the `withHideAfterFirstScroll` method for fixed or sticky position elements such as sticky headers or consent banners.
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
:::

Examples:

```java
Expand All @@ -434,7 +438,87 @@
visual.sauceVisualCheck("Long content page", options);
```

<FullPageLimit />
#### Mobile Native (beta)

Check warning on line 441 in docs/visual-testing/integrations/java.md

View workflow job for this annotation

GitHub Actions / vale

[vale] docs/visual-testing/integrations/java.md#L441

[sauce.Headings] 'Mobile Native (beta)' should use title case capitalization.
Raw output
{"message": "[sauce.Headings] 'Mobile Native (beta)' should use title case capitalization.", "location": {"path": "docs/visual-testing/integrations/java.md", "range": {"start": {"line": 441, "column": 6}}}, "severity": "WARNING"}

Methods available:
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
- `withDelayAfterScrollMs(int delayAfterScrollMs)`: Delay in ms after scrolling and before taking screenshots. The default value is 0. We recommend using this option for lazy loading content.
- `withNativeClipSelector(SelectorIn nativeClipSelector)`: Selector used to identify the first element to which clipping will be applied.
- `withScrollElement(WebElement scrollElement)`: Scrollable element used for scrolling. The default is root element.
- `withScrollLimit(int scrollLimit)`: Limit the number of screenshots taken for scrolling and stitching. The default value is 10. The value needs to be between 1 and 10.

:::note
It is recommended to define the `withScrollElement` as the appropriate scrollable container.
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
:::

paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
```java
import com.saucelabs.visual.CheckOptions;
import com.saucelabs.visual.model.FullPageScreenshotConfig;

RemoteWebDriver driver;
...

WebElement scrollElement = driver.findElement(AppiumBy.xpath("//XCUIElementTypeCollectionView"));
CheckOptions options = new CheckOptions();
FullPageScreenshotConfig config = new FullPageScreenshotConfig.Builder()
.withScrollElement(scrollElement)
.withScrollLimit(5)
.build();
options.enableFullPageScreenshots(config);
visual.sauceVisualCheck("Long content page", options);
```

Use only XPath selectors for ignore regions and clipping to an element.
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved

:::note
On iOS, selectors must be contained within the `scrollElement`.

Check warning on line 473 in docs/visual-testing/integrations/java.md

View workflow job for this annotation

GitHub Actions / vale

[vale] docs/visual-testing/integrations/java.md#L473

[sauce.WordList] Use 'in' instead of 'within'.
Raw output
{"message": "[sauce.WordList] Use 'in' instead of 'within'.", "location": {"path": "docs/visual-testing/integrations/java.md", "range": {"start": {"line": 473, "column": 37}}}, "severity": "WARNING"}
:::
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved

```java
import com.saucelabs.visual.CheckOptions;
import com.saucelabs.visual.model.FullPageScreenshotConfig;

RemoteWebDriver driver;
...

WebElement scrollElement = driver.findElement(AppiumBy.xpath("//XCUIElementTypeCollectionView"));
CheckOptions options = new CheckOptions();
FullPageScreenshotConfig config = new FullPageScreenshotConfig.Builder()
.withScrollElement(scrollElement)
.build();
options.enableFullPageScreenshots(config);
List<IgnoreSelectorIn> ignoreSelectors = List.of(
new IgnoreSelectorIn.Builder()
.withSelector(
new SelectorIn.Builder()
.withValue(
"//XCUIElementTypeCollectionView//XCUIElementTypeStaticText")
.withType(SelectorType.XPATH)
.build())
.build());
options.setIgnoreSelectors(ignoreSelectors);
visual.sauceVisualCheck("Long content page", options);
```

```java
import com.saucelabs.visual.CheckOptions;
import com.saucelabs.visual.model.FullPageScreenshotConfig;

RemoteWebDriver driver;
...

WebElement scrollElement = driver.findElement(AppiumBy.xpath("//XCUIElementTypeCollectionView"));
CheckOptions options = new CheckOptions();
SelectorIn nativeClipSelector = new SelectorIn.Builder()
.withType(SelectorType.XPATH)
.withValue("//XCUIElementTypeCollectionView/XCUIElementTypeOther")
.build();
FullPageScreenshotConfig config = new FullPageScreenshotConfig.Builder()
.withScrollElement(scrollElement)
.withNativeClipSelector(nativeClipSelector)
.build();
options.enableFullPageScreenshots(config);
visual.sauceVisualCheck("Long content page", options);
```

### Clip to an Element

Expand Down
8 changes: 7 additions & 1 deletion docs/visual-testing/mobile-native-testing.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,12 @@
## Limitations
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved

The following features are not yet available for mobile app testing:
- Full page screenshots
- DOM capture and inspection
- [Selective diffing](./selective-diffing.md)

Native full page screenshots are in beta and may have bugs.
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
Possible issues include:
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
- Slow screenshot capture
- Baseline and snapshot differences on iOS tablets
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
- Ignoring and clipping limited to elements within scrollElement on iOS

Check warning on line 35 in docs/visual-testing/mobile-native-testing.md

View workflow job for this annotation

GitHub Actions / vale

[vale] docs/visual-testing/mobile-native-testing.md#L35

[sauce.WordList] Use 'in' instead of 'within'.
Raw output
{"message": "[sauce.WordList] Use 'in' instead of 'within'.", "location": {"path": "docs/visual-testing/mobile-native-testing.md", "range": {"start": {"line": 35, "column": 45}}}, "severity": "WARNING"}
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved
- Missing sticky elements at the bottom of the screen
paweltomaszewskisaucelabs marked this conversation as resolved.
Show resolved Hide resolved