import { forEachCli, runCLI, supportUi, uniq, ensureProject, tmpProjPath, checkFilesExist, readFile, } from './utils'; import { writeFileSync, mkdirSync } from 'fs'; forEachCli(() => { describe('Storybook schematics', () => { describe('running Storybook and Cypress', () => { it('should execute e2e tests using Cypress running against Storybook', () => { ensureProject(); const myapp = uniq('myapp'); runCLI(`generate @nrwl/angular:app ${myapp} --no-interactive`); const mylib = uniq('test-ui-lib'); createTestUILib(mylib); const mylib2 = uniq('test-ui-lib-react'); runCLI(`generate @nrwl/react:lib ${mylib2} --no-interactive`); runCLI( `generate @nrwl/react:component Button --project=${mylib2} --no-interactive` ); writeFileSync( tmpProjPath(`libs/${mylib2}/src/lib/button.tsx`), ` import React from 'react'; import './button.css'; export type ButtonStyle = 'default' | 'primary' | 'warning'; /* eslint-disable-next-line */ export interface ButtonProps { text?: string; style?: ButtonStyle; padding?: number; } export const Button = (props: ButtonProps) => { return ( ); }; export default Button; ` ); writeFileSync( tmpProjPath(`libs/${mylib2}/src/lib/button.stories.tsx`), ` import React from 'react'; import { text, number } from '@storybook/addon-knobs'; import { Button, ButtonStyle } from './button'; export default { title: 'Button' }; export const primary = () => ( ); ` ); runCLI( `generate @nrwl/angular:storybook-configuration ${mylib} --configureCypress --generateStories --generateCypressSpecs --no-interactive` ); runCLI( `generate @nrwl/angular:stories ${mylib} --generateCypressSpecs --no-interactive` ); writeFileSync( tmpProjPath( `apps/${mylib}-e2e/src/integration/test-button/test-button.component.spec.ts` ), ` describe('test-ui-lib3726865', () => { it('should render the component', () => { cy.visit('/iframe.html?id=testbuttoncomponent--primary&knob-buttonType=button&knob-style=default&knob-age&knob-isDisabled=false'); cy.get('proj-test-button').should('exist'); cy.get('button').should('not.be.disabled'); cy.get('button').should('have.class', 'default'); cy.contains('You are 0 years old.'); }); it('should adjust the knobs', () => { cy.visit('/iframe.html?id=testbuttoncomponent--primary&knob-buttonType=button&knob-style=primary&knob-age=10&knob-isDisabled=true'); cy.get('button').should('be.disabled'); cy.get('button').should('have.class', 'primary'); cy.contains('You are 10 years old.'); }); }); ` ); runCLI( `generate @nrwl/react:storybook-configuration ${mylib2} --configureCypress --no-interactive` ); mkdirSync(tmpProjPath(`apps/${mylib2}-e2e/src/integration`)); writeFileSync( tmpProjPath(`apps/${mylib2}-e2e/src/integration/button.spec.ts`), ` describe('react-ui', () => { it('should render the component', () => { cy.visit( '/iframe.html?id=button--primary&knob-Style=default&knob-Padding&knob-Text=Click%20me' ); cy.get('button').should('exist'); cy.get('button').should('have.class', 'default'); }); it('should adjust the knobs', () => { cy.visit( '/iframe.html?id=button--primary&knob-Style=primary&knob-Padding=10&knob-Text=Other' ); cy.get('button').should('have.class', 'primary'); }); }); ` ); if (supportUi()) { expect(runCLI(`run ${mylib}-e2e:e2e --no-watch`)).toContain( 'All specs passed!' ); } runCLI(`run ${mylib}:build-storybook`); checkFilesExist(`dist/storybook/${mylib}/index.html`); expect(readFile(`dist/storybook/${mylib}/index.html`)).toContain( `
You are {{age}} years old.
` ); runCLI( `g @nrwl/angular:component test-other --project=${libName} --no-interactive` ); }