Best JavaScript code snippet using storybook-test-runner
getStorybookMetadata.test.ts
Source:getStorybookMetadata.test.ts
1import * as storybookMain from './getStorybookMain';2import { getStorybookMetadata } from './getStorybookMetadata';3describe('getStorybookMetadata', () => {4 afterAll(() => {5 process.env.STORYBOOK_CONFIG_DIR = undefined;6 });7 it('should return configDir coming from environment variable', () => {8 const mockedMain = {9 stories: [],10 };11 jest.spyOn(storybookMain, 'getStorybookMain').mockReturnValueOnce(mockedMain);12 process.env.STORYBOOK_CONFIG_DIR = '.storybook';13 const { configDir } = getStorybookMetadata();14 expect(configDir).toEqual(process.env.STORYBOOK_CONFIG_DIR);15 });16 it('should return storiesPath with default glob from CSF3 style config', () => {17 const mockedMain = {18 stories: [19 {20 directory: '../stories/basic',21 titlePrefix: 'Example',22 },23 ],24 };25 jest.spyOn(storybookMain, 'getStorybookMain').mockReturnValueOnce(mockedMain);26 process.env.STORYBOOK_CONFIG_DIR = '.storybook';27 const { storiesPaths } = getStorybookMetadata();28 expect(storiesPaths).toMatchInlineSnapshot(29 `"<rootDir>/stories/basic/**/*.stories.@(mdx|tsx|ts|jsx|js)"`30 );31 });32 it('should return storiesPath with glob defined in CSF2 style config', () => {33 const mockedMain = {34 stories: ['../**/stories/*.stories.@(js|ts)'],35 };36 jest.spyOn(storybookMain, 'getStorybookMain').mockReturnValueOnce(mockedMain);37 process.env.STORYBOOK_CONFIG_DIR = '.storybook';38 const { storiesPaths } = getStorybookMetadata();39 expect(storiesPaths).toMatchInlineSnapshot(`"<rootDir>/**/stories/*.stories.@(js|ts)"`);40 });41 it('should return storiesPath from mixed CSF2 and CSF3 style config', () => {42 const mockedMain = {43 stories: [44 {45 directory: '../stories/basic',46 titlePrefix: 'Example',47 },48 '../stories/complex/*.stories.@(js|ts)',49 ],50 };51 jest.spyOn(storybookMain, 'getStorybookMain').mockReturnValueOnce(mockedMain);52 process.env.STORYBOOK_CONFIG_DIR = '.storybook';53 const { storiesPaths } = getStorybookMetadata();54 expect(storiesPaths).toMatchInlineSnapshot(55 `"<rootDir>/stories/basic/**/*.stories.@(mdx|tsx|ts|jsx|js);<rootDir>/stories/complex/*.stories.@(js|ts)"`56 );57 });58 it('should return lazyCompilation=false when unset', () => {59 const mockedMain = { stories: [] };60 jest.spyOn(storybookMain, 'getStorybookMain').mockReturnValueOnce(mockedMain);61 process.env.STORYBOOK_CONFIG_DIR = '.storybook';62 expect(getStorybookMetadata().lazyCompilation).toBe(false);63 });64 it('should return lazyCompilation=true when set', () => {65 const mockedMain = {66 stories: [],67 core: { builder: { name: 'webpack5', options: { lazyCompilation: true } } },68 };69 jest.spyOn(storybookMain, 'getStorybookMain').mockReturnValueOnce(mockedMain);70 process.env.STORYBOOK_CONFIG_DIR = '.storybook';71 expect(getStorybookMetadata().lazyCompilation).toBe(true);72 });...
getStorybookMetadata.ts
Source:getStorybookMetadata.ts
...3import { getStorybookMain } from './getStorybookMain';4export const getStorybookMetadata = () => {5 const workingDir = resolve();6 const configDir = process.env.STORYBOOK_CONFIG_DIR;7 const main = getStorybookMain(configDir);8 const normalizedStoriesEntries = normalizeStories(main.stories, {9 configDir,10 workingDir,11 }).map((specifier) => ({12 ...specifier,13 importPathMatcher: new RegExp(specifier.importPathMatcher),14 }));15 const storiesPaths = normalizedStoriesEntries16 .map((entry) => entry.directory + '/' + entry.files)17 .map((dir) => '<rootDir>/' + relative(workingDir, dir))18 .join(';');19 // @ts-ignore -- this is added in @storybook/core-common@6.5, which we don't depend on20 const lazyCompilation = !!main?.core?.builder?.options?.lazyCompilation;21 return {...
getStorybookMain.test.ts
Source:getStorybookMain.test.ts
2import * as coreCommon from '@storybook/core-common';3jest.mock('@storybook/core-common');4describe('getStorybookMain', () => {5 it('should throw an error if no configuration is found', () => {6 expect(() => getStorybookMain('.storybook')).toThrow();7 });8 it('should return mainjs', () => {9 const mockedMain = {10 stories: [11 {12 directory: '../stories/basic',13 titlePrefix: 'Example',14 },15 ],16 };17 jest.spyOn(coreCommon, 'serverRequire').mockImplementation(() => mockedMain);18 const res = getStorybookMain('.storybook');19 expect(res).toMatchObject(mockedMain);20 });...
Using AI Code Generation
1const { getStorybookMain } = require('storybook-test-runner');2const { getStorybookConfig } = require('storybook-test-runner');3const { StorybookTestRunner } = require('storybook-test-runner');4const { StorybookTestRunnerConfig } = require('storybook-test-runner');5const { StorybookTestRunnerOptions } = require('storybook-test-runner');6const { StorybookTestRunnerStory } = require('storybook-test-runner');7const { StorybookTestRunnerStoryConfig } = require('storybook-test-runner');8const { StorybookTestRunnerStoryOptions } = require('storybook-test-runner');9const { StorybookTestRunnerStoryScreenshotOptions } = require('storybook-test-runner');10const { StorybookTestRunnerStoryScreenshotSizes } = require('storybook-test-runner');11const { StorybookTestRunnerStoryScreenshotSizesOptions } = require('storybook-test-runner');12const { StorybookTestRunnerStoryScreenshotSizesOptionsMobile } = require('storybook-test-runner');13const { StorybookTestRunnerStoryScreenshotSizesOptionsTablet } = require('storybook-test-runner');14const { StorybookTestRunnerStoryScreenshotSizesOptionsDesktop } = require('storybook-test-runner');15const { StorybookTestRunnerStoryScreenshotSizesOptionsHd } = require('storybook-test-runner');
Using AI Code Generation
1const { getStorybookMain } = require('storybook-test-runner');2const { getStorybookConfig } = require('@storybook/react/dist/server/config/defaults/webpack.config.js');3module.exports = getStorybookMain(getStorybookConfig({ configDir: './.storybook' }));4module.exports = {5};6import { configure } from '@storybook/react';7configure(require.context('../src', true, /\.stories\.tsx$/), module);8module.exports = ({ config }) => {9 config.module.rules.push({10 test: /\.(ts|tsx)$/,11 loader: require.resolve('ts-loader'),12 });13 config.resolve.extensions.push('.ts', '.tsx');14 return config;15};16{17 "compilerOptions": {18 "paths": {19 },20 },21}22module.exports = {23 {24 targets: {25 },26 },
Using AI Code Generation
1const { getStorybookMain } = require('storybook-test-runner');2const { stories, addons } = getStorybookMain();3const { getStorybookMain } = require('storybook-test-runner');4const { stories, addons } = getStorybookMain();5module.exports = {6};7module.exports = {8};9module.exports = {10};11module.exports = {12};13module.exports = {14};15module.exports = {16};17module.exports = {18};19const { getStorybookMain } = require('storybook-test-runner');20const { stories, addons } = getStorybookMain();21const { getStorybookMain } = require('storybook-test-runner');22const { stories, addons } = getStorybookMain();23module.exports = {24};25module.exports = {26};27module.exports = {28};29module.exports = {30};31module.exports = {32};33module.exports = {
Using AI Code Generation
1import { getStorybookMain } from 'storybook-test-runner';2export default getStorybookMain(__dirname);3import { getStorybookStories } from 'storybook-test-runner';4const stories = getStorybookStories(__dirname);5describe('stories', () => {6 stories.forEach(story => {7 it(story.name, () => {8 const storyFn = story.storyFn();9 expect(storyFn).toMatchSnapshot();10 });11 });12});
Using AI Code Generation
1const { getStorybookMain } = require('storybook-test-runner');2const { getStorybookConfig } = require('storybook-test-runner');3const { getStorybook } = require('storybook-test-runner');4const { getStorybook } = require('storybook-test-runner');5const { getStorybook } = require('storybook-test-runner');6const { getStorybook } = require('storybook-test-runner');7const { getStorybook } = require('storybook-test-runner');8const { getStorybook } = require('storybook-test-runner');9const { getStorybook } = require('storybook-test-runner');10const { getStorybook } = require('storybook-test-runner');11const { getStorybook } = require('storybook-test-runner');12const { getStorybook } = require('storybook-test-runner');13const { getStorybook } = require('storybook-test-runner');14const { getStorybook } = require('storybook-test-runner');
Using AI Code Generation
1const { getStorybookMain } = require('storybook-test-runner');2const storybookMain = getStorybookMain({3 storybookConfig: {4 },5});6module.exports = storybookMain;7const { getStorybookMain } = require('storybook-test-runner');8const storybookMain = getStorybookMain({9 storybookConfig: {10 },11});12module.exports = storybookMain;13const { getStorybookPreview } = require('storybook-test-runner');14const storybookPreview = getStorybookPreview({15 storybookConfig: {16 },17});18module.exports = storybookPreview;19const { getStorybookWebpackConfig } = require('storybook-test-runner');20const storybookWebpackConfig = getStorybookWebpackConfig({21 storybookConfig: {22 },23});24module.exports = storybookWebpackConfig;25const { getStorybookTsConfig } = require('storybook-test-runner');26const storybookTsConfig = getStorybookTsConfig({27 storybookConfig: {28 },29});30module.exports = storybookTsConfig;31const { getStorybookBabelConfig } = require('storybook-test-runner');32const storybookBabelConfig = getStorybookBabelConfig({33 storybookConfig: {34 },35});36module.exports = storybookBabelConfig;37const { getStorybookManager } =
Using AI Code Generation
1import { getStorybookMain } from 'storybook-test-runner';2module.exports = {3 main: getStorybookMain({4 configPath: path.join(__dirname, 'storybook.config.js'),5 storiesPath: path.join(__dirname, 'stories'),6 }),7};8import { getStorybookMain } from 'storybook-test-runner';9const main = getStorybookMain({10 configPath: path.join(__dirname, 'storybook.config.js'),11 storiesPath: path.join(__dirname, 'stories'),12});13import { getStories } from 'storybook-test-runner';14const stories = getStories({15 configPath: path.join(__dirname, 'storybook.config.js'),16 storiesPath: path.join(__dirname, 'stories'),17});18import { getStoriesByKind } from 'storybook-test-runner';19const stories = getStoriesByKind({20 configPath: path.join(__dirname, 'storybook.config.js'),21 storiesPath: path.join(__dirname, 'stories'),22});
Using AI Code Generation
1const { getStorybookMain } = require('storybook-test-runner')2const mainConfig = getStorybookMain(__dirname)3const { getJestConfig } = require('storybook-test-runner')4const jestConfig = getJestConfig(__dirname)5const { getStorybookConfig } = require('storybook-test-runner')6const storybookConfig = getStorybookConfig(__dirname)7const { getStorybookPreviewConfig } = require('storybook-test-runner')8const storybookPreviewConfig = getStorybookPreviewConfig(__dirname)9const { getStorybookWebpackConfig } = require('storybook-test-runner')10const storybookWebpackConfig = getStorybookWebpackConfig(__dirname)11const { getStorybookAddonConfig } = require('storybook-test-runner')12const storybookAddonConfig = getStorybookAddonConfig(__dirname)13const { getStorybookTsConfig } = require('storybook-test-runner')14const storybookTsConfig = getStorybookTsConfig(__dirname)
Using AI Code Generation
1const storybookTestRunner = require('storybook-test-runner').storybookTestRunner;2const getStorybookMain = require('storybook-test-runner').getStorybookMain;3const path = require('path');4getStorybookMain(path.resolve(__dirname, './stories'), path.resolve(__dirname, './.storybook/main.js'));5storybookTestRunner(path.resolve(__dirname, './.storybook/main.js'), path.resolve(__dirname, './.storybook/webpack.config.js'));6require('./.storybook/tests');7const { storybookTestRunner } = require('storybook-test-runner');8storybookTestRunner(path.resolve(__dirname, './main.js'), path.resolve(__dirname, './webpack.config.js'));9require('./tests');10const { renderStorybook } = require('storybook-test-runner');11describe('Storybook', () => {12});
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!