UNPKG

creevey

Version:

creevey is a tool for automated visual testing, that tightly integrated with storybook

34 lines (27 loc) 10.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.noop = noop; exports.isDefined = isDefined; exports.isTest = isTest; exports.isObject = isObject; exports.isString = isString; /* eslint-disable @typescript-eslint/no-explicit-any */ /* eslint-enable @typescript-eslint/no-explicit-any */ function noop() { /* noop */ } function isDefined(value) { return value !== null && value !== undefined; } function isTest(x) { return isDefined(x) && 'id' in x && 'path' in x && Array.isArray(x.path) && typeof x.id == 'string'; } function isObject(x) { return typeof x == 'object' && x != null; } function isString(x) { return typeof x == 'string'; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/types.ts"],"names":["noop","isDefined","value","undefined","isTest","x","Array","isArray","path","id","isObject","isString"],"mappings":";;;;;;;;;;;AAQA;;AAWA;AAgOO,SAASA,IAAT,GAAsB;AAC3B;AACD;;AAEM,SAASC,SAAT,CAAsBC,KAAtB,EAA+D;AACpE,SAAOA,KAAK,KAAK,IAAV,IAAkBA,KAAK,KAAKC,SAAnC;AACD;;AAEM,SAASC,MAAT,CAAqCC,CAArC,EAA2D;AAChE,SAAOJ,SAAS,CAACI,CAAD,CAAT,IAAgB,QAAQA,CAAxB,IAA6B,UAAUA,CAAvC,IAA4CC,KAAK,CAACC,OAAN,CAAcF,CAAC,CAACG,IAAhB,CAA5C,IAAqE,OAAOH,CAAC,CAACI,EAAT,IAAe,QAA3F;AACD;;AAEM,SAASC,QAAT,CAAkBL,CAAlB,EAA2C;AAChD,SAAO,OAAOA,CAAP,IAAY,QAAZ,IAAwBA,CAAC,IAAI,IAApC;AACD;;AAEM,SAASM,QAAT,CAAkBN,CAAlB,EAA2C;AAChD,SAAO,OAAOA,CAAP,IAAY,QAAnB;AACD","sourcesContent":["import { API as StorybookAPI } from '@storybook/api';\nimport { DecoratorFunction } from '@storybook/addons';\nimport { IKey } from 'selenium-webdriver/lib/input';\nimport { Worker as ClusterWorker } from 'cluster';\nimport { WebDriver, WebElementPromise } from 'selenium-webdriver';\nimport Pixelmatch from 'pixelmatch';\nimport { Context } from 'mocha';\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\nexport type DiffOptions = typeof Pixelmatch extends (\n  x1: any,\n  x2: any,\n  x3: any,\n  x4: any,\n  x5: any,\n  options?: infer T,\n) => void\n  ? T\n  : never;\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nexport type StoriesRaw = StorybookAPI extends { setStories: (stories: infer SS) => void } ? SS : never;\n\nexport type StoryInput = StoriesRaw extends { [id: string]: infer S } ? S : never;\n\nexport interface StoryMeta<StoryFnReturnType = unknown> {\n  title: string;\n  component?: unknown;\n  decorators?: DecoratorFunction<StoryFnReturnType>[];\n  parameters?: {\n    creevey?: CreeveyStoryParams;\n    [name: string]: unknown;\n  };\n}\n\nexport interface CSFStory<StoryFnReturnType = unknown> {\n  (): StoryFnReturnType;\n  story?: {\n    name?: string;\n    decorators?: DecoratorFunction<StoryFnReturnType>[];\n    parameters?: {\n      creevey?: CreeveyStoryParams;\n      [name: string]: unknown;\n    };\n  };\n}\n\nexport interface Capabilities {\n  browserName: string;\n}\n\nexport type BrowserConfig = Capabilities & {\n  limit?: number;\n  gridUrl?: string;\n  storybookUrl?: string;\n  testRegex?: RegExp;\n  viewport?: { width: number; height: number };\n};\n\nexport type Browser = boolean | string | BrowserConfig;\n\nexport interface Config {\n  /**\n   * Url to Selenium grid hub or standalone selenium instance\n   */\n  gridUrl: string;\n  /**\n   * Url where storybook hosted on\n   * @default http://localhost:6006\n   */\n  storybookUrl: string;\n  /**\n   * Absolute path to directory with reference images\n   * @default path.join(process.cwd(), './images')\n   */\n  screenDir: string;\n  /**\n   * Absolute path where test reports and diff images would be saved\n   * @default path.join(process.cwd(), './report')\n   */\n  reportDir: string;\n  /**\n   * Absolute path to storybook config directory\n   * @default path.join(process.cwd(), './.storybook')\n   */\n  storybookDir: string;\n  enableFastStoriesLoading: boolean;\n  /**\n   * How much test would be retried\n   * @default 0\n   */\n  maxRetries: number;\n  /**\n   * Define pixelmatch diff options\n   * @default { threshold: 0, includeAA: true }\n   */\n  diffOptions: DiffOptions;\n  /**\n   * Browser capabilities\n   * @default { chrome: true }\n   */\n  browsers: { [key: string]: Browser };\n}\n\nexport type CreeveyConfig = Config | Partial<Omit<Config, 'gridUrl'>>;\n\nexport interface Options {\n  config: string;\n  port: number;\n  ui: boolean;\n  update: boolean;\n  debug: boolean;\n  browser?: string;\n  reporter?: string;\n  gridUrl?: string;\n  screenDir?: string;\n  reportDir?: string;\n}\n\nexport interface Worker extends ClusterWorker {\n  isRunning?: boolean;\n}\n\nexport type WorkerMessage =\n  | { type: 'ready' }\n  | {\n      type: 'error';\n      payload: { status: 'failed'; error: string };\n    }\n  | {\n      type: 'test';\n      payload: TestResult;\n    };\n\nexport interface Images {\n  actual: string;\n  expect?: string;\n  diff?: string;\n}\n\nexport type TestStatus = 'unknown' | 'pending' | 'running' | 'failed' | 'success';\n\nexport interface TestResult {\n  status: 'failed' | 'success';\n  // TODO Remove checks `name == browser` in TestResultsView\n  // images?: Partial<{ [name: string]: Images }> | Images;\n  images?: Partial<{ [name: string]: Images }>;\n  error?: string;\n}\n\nexport interface Test {\n  id: string;\n  // NOTE example: [browser, test, story, kind],\n  path: string[];\n  skip: boolean | string;\n  retries?: number;\n  status?: TestStatus;\n  results?: TestResult[];\n  approved?: Partial<{ [image: string]: number }>;\n}\n\nexport interface ServerTest extends Test {\n  story: StoryInput;\n  fn: (this: Context) => Promise<void>;\n}\n\nexport interface CreeveyStatus {\n  isRunning: boolean;\n  tests: Partial<{ [id: string]: Test }>;\n}\n\nexport interface CreeveyUpdate {\n  isRunning?: boolean;\n  tests?: Partial<{ [id: string]: Partial<Test> & { path: string[] } }>;\n  removedTests?: string[][];\n}\n\nexport interface SkipOption {\n  reason?: string;\n  in?: string | string[] | RegExp;\n  kinds?: string | string[] | RegExp;\n  stories?: string | string[] | RegExp;\n  tests?: string | string[] | RegExp;\n}\n\nexport type SkipOptions = string | SkipOption | SkipOption[];\n\nexport interface CreeveyStoryParams {\n  captureElement?: string | null;\n  delay?: number;\n  skip?: SkipOptions;\n  tests?: {\n    // TODO Define browserName, story\n    [name: string]: (this: {\n      browser: WebDriver;\n      keys: IKey;\n      expect: Chai.ExpectStatic;\n      takeScreenshot: () => Promise<string>;\n      readonly captureElement?: WebElementPromise;\n    }) => Promise<void>;\n  };\n}\n\nexport type CreeveyStory = {\n  id: string;\n  name: string;\n  kind: string;\n  params?: CreeveyStoryParams;\n};\nexport type CreeveyStories = Partial<{\n  [id: string]: CreeveyStory;\n}>;\n\nexport interface ApprovePayload {\n  id: string;\n  retry: number;\n  image: string;\n}\n\nexport type Request =\n  | { type: 'status' }\n  | { type: 'start'; payload: string[] }\n  | { type: 'stop' }\n  | { type: 'approve'; payload: ApprovePayload };\n\nexport type Response = { type: 'status'; payload: CreeveyStatus } | { type: 'update'; payload: CreeveyUpdate };\n\nexport interface CreeveyTest extends Test {\n  checked: boolean;\n}\n\nexport interface CreeveySuite {\n  path: string[];\n  skip: boolean;\n  status?: TestStatus;\n  opened: boolean;\n  checked: boolean;\n  indeterminate: boolean;\n  children: Partial<{ [title: string]: CreeveySuite | CreeveyTest }>;\n}\n\nexport type ImagesViewMode = 'side-by-side' | 'swap' | 'slide' | 'blend';\n\nexport function noop(): void {\n  /* noop */\n}\n\nexport function isDefined<T>(value: T | null | undefined): value is T {\n  return value !== null && value !== undefined;\n}\n\nexport function isTest<T1, T2 extends Test>(x?: T1 | T2): x is T2 {\n  return isDefined(x) && 'id' in x && 'path' in x && Array.isArray(x.path) && typeof x.id == 'string';\n}\n\nexport function isObject(x: unknown): x is object {\n  return typeof x == 'object' && x != null;\n}\n\nexport function isString(x: unknown): x is string {\n  return typeof x == 'string';\n}\n"]}