Merge pull request #18917 from storybookjs/fix/sb-scripts-automigration

CLI: install the same version as the user in sb-scripts automigration
This commit is contained in:
Yann Braga 2022-08-11 14:07:15 +02:00 committed by GitHub
commit 1d80c8ee62
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 91 additions and 35 deletions

View File

@ -88,16 +88,18 @@ describe('sb scripts fix', () => {
checkSbScripts({ checkSbScripts({
packageJson, packageJson,
}) })
).resolves.toEqual({ ).resolves.toEqual(
storybookScripts: { expect.objectContaining({
official: { storybookScripts: {
storybook: 'storybook dev -p 6006', official: {
'build-storybook': 'storybook build -o build/storybook', storybook: 'storybook dev -p 6006',
'build-storybook': 'storybook build -o build/storybook',
},
custom: {},
}, },
custom: {}, storybookVersion: '^7.0.0-alpha.0',
}, })
storybookVersion: '^7.0.0-alpha.0', );
});
}); });
}); });
@ -122,18 +124,20 @@ describe('sb scripts fix', () => {
checkSbScripts({ checkSbScripts({
packageJson, packageJson,
}) })
).resolves.toEqual({ ).resolves.toEqual(
storybookScripts: { expect.objectContaining({
custom: { storybookScripts: {
'sb:start': 'start-storybook -p 6006', custom: {
'sb:build': 'build-storybook -o buid/storybook', 'sb:start': 'start-storybook -p 6006',
'test-storybook:ci': 'sb:build': 'build-storybook -o buid/storybook',
'concurrently -k -s first -n "SB,TEST" -c "magenta,blue" "yarn build-storybook --quiet && npx http-server storybook-static --port 6006 --silent" "wait-on tcp:6006 && yarn test-storybook"', 'test-storybook:ci':
'concurrently -k -s first -n "SB,TEST" -c "magenta,blue" "yarn build-storybook --quiet && npx http-server storybook-static --port 6006 --silent" "wait-on tcp:6006 && yarn test-storybook"',
},
official: {},
}, },
official: {}, storybookVersion: '^7.0.0-alpha.0',
}, })
storybookVersion: '^7.0.0-alpha.0', );
});
}); });
describe('with old official and custom scripts', () => { describe('with old official and custom scripts', () => {
@ -156,19 +160,21 @@ describe('sb scripts fix', () => {
checkSbScripts({ checkSbScripts({
packageJson, packageJson,
}) })
).resolves.toEqual({ ).resolves.toEqual(
storybookScripts: { expect.objectContaining({
custom: { storybookScripts: {
'storybook:build': 'build-storybook -o buid/storybook', custom: {
'test-storybook:ci': 'storybook:build': 'build-storybook -o buid/storybook',
'concurrently -k -s first -n "SB,TEST" -c "magenta,blue" "yarn build-storybook --quiet && npx http-server storybook-static --port 6006 --silent" "wait-on tcp:6006 && yarn test-storybook"', 'test-storybook:ci':
'concurrently -k -s first -n "SB,TEST" -c "magenta,blue" "yarn build-storybook --quiet && npx http-server storybook-static --port 6006 --silent" "wait-on tcp:6006 && yarn test-storybook"',
},
official: {
storybook: 'storybook dev -p 6006',
},
}, },
official: { storybookVersion: '^7.0.0-alpha.0',
storybook: 'storybook dev -p 6006', })
}, );
},
storybookVersion: '^7.0.0-alpha.0',
});
}); });
}); });

View File

@ -3,6 +3,8 @@ import { dedent } from 'ts-dedent';
import semver from '@storybook/semver'; import semver from '@storybook/semver';
import { getStorybookInfo } from '@storybook/core-common'; import { getStorybookInfo } from '@storybook/core-common';
import { Fix } from '../types'; import { Fix } from '../types';
import { getStorybookVersionSpecifier } from '../../helpers';
import { PackageJsonWithDepsAndDevDeps } from '../../js-package-manager';
interface SbScriptsRunOptions { interface SbScriptsRunOptions {
storybookScripts: { storybookScripts: {
@ -10,6 +12,7 @@ interface SbScriptsRunOptions {
official: Record<string, string>; official: Record<string, string>;
}; };
storybookVersion: string; storybookVersion: string;
packageJson: PackageJsonWithDepsAndDevDeps;
} }
const logger = console; const logger = console;
@ -76,7 +79,9 @@ export const sbScripts: Fix<SbScriptsRunOptions> = {
.replace('build-storybook', 'storybook build'); .replace('build-storybook', 'storybook build');
}); });
return semver.gte(storybookCoerced, '6.0.0') ? { storybookScripts, storybookVersion } : null; return semver.gte(storybookCoerced, '7.0.0')
? { packageJson, storybookScripts, storybookVersion }
: null;
}, },
prompt({ storybookVersion }) { prompt({ storybookVersion }) {
@ -104,13 +109,16 @@ export const sbScripts: Fix<SbScriptsRunOptions> = {
.join('\n\n'); .join('\n\n');
}, },
async run({ result: { storybookScripts }, packageManager, dryRun }) { async run({ result: { storybookScripts, packageJson }, packageManager, dryRun }) {
logger.log(); logger.log();
logger.info(`Adding 'storybook' as dev dependency`); logger.info(`Adding 'storybook' as dev dependency`);
logger.log(); logger.log();
if (!dryRun) { if (!dryRun) {
packageManager.addDependencies({ installAsDevDependencies: true }, ['storybook']); const versionToInstall = getStorybookVersionSpecifier(packageJson);
packageManager.addDependencies({ installAsDevDependencies: true }, [
`storybook@${versionToInstall}`,
]);
} }
logger.info(`Updating scripts in package.json`); logger.info(`Updating scripts in package.json`);

View File

@ -108,4 +108,28 @@ describe('Helpers', () => {
helpers.copyComponents(framework, SupportedLanguage.JAVASCRIPT) helpers.copyComponents(framework, SupportedLanguage.JAVASCRIPT)
).rejects.toThrowError(expectedMessage); ).rejects.toThrowError(expectedMessage);
}); });
describe('getStorybookVersionSpecifier', () => {
it(`should return the specifier if storybook lib exists in package.json`, () => {
expect(
helpers.getStorybookVersionSpecifier({
dependencies: {},
devDependencies: {
'@storybook/react': '^x.x.x',
},
})
).toEqual('^x.x.x');
});
it(`should throw an error if no package is found`, () => {
expect(() => {
helpers.getStorybookVersionSpecifier({
dependencies: {},
devDependencies: {
'something-else': '^x.x.x',
},
});
}).toThrowError("Couldn't find any official storybook packages in package.json");
});
});
}); });

View File

@ -9,6 +9,7 @@ import stripJsonComments from 'strip-json-comments';
import { SupportedRenderers, SupportedLanguage } from './project_types'; import { SupportedRenderers, SupportedLanguage } from './project_types';
import { JsPackageManager, PackageJson, PackageJsonWithDepsAndDevDeps } from './js-package-manager'; import { JsPackageManager, PackageJson, PackageJsonWithDepsAndDevDeps } from './js-package-manager';
import { getBaseDir } from './dirs'; import { getBaseDir } from './dirs';
import storybookMonorepoPackages from './versions';
const logger = console; const logger = console;
@ -222,3 +223,20 @@ export async function copyComponents(framework: SupportedRenderers, language: Su
overwrite: true, overwrite: true,
}); });
} }
// Given a package.json, finds any official storybook package within it
// and if it exists, returns the version of that package from the specified package.json
export function getStorybookVersionSpecifier(packageJson: PackageJsonWithDepsAndDevDeps) {
const allDeps = { ...packageJson.dependencies, ...packageJson.devDependencies };
const storybookPackage = Object.keys(allDeps).find(
(name: keyof typeof storybookMonorepoPackages) => {
return storybookMonorepoPackages[name];
}
);
if (!storybookPackage) {
throw new Error(`Couldn't find any official storybook packages in package.json`);
}
return allDeps[storybookPackage];
}