From ea3eb80c384563231a53928bde3604ef8963d932 Mon Sep 17 00:00:00 2001 From: Pawel Tomaszewski Date: Wed, 4 Dec 2024 18:34:01 +0100 Subject: [PATCH 1/5] scroll to top before and after screenshot --- visual-js/visual/src/graphql/__generated__/graphql.ts | 9 +++++++++ visual-js/visual/src/types.ts | 10 +++++++++- 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/visual-js/visual/src/graphql/__generated__/graphql.ts b/visual-js/visual/src/graphql/__generated__/graphql.ts index d4b39fc7..fc9aff9f 100644 --- a/visual-js/visual/src/graphql/__generated__/graphql.ts +++ b/visual-js/visual/src/graphql/__generated__/graphql.ts @@ -1685,6 +1685,15 @@ export type RegionIn = { y: Scalars['Int']; }; +/** + * TOP - scroll before and after to top of the scrollElement + * CONTINUE - no scroll before and after + */ +export enum ScrollOption { + Continue = 'CONTINUE', + Top = 'TOP' +} + export type SelectorIn = { type: SelectorType; value: Scalars['String']; diff --git a/visual-js/visual/src/types.ts b/visual-js/visual/src/types.ts index 7c3ef785..953fb793 100644 --- a/visual-js/visual/src/types.ts +++ b/visual-js/visual/src/types.ts @@ -1,4 +1,8 @@ -import { RegionIn, SelectorIn } from './graphql/__generated__/graphql'; +import { + RegionIn, + ScrollOption, + SelectorIn, +} from './graphql/__generated__/graphql'; import { SelectiveRegionOptions } from './common/selective-region'; import { SauceRegion } from './common/regions'; @@ -34,6 +38,10 @@ export type FullPageScreenshotOptions = * Selector of an element that we should crop the screenshot to. Available only on native apps. */ nativeClipSelector?: SelectorIn; + /** + * Change scroll behaviour before and after taking full page screenshot. Available only on native apps. + */ + nativeScrollOptions?: ScrollOption; }; export type Ignorable = T | T[] | Promise | Promise | RegionIn; From 05c2c0d8c3d0c304adb19f552994a8c3f2b3c9a7 Mon Sep 17 00:00:00 2001 From: Pawel Tomaszewski Date: Wed, 4 Dec 2024 18:36:12 +0100 Subject: [PATCH 2/5] docs(changeset): Add scroll to top before and after native full page screenshot --- visual-js/.changeset/silent-jeans-reflect.md | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 visual-js/.changeset/silent-jeans-reflect.md diff --git a/visual-js/.changeset/silent-jeans-reflect.md b/visual-js/.changeset/silent-jeans-reflect.md new file mode 100644 index 00000000..cdce9873 --- /dev/null +++ b/visual-js/.changeset/silent-jeans-reflect.md @@ -0,0 +1,7 @@ +--- +"@saucelabs/visual": minor +"@saucelabs/nightwatch-sauce-visual-service": minor +"@saucelabs/wdio-sauce-visual-service": minor +--- + +Add scroll to top before and after native full page screenshot From 343428c5dc5b4e3501de98e7ee54cdc2347acf80 Mon Sep 17 00:00:00 2001 From: Pawel Tomaszewski Date: Mon, 9 Dec 2024 13:55:41 +0100 Subject: [PATCH 3/5] rename scrollOptions --- visual-js/visual/src/graphql/__generated__/graphql.ts | 2 ++ visual-js/visual/src/types.ts | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/visual-js/visual/src/graphql/__generated__/graphql.ts b/visual-js/visual/src/graphql/__generated__/graphql.ts index fc9aff9f..2a2f16df 100644 --- a/visual-js/visual/src/graphql/__generated__/graphql.ts +++ b/visual-js/visual/src/graphql/__generated__/graphql.ts @@ -983,6 +983,8 @@ export type FullPageConfigIn = { * Default and max value is 10 */ scrollLimit?: InputMaybe; + /** Change scroll behaviour before and after taking full page screenshot. Available only on native apps. */ + scrollOptions?: InputMaybe; }; /** A filter to be used against FullText fields. All fields are combined with a logical ‘and.’ */ diff --git a/visual-js/visual/src/types.ts b/visual-js/visual/src/types.ts index 953fb793..baffc891 100644 --- a/visual-js/visual/src/types.ts +++ b/visual-js/visual/src/types.ts @@ -41,7 +41,7 @@ export type FullPageScreenshotOptions = /** * Change scroll behaviour before and after taking full page screenshot. Available only on native apps. */ - nativeScrollOptions?: ScrollOption; + scrollOptions?: ScrollOption; }; export type Ignorable = T | T[] | Promise | Promise | RegionIn; From d3eafebe0a21237402213a478ede0e3da9927f10 Mon Sep 17 00:00:00 2001 From: Felix P Date: Wed, 18 Dec 2024 11:33:54 +0100 Subject: [PATCH 4/5] Update definitions + typo --- .../src/graphql/__generated__/graphql.ts | 101 ++++++++++++++++-- visual-js/visual/src/types.ts | 2 +- 2 files changed, 93 insertions(+), 10 deletions(-) diff --git a/visual-js/visual/src/graphql/__generated__/graphql.ts b/visual-js/visual/src/graphql/__generated__/graphql.ts index 2a2f16df..93165d55 100644 --- a/visual-js/visual/src/graphql/__generated__/graphql.ts +++ b/visual-js/visual/src/graphql/__generated__/graphql.ts @@ -60,7 +60,7 @@ export type Baseline = Node & { appName: Maybe; appVersion: Maybe; branch: Maybe; - browser: Maybe; + browser: Browser; browserVersion: Maybe; createdAt: Scalars['Datetime']; createdByOrgId: Scalars['UUID']; @@ -82,10 +82,12 @@ export type Baseline = Node & { name: Scalars['String']; /** A globally unique identifier. Can be used in various places throughout the system to identify this single value. */ nodeId: Scalars['ID']; - operatingSystem: Maybe; + operatingSystem: OperatingSystem; operatingSystemVersion: Maybe; parentId: Maybe; project: Maybe; + smartSuiteName: Scalars['String']; + smartTestName: Scalars['String']; /** Reads a single `Snapshot` that is related to this `Baseline`. */ snapshot: Maybe; snapshotId: Maybe; @@ -645,6 +647,8 @@ export type CreateSnapshotFromWebDriverIn = { captureDom?: InputMaybe; /** The selenium ID of an element we should clip the screen to. */ clipElement?: InputMaybe; + /** @deprecated(reason: "clipElement should be used instead.") */ + clipSelector?: InputMaybe; diffingMethod?: InputMaybe; diffingOptions?: InputMaybe; /** @@ -708,6 +712,7 @@ export type Diff = Node & { diffingMethod: DiffingMethod; /** snapshot { uploadId } should be requested at the same moment */ domDiffUrl: Maybe; + feedback: DiffFeedback; hasDom: Scalars['Boolean']; id: Scalars['UUID']; /** A globally unique identifier. Can be used in various places throughout the system to identify this single value. */ @@ -779,6 +784,39 @@ export type DiffCountIn = { withBaseline?: InputMaybe; }; +export type DiffFeedback = { + __typename?: 'DiffFeedback'; + hasIrrelevantChanges: Scalars['Boolean']; + isBroken: Scalars['Boolean']; +}; + +/** A connection to a list of `DiffFeedback` values. */ +export type DiffFeedbacksConnection = { + __typename?: 'DiffFeedbacksConnection'; + /** A list of edges which contains the `DiffFeedback` and cursor to aid in pagination. */ + edges: Array; + /** A list of `DiffFeedback` objects. */ + nodes: Array; + /** Information to aid in pagination. */ + pageInfo: PageInfo; + /** The count of *all* `DiffFeedback` you could get from the connection. */ + totalCount: Scalars['Int']; +}; + +/** A `DiffFeedback` edge in the connection. */ +export type DiffFeedbacksEdge = { + __typename?: 'DiffFeedbacksEdge'; + /** A cursor for use in pagination. */ + cursor: Maybe; + /** The `DiffFeedback` at the end of the edge. */ + node: DiffFeedback; +}; + +/** Methods to use when ordering `DiffFeedback`. */ +export enum DiffFeedbacksOrderBy { + Natural = 'NATURAL' +} + /** A filter to be used against `Diff` object types. All fields are combined with a logical ‘and.’ */ export type DiffFilter = { /** Filter by the object’s `baselineId` field. */ @@ -984,7 +1022,7 @@ export type FullPageConfigIn = { */ scrollLimit?: InputMaybe; /** Change scroll behaviour before and after taking full page screenshot. Available only on native apps. */ - scrollOptions?: InputMaybe; + scrollOption?: InputMaybe; }; /** A filter to be used against FullText fields. All fields are combined with a logical ‘and.’ */ @@ -997,6 +1035,8 @@ export enum GroupByOption { Browser = 'Browser', Device = 'Device', OperatingSystemOperatingSystemVersion = 'OperatingSystem_OperatingSystemVersion', + SmartSuiteName = 'SmartSuiteName', + SmartTestName = 'SmartTestName', SuiteName = 'SuiteName', TestName = 'TestName' } @@ -1036,6 +1076,7 @@ export type MergeBaselinesPayload = { export type Mutation = { __typename?: 'Mutation'; addComment: Comment; + /** @deprecated Use setDiffStatus */ approveBuild: Build; createBuild: Build; /** @@ -1050,7 +1091,10 @@ export type Mutation = { finishBuild: Build; forceFinishBuild: Maybe; mergeBaselines: MergeBaselinesPayload; + setDiffFeedback: Diff; + setDiffStatus: Array; updateComment: Comment; + /** @deprecated Use setDiffStatus */ updateDiff: Diff; }; @@ -1121,6 +1165,18 @@ export type MutationMergeBaselinesArgs = { }; +/** The root mutation type which contains root level fields which mutate data. */ +export type MutationSetDiffFeedbackArgs = { + input: SetDiffFeedbackIn; +}; + + +/** The root mutation type which contains root level fields which mutate data. */ +export type MutationSetDiffStatusArgs = { + input: SetDiffStatusIn; +}; + + /** The root mutation type which contains root level fields which mutate data. */ export type MutationUpdateCommentArgs = { input: UpdateCommentIn; @@ -1143,6 +1199,7 @@ export enum OperatingSystem { Ios = 'IOS', Linux = 'LINUX', Macos = 'MACOS', + Unknown = 'UNKNOWN', Windows = 'WINDOWS' } @@ -1370,6 +1427,8 @@ export type Query = Node & { diff: Maybe; /** Reads a single `Diff` using its globally unique `ID`. */ diffByNodeId: Maybe; + /** Reads and enables pagination through a set of `DiffFeedback`. */ + diffFeedbacks: Maybe; /** Reads and enables pagination through a set of `Diff`. */ diffs: Maybe; /** @@ -1550,6 +1609,17 @@ export type QueryDiffByNodeIdArgs = { }; +/** The root query type which gives access points into the data universe. */ +export type QueryDiffFeedbacksArgs = { + after: InputMaybe; + before: InputMaybe; + first: InputMaybe; + last: InputMaybe; + offset: InputMaybe; + orderBy?: InputMaybe>; +}; + + /** The root query type which gives access points into the data universe. */ export type QueryDiffsArgs = { after: InputMaybe; @@ -1688,12 +1758,12 @@ export type RegionIn = { }; /** - * TOP - scroll before and after to top of the scrollElement - * CONTINUE - no scroll before and after + * START_FROM_TOP - scroll before and after to top of the scrollElement + * START_FROM_CURRENT_LOCATION - no scroll before and after */ export enum ScrollOption { - Continue = 'CONTINUE', - Top = 'TOP' + StartFromCurrentLocation = 'START_FROM_CURRENT_LOCATION', + StartFromTop = 'START_FROM_TOP' } export type SelectorIn = { @@ -1705,6 +1775,17 @@ export enum SelectorType { Xpath = 'XPATH' } +export type SetDiffFeedbackIn = { + diffId: Scalars['UUID']; + hasIrrelevantChanges: Scalars['Boolean']; + isBroken: Scalars['Boolean']; +}; + +export type SetDiffStatusIn = { + diffIds: Array; + status: UpdateDiffStatus; +}; + export type Snapshot = Node & { __typename?: 'Snapshot'; appId: Maybe; @@ -1713,7 +1794,7 @@ export type Snapshot = Node & { /** Reads and enables pagination through a set of `Baseline`. */ baselines: BaselinesConnection; branch: Maybe; - browser: Maybe; + browser: Browser; browserVersion: Maybe; /** Reads a single `Build` that is related to this `Snapshot`. */ build: Maybe; @@ -1753,8 +1834,10 @@ export type Snapshot = Node & { name: Scalars['String']; /** A globally unique identifier. Can be used in various places throughout the system to identify this single value. */ nodeId: Scalars['ID']; - operatingSystem: Maybe; + operatingSystem: OperatingSystem; operatingSystemVersion: Maybe; + smartSuiteName: Scalars['String']; + smartTestName: Scalars['String']; suiteName: Maybe; testName: Maybe; thumbnailUrl: Scalars['String']; diff --git a/visual-js/visual/src/types.ts b/visual-js/visual/src/types.ts index baffc891..84572b13 100644 --- a/visual-js/visual/src/types.ts +++ b/visual-js/visual/src/types.ts @@ -41,7 +41,7 @@ export type FullPageScreenshotOptions = /** * Change scroll behaviour before and after taking full page screenshot. Available only on native apps. */ - scrollOptions?: ScrollOption; + scrollOption?: ScrollOption; }; export type Ignorable = T | T[] | Promise | Promise | RegionIn; From 2d5525a3b74d6d9440534390411d717ad967f4f1 Mon Sep 17 00:00:00 2001 From: Felix P Date: Wed, 18 Dec 2024 11:40:38 +0100 Subject: [PATCH 5/5] Enhance changelog --- visual-js/.changeset/silent-jeans-reflect.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/visual-js/.changeset/silent-jeans-reflect.md b/visual-js/.changeset/silent-jeans-reflect.md index cdce9873..0665695a 100644 --- a/visual-js/.changeset/silent-jeans-reflect.md +++ b/visual-js/.changeset/silent-jeans-reflect.md @@ -4,4 +4,4 @@ "@saucelabs/wdio-sauce-visual-service": minor --- -Add scroll to top before and after native full page screenshot +Added control over scrolling to the top before and after capturing a native full-page screenshot. \ No newline at end of file