Describe the bug
In 5.0.0-rc4, the storybook UI fails to load, throwing cannot read property 'secondary' of undefined
, while trying to read theme.color.secondary
in node_modules/@storybook/ui/dist/components/layout/draggers.js
. The provided theme
object is empty.
I'm seeing this even if I wipe out my custom webpack config and use the default storybook config, with no addons.
If I downgrade to rc3, the problem goes away.
Screenshots
System:
@jdelStrother Are you using a theme, or just the default?
Just the default. I'm not customizing storybook with addParameters or addOptions anywhere.
@jdelStrother Ok just reproduced in a different test project. Try removing yarn.lock
and node_modules
and reinstalling. We've been seeing a lot of yarn issues lately and I suspect this is one. Please let me know if that works. It's not a very satisfying solution, but at least it will help us get closer to understanding what's going on.
Trashing node_modules/yarn.lock doesn't seem to help (although while trying to produce a minimal test case for this, I'm pretty sure I was running into some weirdness where I'd have to trash them before my test case would reliably pass/fail)
Are you able to reproduce with this? For me, if I remove @storybook/addon-actions
from package.json and re-run yarn, storybook starts working again.
Weird. I couldn't repro in my standard CRA test project, repro'd in a gatsby test project but then fixed the problem by cleaning and reinstalling. Now I'm able to repro in your test project. Will dig in tomorrow AM and see whether I can get to the bottom of this -- thanks for the juicy bug!! ๐
Ok it's a yarn hoisting issue. There are two copies of @storybook/theming
installed, so this is a known issue after all:
MMBP:storybook-missing-theme shilman$ npm ls @storybook/theming
[email protected] /Users/shilman/projects/storybook/testing/storybook-missing-theme
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโฌ @storybook/[email protected]
โ โ โ โโโ @storybook/[email protected] deduped
โ โ โโโ @storybook/[email protected] deduped
โ โโโ @storybook/[email protected]
โโโฌ @storybook/[email protected]
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโ @storybook/[email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโ @storybook/[email protected] deduped
โโโ @storybook/[email protected]
Note that it works fine if I install with NPM ๐ญ
Not sure why that's happening or what to do about it. @ndelangen @tmeasday can you shed any light on this?
Ahh, gotcha. FWIW, I can work around the issue by adding an explicit dependency for @storybook/theming
in my package.json
Ran into the same issue.
I can confirm that deleting yarn.lock
and adding @storybook/theming
with a fresh install of node_modules
worked to solve this.
Thanks for the help @shilman and bringing up the issue @jdelStrother.
Hmm I think https://github.com/storybooks/storybook/pull/5679 was supposed to solve this even if there are two copies in your node_modules
. @shilman do you have a reproduction? If #5679 isn't solving the problem we need to re-evaluate
@tmeasday the repro is attached here: https://github.com/storybooks/storybook/issues/5706#issuecomment-466059375
I don't get it. Here's the webpack config it is using:
{ name: 'manager',
mode: 'development',
bail: false,
devtool: 'none',
entry:
[ '/private/tmp/storybook-missing-theme/node_modules/@storybook/core/dist/server/common/polyfills.js',
'/private/tmp/storybook-missing-theme/node_modules/@storybook/core/dist/client/manager/index.js' ],
output:
{ path: '/private/tmp/storybook-missing-theme/node_modules/@storybook/core/dist/public',
filename: '[name].[chunkhash].bundle.js',
publicPath: '' },
cache: {},
plugins:
[ DllReferencePlugin { options: [Object] },
HtmlWebpackPlugin {
options: [Object],
childCompilerHash: undefined,
childCompilationOutputName: undefined,
assetJson: undefined,
hash: undefined,
version: 4 },
DefinePlugin { definitions: [Object] },
CaseSensitivePathsPlugin { options: {}, pathCache: {}, fsOperations: 0, primed: false },
DefinePlugin { definitions: {} } ],
module: { rules: [ [Object], [Object] ] },
resolve:
{ extensions: [ '.mjs', '.js', '.jsx', '.json' ],
modules: [ 'node_modules' ],
alias:
{ 'core-js': '/private/tmp/storybook-missing-theme/node_modules/core-js',
'@storybook/router': '/private/tmp/storybook-missing-theme/node_modules/@storybook/router',
'@storybook/theming': '/private/tmp/storybook-missing-theme/node_modules/@storybook/theming',
'@storybook/channels': '/private/tmp/storybook-missing-theme/node_modules/@storybook/channels',
'@storybook/client-api': '/private/tmp/storybook-missing-theme/node_modules/@storybook/client-api',
'@storybook/core': '/private/tmp/storybook-missing-theme/node_modules/@storybook/core',
'@storybook/ui': '/private/tmp/storybook-missing-theme/node_modules/@storybook/ui',
react: '/private/tmp/storybook-missing-theme/node_modules/@storybook/ui/node_modules/react',
'react-dom': '/private/tmp/storybook-missing-theme/node_modules/@storybook/ui/node_modules/react-dom' } },
recordsPath: '/private/tmp/storybook-missing-theme/node_modules/.cache/storybook/records.json',
optimization: { splitChunks: { chunks: 'all' }, runtimeChunk: true } }
Might have to pass this one over to @ndelangen
I'm on it
UPDATE:
I found something, it's related to the version of react, upgrading and syncing it to the version of react used by storybook seems to make yarn install in a de-duped way.....
@jdelStrother I'm using your reproduction zip, so possibly this info will unblock you.
still working on finding an actual solution.
Analysing the stats, I'm NOT finding duplicated theming or packages ๐
I do find ui to ship nested node_modules, but nothing duplicated it seems?
Emotion seems fragtured?
By doing some fancy testing I got to a solution that seemed to work!
emotion packages are now longer duplicated in @storyboom/theming
Also no nested node_modules in ui:
Should be fixed by https://github.com/storybooks/storybook/pull/5722
Yee-haw!! I just released https://github.com/storybooks/storybook/releases/tag/v5.0.0-rc.5 containing PR #5722 that references this issue. Upgrade today to try it out!
Because it's a pre-release you can find it on the @next
NPM tag.
@ndelangen I'm getting this error when running rc.5
against the example above:
WARN FATAL broken build!, will close the process,
WARN Fix the error below and restart storybook.
EntryModuleNotFoundError: Entry module not found: Error: Can't resolve './src' in '/Users/shilman/projects/storybook/testing/storybook-missing-theme'
at moduleFactory.create (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/webpack/lib/Compilation.js:980:31)
at factory (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/webpack/lib/NormalModuleFactory.js:397:22)
at resolver (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/webpack/lib/NormalModuleFactory.js:130:21)
at asyncLib.parallel (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/webpack/lib/NormalModuleFactory.js:224:22)
at /Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/neo-async/async.js:2825:7
at /Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/neo-async/async.js:6886:13
at normalResolver.resolve (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/webpack/lib/NormalModuleFactory.js:214:25)
at doResolve (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/enhanced-resolve/lib/Resolver.js:184:12)
at hook.callAsync (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/enhanced-resolve/lib/Resolver.js:238:5)
at _fn0 (eval at create (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/tapable/lib/HookCodeFactory.js:32:10), <anonymous>:15:1)
at resolver.doResolve (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/enhanced-resolve/lib/UnsafeCachePlugin.js:37:5)
at hook.callAsync (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/enhanced-resolve/lib/Resolver.js:238:5)
at _fn0 (eval at create (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/tapable/lib/HookCodeFactory.js:32:10), <anonymous>:15:1)
at hook.callAsync (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/enhanced-resolve/lib/Resolver.js:238:5)
at _fn0 (eval at create (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/tapable/lib/HookCodeFactory.js:32:10), <anonymous>:12:1)
at resolver.doResolve (/Users/shilman/projects/storybook/testing/storybook-missing-theme/node_modules/enhanced-resolve/lib/DescriptionFilePlugin.js:42:38)
resolve './src' in '/Users/shilman/projects/storybook/testing/storybook-missing-theme'
using description file: /Users/shilman/projects/storybook/testing/storybook-missing-theme/package.json (relative path: .)
Field 'browser' doesn't contain a valid alias configuration
using description file: /Users/shilman/projects/storybook/testing/storybook-missing-theme/package.json (relative path: ./src)
no extension
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src is not a file
.wasm
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src.wasm doesn't exist
.mjs
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src.mjs doesn't exist
.js
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src.js doesn't exist
.json
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src.json doesn't exist
as directory
existing directory
using path: /Users/shilman/projects/storybook/testing/storybook-missing-theme/src/index
using description file: /Users/shilman/projects/storybook/testing/storybook-missing-theme/package.json (relative path: ./src/index)
no extension
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src/index doesn't exist
.wasm
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src/index.wasm doesn't exist
.mjs
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src/index.mjs doesn't exist
.js
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src/index.js doesn't exist
.json
Field 'browser' doesn't contain a valid alias configuration
/Users/shilman/projects/storybook/testing/storybook-missing-theme/src/index.json doesn't exist
error Command failed with exit code 1.
I cannot reproduce that @shilman
I open the zip, upgraded to rc.5, ran yarn
, ran yarn stories
.
Result:
Functioning storybook
@ndelangen weird, it was consistent for me! Well let's call it solved and come back to it if other people run into the problem
@shilman I'm seeing the same problem in my main app, but not in that demo project ๐
@jdelStrother Does your main app work if you remove node_modules and recreate your lockfile, or install using npm? Sorry this is such a pain -- really not sure what's going on here.
Urgh... so, first time through, I ran npx npm-check-updates '/storybook/' -un; yarn
, ran yarn run start-storybook
, and then hit the error seen here
I deleted node_modules, re-ran yarn, and hit the same error.
I've just gone back to it, running npx npm-check-updates '/storybook/' -un; yarn
from the same commit that I was doing so previously, and can no longer reproduce the error ๐ฆ
@jdelStrother Ugh ... that sounds pretty nasty. Gonna close this now but I suspect it's not the end of the story for this one... ๐ฆ
@jdelStrother contact me directly on our discord if the issue persists, so maybe we can debug together.
For anyone running into the EntryModuleNotFoundError
(I landed here while Googling / troubleshooting) I want to point out that it sounds like this is specific to yarn and that @jdelStrother's recommendation fixed it for me:
Ahh, gotcha. FWIW, I can work around the issue by adding an explicit dependency for
@storybook/theming
in my package.json
๐ I'm also not using any custom theming. I did try blowing away node_modules
and even yarn.lock
. Still had the same issue with 5.0.0
. yarn add -D @storybook/theming
did the trick.
FWIW here is my entire diff (minus lock file) for upgrading a project from 4.x
-> 5.0.0
just now. Thank you to all who were involved in this effort! Seriously great work ๐
diff --git a/package.json b/package.json
index 0c5553602..316257f68 100644
--- a/package.json
+++ b/package.json
@@ -58,11 +58,12 @@
"@babel/preset-env": "7.3.4",
"@babel/preset-react": "7.0.0",
"@babel/register": "7.0.0",
- "@storybook/addon-actions": "4.1.13",
- "@storybook/addon-knobs": "4.1.13",
- "@storybook/addon-links": "4.1.13",
- "@storybook/addons": "4.1.13",
- "@storybook/react": "4.1.13",
+ "@storybook/addon-actions": "5.0.0",
+ "@storybook/addon-knobs": "5.0.0",
+ "@storybook/addon-links": "5.0.0",
+ "@storybook/addons": "5.0.0",
+ "@storybook/react": "5.0.0",
+ "@storybook/theming": "5.0.0",
"babel-eslint": "10.0.1",
"babel-loader": "8.0.5",
"babel-plugin-syntax-async-functions": "6.13.0",
I cannot resolve these errors.
vendors~main.51373e64048002224644.bundle.js:30622 Uncaught TypeError: Cannot read property 'Consumer' of undefined
at ThemeProvider (vendors~main.51373e64048002224644.bundle.js:30622)
at renderWithHooks (vendors~main.51373e64048002224644.bundle.js:80002)
at mountIndeterminateComponent (vendors~main.51373e64048002224644.bundle.js:82084)
at beginWork (vendors~main.51373e64048002224644.bundle.js:82689)
at performUnitOfWork (vendors~main.51373e64048002224644.bundle.js:86376)
at workLoop (vendors~main.51373e64048002224644.bundle.js:86416)
at HTMLUnknownElement.callCallback (vendors~main.51373e64048002224644.bundle.js:67213)
at Object.invokeGuardedCallbackDev (vendors~main.51373e64048002224644.bundle.js:67263)
at invokeGuardedCallback (vendors~main.51373e64048002224644.bundle.js:67320)
at replayUnitOfWork (vendors~main.51373e64048002224644.bundle.js:85642)
vendors~main.51373e64048002224644.bundle.js:84181 The above error occurred in the <ThemeProvider> component:
in ThemeProvider (created by Manager)
in Manager (created by Context.Consumer)
in Location (created by QueryLocation)
in QueryLocation (created by Root)
in LocationProvider (created by Root)
in HelmetProvider (created by Root)
in Root
React will try to recreate this component tree from scratch using the error boundary you provided, LocationProvider.
logCapturedError @ vendors~main.51373e64048002224644.bundle.js:84181
vendors~main.51373e64048002224644.bundle.js:3086 Uncaught TypeError: Cannot read property 'Consumer' of undefined
at ThemeProvider (vendors~main.51373e64048002224644.bundle.js:30622)
at renderWithHooks (vendors~main.51373e64048002224644.bundle.js:80002)
at mountIndeterminateComponent (vendors~main.51373e64048002224644.bundle.js:82084)
at beginWork (vendors~main.51373e64048002224644.bundle.js:82689)
at performUnitOfWork (vendors~main.51373e64048002224644.bundle.js:86376)
at workLoop (vendors~main.51373e64048002224644.bundle.js:86416)
at renderRoot (vendors~main.51373e64048002224644.bundle.js:86499)
at performWorkOnRoot (vendors~main.51373e64048002224644.bundle.js:87406)
at performWork (vendors~main.51373e64048002224644.bundle.js:87318)
at performSyncWork (vendors~main.51373e64048002224644.bundle.js:87292)
vendors~main.51373e64048002224644.bundle.js:84181 The above error occurred in the <LocationProvider> component:
in LocationProvider (created by Root)
in HelmetProvider (created by Root)
in Root
Consider adding an error boundary to your tree to customize error handling behavior.
Visit https://fb.me/react-error-boundaries to learn more about error boundaries.
logCapturedError @ vendors~main.51373e64048002224644.bundle.js:84181
vendors~main.51373e64048002224644.bundle.js:87376 Uncaught TypeError: Cannot read property 'Consumer' of undefined
at ThemeProvider (vendors~main.51373e64048002224644.bundle.js:30622)
at renderWithHooks (vendors~main.51373e64048002224644.bundle.js:80002)
at mountIndeterminateComponent (vendors~main.51373e64048002224644.bundle.js:82084)
at beginWork (vendors~main.51373e64048002224644.bundle.js:82689)
at performUnitOfWork (vendors~main.51373e64048002224644.bundle.js:86376)
at workLoop (vendors~main.51373e64048002224644.bundle.js:86416)
at renderRoot (vendors~main.51373e64048002224644.bundle.js:86499)
at performWorkOnRoot (vendors~main.51373e64048002224644.bundle.js:87406)
at performWork (vendors~main.51373e64048002224644.bundle.js:87318)
at performSyncWork (vendors~main.51373e64048002224644.bundle.js:87292)
I have tried multiple times deleting my node_modules and yarn.lock
I am working with a monorepository so I don't know if that would make a difference
Strange as it is to say, I'm coming in a full year later for upgrading to v6 (!) and seeing the same sorts of errors. Any ways that I can deliver diagnostics against our weird little codebase?
Strange as it is to say, I'm coming in a full year later for upgrading to v6 (!) and seeing the same sorts of errors. Any ways that I can deliver diagnostics against our weird little codebase?
If you add @storybook/theming
to your package.json does that fix anything?
@jdelStrother I'm having the same issue as @danyelf while trying to configure Storybook 6.0.12 using npx sb init
inside a new Gatsby project.
I did try adding @storybook/theming
but that did not help.
Because I'm using yarn
I checked for duplicate packages which is also not the case.
npm ls @storybook/theming (6s 383ms) โ
@******/******@0.1.0 /Users/ramon/******/******/website
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโ @storybook/[email protected]
I had some hopes for @ndelangen's comments about duplicate React version but that is also not the case.
npm ls react (5s 951ms)
@******/******@0.1.0 /Users/ramon/******/******/website
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ [email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โโโ [email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ [email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ [email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โโโ [email protected] deduped
โโโฌ [email protected]
โ โโโฌ [email protected]
โ โโโ [email protected] deduped
โโโ [email protected]
Sadly, storybook/theming is already in my package.json
> npm ls @storybook/theming
[email protected] /home/danyel/go/src/github.com/honeycombio/hound/cmd/poodle
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โ โโโฌ @storybook/[email protected]
โ โ โโโ @storybook/[email protected] deduped
โ โโโ @storybook/[email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ @storybook/[email protected] deduped
โโโ @storybook/[email protected]
> npm ls react
[email protected] /home/danyel/go/src/github.com/honeycombio/hound/cmd/poodle
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โ โโโ [email protected] deduped
โ โโโฌ @storybook/[email protected]
โ โ โโโ [email protected] deduped
โ โโโ [email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โโโฌ @storybook/[email protected]
โ โโโ [email protected] deduped
โโโฌ @storybook/[email protected]
โ โโโ [email protected] deduped
โโโ [email protected]
Anything else I can check on?
hey @danyelf, long time!!! ๐
do you have a repro repo we could look at?
Ouch. Not really -- it's our core prod, and we're a monorepo. I could possibly try to split off pieces. Or share our yarn.lock
or something.
Also, hey @shilman ! I'd meant to send you a wave at some point -- storybook is awesome, and I'm so glad you're making it happen!
Thanks, it's been a ton of fun! ๐
I'm certain that the issue is due to some kind of conflict, either react or emotion. With a repro we might be able to fiddle with it and see what kind of webpack resolutions voodoo we might need to do to get it fixed. But honestly this stuff is really confusing and I'm not even sure a repro would help -- more likely you'd get it figured out yourself trying to disentangle from the monorepo... Wish I had a magic bullet for this!
That indeed did it. A little updating of dependencies seemed to clear it up. Thanks!
Hi @danyelf do you have any pointers which dep (or deps) might have been the culprit?
Having the same issue in our monorepo, set up with Lerna and eh ... not having a fun time :(
EDIT: just realised I was only nuking either package-lock OR node_modules, nuking both before reinstalling was the cure.
Considering the amount of issues across multiple versions of SB is it an idea to add this tip to the documentation?
Perhaps in a new category "Configuration > Troubleshooting" ?
Great idea @GriffinSauce ! Would you mind contributing a PR for that?
Of course, I'll give it a shot!
@GriffinSauce , I didn't follow up because I'm ashamed of my solution.
Following @shilman 's suggestion, I dug around in my dependencies under the assumption that there were inconsistent versions of either emotion
or react
. I read the yarn.lock
file looking for versions of them, and noticed a few cases where it was resolving counterintuitively: emotion ^10.1
would resolve to emotion 10.3
, but emotion ^10.2
resolved to emotion 10.2
.
I simply removed those from the yarn.lock
(Warning: you aren't supposed to hand-edit yarn.lock
. It makes the maintainers sad) and then reran yarn
.
This maintained most of my various package versions, but got rid of a metric ton of crud. Fewer versions of @emotion/core
and @babel/runtime
and react-foo
floating around.
This didn't break anything, and seemed to work well enough.
Most helpful comment
Ahh, gotcha. FWIW, I can work around the issue by adding an explicit dependency for
@storybook/theming
in my package.json