From b97b5995478d2e2cd92d9713f616f37e476d1ae9 Mon Sep 17 00:00:00 2001 From: Kasper Peulen Date: Tue, 8 Aug 2023 17:02:12 +0200 Subject: [PATCH 1/3] Merge pull request #23755 from storybookjs/kasper/ci-flake Build: Fix CI flakiness by setting TEST_ROOT for the test runner (cherry picked from commit f50c26f529e9a726289cc0e792e559f258eb0aeb) --- scripts/tasks/test-runner-build.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/scripts/tasks/test-runner-build.ts b/scripts/tasks/test-runner-build.ts index e25b2fa54906..546bb6c5aa38 100644 --- a/scripts/tasks/test-runner-build.ts +++ b/scripts/tasks/test-runner-build.ts @@ -25,6 +25,7 @@ export const testRunnerBuild: Task & { port: number } = { ...execOptions, env: { JEST_JUNIT_OUTPUT_FILE: junitFilename, + TEST_ROOT: sandboxDir, }, }, { dryRun, debug } From 3389866f1d2eb5ddf329d1532104f3d5c4c62861 Mon Sep 17 00:00:00 2001 From: Kasper Peulen Date: Wed, 9 Aug 2023 11:16:37 +0200 Subject: [PATCH 2/3] Merge pull request #23766 from storybookjs/kasper/remove-prettier-from-csf-tools CSF-Tools: Remove prettier from printConfig (cherry picked from commit 8ee67983258e445fccfead9db7d06adbdb508838) --- code/lib/csf-tools/package.json | 1 - code/lib/csf-tools/src/ConfigFile.test.ts | 201 ++++++---------------- code/lib/csf-tools/src/ConfigFile.ts | 24 +-- code/yarn.lock | 1 - 4 files changed, 58 insertions(+), 169 deletions(-) diff --git a/code/lib/csf-tools/package.json b/code/lib/csf-tools/package.json index 49c227392bdf..312e5d144fa0 100644 --- a/code/lib/csf-tools/package.json +++ b/code/lib/csf-tools/package.json @@ -48,7 +48,6 @@ "@storybook/csf": "^0.1.0", "@storybook/types": "workspace:*", "fs-extra": "^11.1.0", - "prettier": "^2.8.0", "recast": "^0.23.1", "ts-dedent": "^2.0.0" }, diff --git a/code/lib/csf-tools/src/ConfigFile.test.ts b/code/lib/csf-tools/src/ConfigFile.test.ts index e72d7813dd80..10b2c5e8d025 100644 --- a/code/lib/csf-tools/src/ConfigFile.test.ts +++ b/code/lib/csf-tools/src/ConfigFile.test.ts @@ -235,9 +235,8 @@ describe('ConfigFile', () => { export const addons = []; export const core = { - builder: 'webpack5', + builder: "webpack5" }; - `); }); it('missing field', () => { @@ -252,9 +251,8 @@ describe('ConfigFile', () => { ).toMatchInlineSnapshot(` export const core = { foo: 'bar', - builder: 'webpack5', + builder: 'webpack5' }; - `); }); it('found scalar', () => { @@ -266,10 +264,7 @@ describe('ConfigFile', () => { export const core = { builder: 'webpack4' }; ` ) - ).toMatchInlineSnapshot(` - export const core = { builder: 'webpack5' }; - - `); + ).toMatchInlineSnapshot(`export const core = { builder: 'webpack5' };`); }); it('found top-level scalar', () => { expect( @@ -280,10 +275,7 @@ describe('ConfigFile', () => { export const foo = 'bar'; ` ) - ).toMatchInlineSnapshot(` - export const foo = 'baz'; - - `); + ).toMatchInlineSnapshot(`export const foo = 'baz';`); }); it('found object', () => { expect( @@ -295,12 +287,9 @@ describe('ConfigFile', () => { ` ) ).toMatchInlineSnapshot(` - export const core = { - builder: { - name: 'webpack5', - }, - }; - + export const core = { builder: { + name: 'webpack5' + } }; `); }); it('variable export', () => { @@ -316,7 +305,6 @@ describe('ConfigFile', () => { ).toMatchInlineSnapshot(` const coreVar = { builder: 'webpack5' }; export const core = coreVar; - `); }); }); @@ -336,10 +324,9 @@ describe('ConfigFile', () => { addons: [], core: { - builder: 'webpack5', - }, + builder: "webpack5" + } }; - `); }); it('missing field', () => { @@ -352,13 +339,10 @@ describe('ConfigFile', () => { ` ) ).toMatchInlineSnapshot(` - module.exports = { - core: { - foo: 'bar', - builder: 'webpack5', - }, - }; - + module.exports = { core: { + foo: 'bar', + builder: 'webpack5' + }}; `); }); it('found scalar', () => { @@ -370,10 +354,7 @@ describe('ConfigFile', () => { module.exports = { core: { builder: 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - module.exports = { core: { builder: 'webpack5' } }; - - `); + ).toMatchInlineSnapshot(`module.exports = { core: { builder: 'webpack5' } };`); }); }); @@ -392,10 +373,9 @@ describe('ConfigFile', () => { addons: [], core: { - builder: 'webpack5', - }, + builder: "webpack5" + } }; - `); }); it('missing field', () => { @@ -408,13 +388,10 @@ describe('ConfigFile', () => { ` ) ).toMatchInlineSnapshot(` - export default { - core: { - foo: 'bar', - builder: 'webpack5', - }, - }; - + export default { core: { + foo: 'bar', + builder: 'webpack5' + }}; `); }); it('found scalar', () => { @@ -426,10 +403,7 @@ describe('ConfigFile', () => { export default { core: { builder: 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - export default { core: { builder: 'webpack5' } }; - - `); + ).toMatchInlineSnapshot(`export default { core: { builder: 'webpack5' } };`); }); }); @@ -437,31 +411,28 @@ describe('ConfigFile', () => { it('no quotes', () => { expect(setField(['foo', 'bar'], 'baz', '')).toMatchInlineSnapshot(` export const foo = { - bar: 'baz', + bar: "baz" }; - `); }); it('more single quotes', () => { expect(setField(['foo', 'bar'], 'baz', `export const stories = ['a', 'b', "c"]`)) .toMatchInlineSnapshot(` - export const stories = ['a', 'b', 'c']; + export const stories = ['a', 'b', "c"] export const foo = { - bar: 'baz', + bar: 'baz' }; - `); }); it('more double quotes', () => { expect(setField(['foo', 'bar'], 'baz', `export const stories = ['a', "b", "c"]`)) .toMatchInlineSnapshot(` - export const stories = ['a', 'b', 'c']; + export const stories = ['a', "b", "c"] export const foo = { - bar: 'baz', + bar: "baz" }; - `); }); }); @@ -480,9 +451,8 @@ describe('ConfigFile', () => { ).toMatchInlineSnapshot(` export default { core: { builder: 'webpack5' }, - addons: ['docs'], + addons: ['docs'] }; - `); }); it('found scalar', () => { @@ -505,10 +475,7 @@ describe('ConfigFile', () => { export default { addons: ['a11y', 'viewport'] }; ` ) - ).toMatchInlineSnapshot(` - export default { addons: ['a11y', 'viewport', 'docs'] }; - - `); + ).toMatchInlineSnapshot(`export default { addons: ['a11y', 'viewport', 'docs'] };`); }); it('array of complex values', () => { @@ -520,10 +487,9 @@ describe('ConfigFile', () => { export default { addons: [require.resolve('a11y'), someVariable] }; ` ) - ).toMatchInlineSnapshot(` - export default { addons: [require.resolve('a11y'), someVariable, 'docs'] }; - - `); + ).toMatchInlineSnapshot( + `export default { addons: [require.resolve('a11y'), someVariable, 'docs'] };` + ); }); }); @@ -537,10 +503,7 @@ describe('ConfigFile', () => { export const addons = []; ` ) - ).toMatchInlineSnapshot(` - export const addons = []; - - `); + ).toMatchInlineSnapshot(`export const addons = [];`); }); it('missing field', () => { expect( @@ -550,10 +513,7 @@ describe('ConfigFile', () => { export const core = { foo: 'bar' }; ` ) - ).toMatchInlineSnapshot(` - export const core = { foo: 'bar' }; - - `); + ).toMatchInlineSnapshot(`export const core = { foo: 'bar' };`); }); it('found scalar', () => { expect( @@ -563,10 +523,7 @@ describe('ConfigFile', () => { export const core = { builder: 'webpack4' }; ` ) - ).toMatchInlineSnapshot(` - export const core = {}; - - `); + ).toMatchInlineSnapshot(`export const core = {};`); }); it('found object', () => { expect( @@ -576,10 +533,7 @@ describe('ConfigFile', () => { export const core = { builder: { name: 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - export const core = {}; - - `); + ).toMatchInlineSnapshot(`export const core = {};`); }); it('nested object', () => { expect( @@ -589,10 +543,7 @@ describe('ConfigFile', () => { export const core = { builder: { name: 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - export const core = { builder: {} }; - - `); + ).toMatchInlineSnapshot(`export const core = { builder: {} };`); }); it('string literal key', () => { expect( @@ -602,10 +553,7 @@ describe('ConfigFile', () => { export const core = { 'builder': 'webpack4' }; ` ) - ).toMatchInlineSnapshot(` - export const core = {}; - - `); + ).toMatchInlineSnapshot(`export const core = {};`); }); it('variable export', () => { expect( @@ -619,7 +567,6 @@ describe('ConfigFile', () => { ).toMatchInlineSnapshot(` const coreVar = {}; export const core = coreVar; - `); }); it('root export variable', () => { @@ -632,10 +579,7 @@ describe('ConfigFile', () => { export const addons = []; ` ) - ).toMatchInlineSnapshot(` - export const addons = []; - - `); + ).toMatchInlineSnapshot(`export const addons = [];`); }); }); @@ -648,10 +592,7 @@ describe('ConfigFile', () => { module.exports = { addons: [] }; ` ) - ).toMatchInlineSnapshot(` - module.exports = { addons: [] }; - - `); + ).toMatchInlineSnapshot(`module.exports = { addons: [] };`); }); it('missing field', () => { expect( @@ -661,10 +602,7 @@ describe('ConfigFile', () => { module.exports = { core: { foo: 'bar' }}; ` ) - ).toMatchInlineSnapshot(` - module.exports = { core: { foo: 'bar' } }; - - `); + ).toMatchInlineSnapshot(`module.exports = { core: { foo: 'bar' }};`); }); it('found scalar', () => { expect( @@ -674,10 +612,7 @@ describe('ConfigFile', () => { module.exports = { core: { builder: 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - module.exports = { core: {} }; - - `); + ).toMatchInlineSnapshot(`module.exports = { core: {} };`); }); it('nested scalar', () => { expect( @@ -687,10 +622,7 @@ describe('ConfigFile', () => { module.exports = { core: { builder: { name: 'webpack4' } } }; ` ) - ).toMatchInlineSnapshot(` - module.exports = { core: { builder: {} } }; - - `); + ).toMatchInlineSnapshot(`module.exports = { core: { builder: {} } };`); }); it('string literal key', () => { expect( @@ -700,10 +632,7 @@ describe('ConfigFile', () => { module.exports = { 'core': { 'builder': 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - module.exports = { core: {} }; - - `); + ).toMatchInlineSnapshot(`module.exports = { 'core': {} };`); }); it('root property', () => { expect( @@ -715,9 +644,8 @@ describe('ConfigFile', () => { ) ).toMatchInlineSnapshot(` module.exports = { - addons: [], + addons: [] }; - `); }); }); @@ -731,10 +659,7 @@ describe('ConfigFile', () => { export default { addons: [] }; ` ) - ).toMatchInlineSnapshot(` - export default { addons: [] }; - - `); + ).toMatchInlineSnapshot(`export default { addons: [] };`); }); it('missing field', () => { expect( @@ -744,10 +669,7 @@ describe('ConfigFile', () => { export default { core: { foo: 'bar' }}; ` ) - ).toMatchInlineSnapshot(` - export default { core: { foo: 'bar' } }; - - `); + ).toMatchInlineSnapshot(`export default { core: { foo: 'bar' }};`); }); it('found scalar', () => { expect( @@ -757,10 +679,7 @@ describe('ConfigFile', () => { export default { core: { builder: 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - export default { core: {} }; - - `); + ).toMatchInlineSnapshot(`export default { core: {} };`); }); it('nested scalar', () => { expect( @@ -770,10 +689,7 @@ describe('ConfigFile', () => { export default { core: { builder: { name: 'webpack4' } } }; ` ) - ).toMatchInlineSnapshot(` - export default { core: { builder: {} } }; - - `); + ).toMatchInlineSnapshot(`export default { core: { builder: {} } };`); }); it('string literal key', () => { expect( @@ -783,10 +699,7 @@ describe('ConfigFile', () => { export default { 'core': { 'builder': 'webpack4' } }; ` ) - ).toMatchInlineSnapshot(` - export default { core: {} }; - - `); + ).toMatchInlineSnapshot(`export default { 'core': {} };`); }); it('root property', () => { expect( @@ -798,9 +711,8 @@ describe('ConfigFile', () => { ) ).toMatchInlineSnapshot(` export default { - addons: [], + addons: [] }; - `); }); }); @@ -809,31 +721,28 @@ describe('ConfigFile', () => { it('no quotes', () => { expect(setField(['foo', 'bar'], 'baz', '')).toMatchInlineSnapshot(` export const foo = { - bar: 'baz', + bar: "baz" }; - `); }); it('more single quotes', () => { expect(setField(['foo', 'bar'], 'baz', `export const stories = ['a', 'b', "c"]`)) .toMatchInlineSnapshot(` - export const stories = ['a', 'b', 'c']; + export const stories = ['a', 'b', "c"] export const foo = { - bar: 'baz', + bar: 'baz' }; - `); }); it('more double quotes', () => { expect(setField(['foo', 'bar'], 'baz', `export const stories = ['a', "b", "c"]`)) .toMatchInlineSnapshot(` - export const stories = ['a', 'b', 'c']; + export const stories = ['a', "b", "c"] export const foo = { - bar: 'baz', + bar: "baz" }; - `); }); }); diff --git a/code/lib/csf-tools/src/ConfigFile.ts b/code/lib/csf-tools/src/ConfigFile.ts index 684e195919a8..e31750a2fed6 100644 --- a/code/lib/csf-tools/src/ConfigFile.ts +++ b/code/lib/csf-tools/src/ConfigFile.ts @@ -6,10 +6,8 @@ import * as t from '@babel/types'; import * as generate from '@babel/generator'; import * as traverse from '@babel/traverse'; -import * as recast from 'recast'; -import prettier from 'prettier'; - import type { Options } from 'recast'; +import * as recast from 'recast'; import { babelParse } from './babelParse'; const logger = console; @@ -718,27 +716,11 @@ export const loadConfig = (code: string, fileName?: string) => { }; export const formatConfig = (config: ConfigFile) => { - const { code } = generate.default(config._ast, {}); - return code; + return printConfig(config).code; }; export const printConfig = (config: ConfigFile, options: Options = {}) => { - const result = recast.print(config._ast, options); - const prettierConfig = prettier.resolveConfig.sync('.'); - - if (prettierConfig) { - let pretty: string; - try { - pretty = prettier.format(result.code, { - ...prettierConfig, - filepath: config.fileName ?? 'main.ts', - }); - } catch (_) { - pretty = result.code; - } - return { ...result, code: pretty }; - } - return result; + return recast.print(config._ast, options); }; export const readConfig = async (fileName: string) => { diff --git a/code/yarn.lock b/code/yarn.lock index 51031f5080f2..602589e56a61 100644 --- a/code/yarn.lock +++ b/code/yarn.lock @@ -6733,7 +6733,6 @@ __metadata: "@types/js-yaml": ^4.0.5 fs-extra: ^11.1.0 js-yaml: ^4.1.0 - prettier: ^2.8.0 recast: ^0.23.1 ts-dedent: ^2.0.0 typescript: ~4.9.3 From 015a3837a427e4f9648393e26b8cfedae78b3829 Mon Sep 17 00:00:00 2001 From: storybook-bot <32066757+storybook-bot@users.noreply.github.com> Date: Wed, 9 Aug 2023 12:56:49 +0000 Subject: [PATCH 3/3] Write changelog for 7.2.2 --- CHANGELOG.md | 4 ++++ code/package.json | 3 ++- docs/versions/latest.json | 2 +- 3 files changed, 7 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 029cacbefcc0..c3d2cc1933c5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,7 @@ +## 7.2.2 + +- CSF-Tools: Remove prettier from printConfig - [#23766](https://github.com/storybookjs/storybook/pull/23766), thanks [@kasperpeulen](https://github.com/kasperpeulen)! + ## 7.2.1 - Addon docs: Add safe check in Webpack preset - [#23687](https://github.com/storybookjs/storybook/pull/23687), thanks [@yannbf](https://github.com/yannbf)! diff --git a/code/package.json b/code/package.json index 7edd4fdb07b9..ceb577fbc378 100644 --- a/code/package.json +++ b/code/package.json @@ -326,5 +326,6 @@ "Dependency Upgrades" ] ] - } + }, + "deferredNextVersion": "7.2.2" } diff --git a/docs/versions/latest.json b/docs/versions/latest.json index c637bb7b504f..0d2d3cb736a7 100644 --- a/docs/versions/latest.json +++ b/docs/versions/latest.json @@ -1 +1 @@ -{"version":"7.2.1","info":{"plain":"- Addon docs: Add safe check in Webpack preset - [#23687](https://github.com/storybookjs/storybook/pull/23687), thanks [@yannbf](https://github.com/yannbf)!\n- Autodocs: Fix docs pages ignoring `meta.id` when calculating their ID - [#23520](https://github.com/storybookjs/storybook/pull/23520), thanks [@sookmax](https://github.com/sookmax)!\n- CLI: Fix error logging being swallowed from dev/build failures - [#23689](https://github.com/storybookjs/storybook/pull/23689), thanks [@yannbf](https://github.com/yannbf)!\n- Channels: Remove self-referencing in `package.json` - [#23681](https://github.com/storybookjs/storybook/pull/23681), thanks [@stof](https://github.com/stof)!\n- UI: Fix ArgsTable empty state on docs - [#23688](https://github.com/storybookjs/storybook/pull/23688), thanks [@cdedreuille](https://github.com/cdedreuille)!\n- UI: Improve controls addon - [#23635](https://github.com/storybookjs/storybook/pull/23635), thanks [@cdedreuille](https://github.com/cdedreuille)!"}} +{"version":"7.2.2","info":{"plain":"- CSF-Tools: Remove prettier from printConfig - [#23766](https://github.com/storybookjs/storybook/pull/23766), thanks [@kasperpeulen](https://github.com/kasperpeulen)!"}}