An open API service indexing awesome lists of open source software.

https://github.com/visual-regression-tracker/sdk-js


https://github.com/visual-regression-tracker/sdk-js

javascript

Last synced: 12 months ago
JSON representation

Awesome Lists containing this project

README

          

# JS SDK for [Visual Regression Tracker](https://github.com/Visual-Regression-Tracker/Visual-Regression-Tracker)

[![Coverage](https://sonarcloud.io/api/project_badges/measure?project=Visual-Regression-Tracker_sdk-js&metric=coverage)](https://sonarcloud.io/summary/new_code?id=Visual-Regression-Tracker_sdk-js)
[![Code Smells](https://sonarcloud.io/api/project_badges/measure?project=Visual-Regression-Tracker_sdk-js&metric=code_smells)](https://sonarcloud.io/summary/new_code?id=Visual-Regression-Tracker_sdk-js)

## Npm

https://www.npmjs.com/package/@visual-regression-tracker/sdk-js

## Install

`npm install @visual-regression-tracker/sdk-js`

## Usage

### Import

```js
import {
VisualRegressionTracker,
Config,
} from "@visual-regression-tracker/sdk-js";
```

### Configure

#### Explicit config from code

```js
const config: Config = {
// URL where backend is running
// Required
apiUrl: "http://localhost:4200",

// Project name or ID
// Required
project: "Default project",

// User apiKey
// Required
apiKey: "tXZVHX0EA4YQM1MGDD",

// Current git branch
// Required
branchName: "develop",

// Log errors instead of throwing exceptions
// Optional - default false
enableSoftAssert: true,

// Unique ID related to one CI build
// Optional - default null
ciBuildId: "SOME_UNIQUE_ID",
};
```

#### Or, as JSON config file `vrt.json`

_Used only if not explicit config provided_
_Is overriden if ENV variables are present_

```json
{
"apiUrl": "http://localhost:4200",
"project": "Default project",
"apiKey": "tXZVHX0EA4YQM1MGDD",
"ciBuildId": "commit_sha",
"branchName": "develop",
"enableSoftAssert": false
}
```

#### Or, as environment variables

_Used only if not explicit config provided_

```
VRT_APIURL="http://localhost:4200"
VRT_PROJECT="Default project"
VRT_APIKEY="tXZVHX0EA4YQM1MGDD"
VRT_CIBUILDID="commit_sha"
VRT_BRANCHNAME="develop"
VRT_ENABLESOFTASSERT=true
```

### Setup

```js
vrt.start();
```

### Teardown

```js
vrt.stop();
```

### Assert

```js
await vrt.track({
// Name to be displayed
// Required
name: "Image name",

// Base64 encoded string
// Required or use imagePath
imageBase64: image,

// Path to image (service version api:4.14.0 or higher is required)
// Required or use imageBase64
imagePath: image,

// Allowed mismatch % (mismatched pixels to overal pixels count)
// Optional
diffTollerancePercent: 0,

// Optional
os: "Mac",

// Optional
browser: "Chrome",

// Optional
viewport: "800x600",

// Optional
device: "PC",

// Optional
customTags: "Cloud, DarkTheme, Auth",

// Array of areas to be ignored
// Optional
ignoreAreas: [
{
// X-coordinate relative of left upper corner
// Required
x: 10;

// Y-coordinate relative of left upper corner
// Required
y: 20;

// Area width in px
// Required
width: 300;

// Height width in px
// Required
height: 400;
}
]

// Allow additional details
// Optional
comment: 'Ignoring region because of animation'
});
```