-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathtest.ts
86 lines (80 loc) · 2.3 KB
/
test.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
const backstop = require('backstopjs')
import { ok } from 'assert'
import { store, Selector } from './src/store'
import commander from 'commander'
import { register } from './src/register'
commander
.version('1.0.0')
.option('--approve', 'Approve the last screenshot')
.option('--test', 'Test the current website')
.option('--hostname <hostname>', 'Hostname')
.parse(process.argv)
ok(commander.hostname, 'Please provide a hostname such as --hostname http://localhost:3000')
ok(commander.approve || commander.test, 'Please provide either --approve or --test')
function renderPage(siteUrl: string): string[] {
register(store)
const state = store.getState()
const pages = Selector.pages.selectAll(state)
return pages.map(it => `${siteUrl}${it.url}`)
}
function toId(raw: string): string {
return raw.toLowerCase().replace(/[^\w]+/g, '-')
}
const command = commander.test ? 'test' : commander.approve ? 'approve' : ''
backstop(command, {
config: {
id: 'default',
viewports: [
{
label: 'phone',
width: 320,
height: 480,
},
{
label: 'tablet',
width: 1024,
height: 768,
},
],
scenarios: renderPage(commander.hostname)
.filter(it => !!it)
.map(it => {
return {
label: toId(new URL(it).pathname),
url: it,
referenceUrl: '',
readyEvent: '',
readySelector: '',
delay: 0,
hideSelectors: [],
removeSelectors: [],
hoverSelector: '',
clickSelector: '',
postInteractionWait: 0,
selectors: [],
selectorExpansion: true,
expect: 0,
misMatchThreshold: 0.01,
requireSameDimensions: true,
}
}),
paths: {
bitmaps_reference: 'backstop_data/bitmaps_reference',
bitmaps_test: 'backstop_data/bitmaps_test',
engine_scripts: 'backstop_data/engine_scripts',
html_report: 'backstop_data/html_report',
ci_report: 'backstop_data/ci_report',
},
report: ['browser'],
engine: 'puppeteer',
engineOptions: {
args: ['--no-sandbox'],
},
asyncCaptureLimit: 5,
asyncCompareLimit: 50,
debug: false,
debugWindow: false,
},
})
.then(() => console.log('DONE'))
.catch((error: any) => console.log('Error', error))