Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Storybook and unit tests #178

Merged
merged 16 commits into from
Aug 28, 2018
Merged

Storybook and unit tests #178

merged 16 commits into from
Aug 28, 2018

Conversation

wilcoschoneveld
Copy link
Contributor

Hey!

I've smashed together a proof of concept for creating unit tests with storybooks. The stories can be used for demonstration purposes as well as testing the animation logic.

  • I've used yarn to set things up (storybooks doesn't work well with npm)
  • I don't fully understand what your dev workflow is yet, so I might have broken some things
  • You can start storybooks with yarn storybook
  • I've added two basic stories (a fade in and move to right animation)
  • I stub the requestAnimationFrame method to allow stepping through the animations
  • I've shown that the properties of the animated div can be inspected in a unit test

It's a very rough proof of concept, what do you think?

@drcmda
Copy link
Member

drcmda commented Aug 11, 2018

@wilcoschoneveld wow, thanks a lot, any kind of improvement to testing in general is a welcome addition. I normally use the examples wolder project for visual proofing, but that's fairly limited. I thought about snapshotting it, though. Other than that storybook could also be a nice tool for learning.

Do you plan to add some more stories to it? I'll def merge this and don't worry, nothing's broken. :-)

@wilcoschoneveld
Copy link
Contributor Author

Good to hear! I'm going to try and find the time to work on this more regularly.

I added one fullscreen example to see how this would work in storybooks. I'm not yet sure how I can alias the 'react-spring' package to make the importing easier. How do you do this? Unfortunately there is a console warning when toggling this example but I haven't digged into the internals of react-spring to see whats going on, maybe you can have a quick look. Would you be ok to migrate all the examples to the storybook? I'm interested to hear what your development workflow is for this project. Maybe we could have a chat outside of this issue so we could do a quick questions and answers session.

I added a couple more stories. I think it would be cool to have a lot of small separate tests in the storybook as demonstrations but also to use as unit tests. However I haven't yet found a way to reliably stub requestAnimationFrame so that a single step is always the same duration in the spring. Again, I haven't dug that deep yet but it looks like animations depend on Date.now()? Maybe we need to make the animation timing functions pluggable so we can control it from unit tests. What are your thoughts on this?

I'm also trying to test Transition with enzyme mount but for now I can't get to the second child, small steps... 😄

@drcmda
Copy link
Member

drcmda commented Aug 19, 2018

@wilcoschoneveld the framing function is pluggable, you can readily exchange it.

import { Spring, Globals } from 'react-spring'
Globals.injectFrame(cb => global.requestAnimationFrame(cb), cb => global.cancelAnimationFrame(cb))

The current spring does depend on date.now(). Actually this is one of the things i want to look into. Right now that oscillator is a huge function with loops and whatnot ... but games usually use semi-explicit euler, which is really, really simple and probably faster as well. But i don't know what made Christopher Chedeau initially go for RK4 instead. Mysteries ...

@wilcoschoneveld
Copy link
Contributor Author

Thanks for the snippet. I made the now function injectable as well and I got the tests to be reproducible. I'll create some tests and come back to you

@drcmda
Copy link
Member

drcmda commented Aug 22, 2018

@wilcoschoneveld sounds fantastic! Whenever you need this merged just ping me here.

@wilcoschoneveld
Copy link
Contributor Author

wilcoschoneveld commented Aug 23, 2018

I introduced react-testing-library and I'm very happy with the resulting test setup: toggle.test.js

@wilcoschoneveld wilcoschoneveld changed the title [WIP] Storybook and unit tests Storybook and unit tests Aug 23, 2018
@wilcoschoneveld
Copy link
Contributor Author

Added more examples and removed enzyme

Todo:

  • Setup jest command for CI (with coverage)
  • Setup jest command for devs (watch, no coverage)
  • Port a couple more full screen examples

@drcmda
Copy link
Member

drcmda commented Aug 23, 2018

Tests started working again :-)

BTW, i've started a documentation using mdx based docz, i think it could well live side by side storybook. Docz leans more into documentation, storybook would be great for visual proofing/testing.

@wilcoschoneveld
Copy link
Contributor Author

I added two more tests for the delay and immediate props. I'm happy with the current setup and I think it should function as a good basis for the test suite. I added package-lock.json to gitignore to indicate that we should only use yarn and the accompanied yarn.lock file.

I like the idea of docz, I'm interested to see how that would work out!

If you're ok with everything you can go ahead and merge 👍

@drcmda drcmda merged commit 1dcc5ec into pmndrs:master Aug 28, 2018
szjemljanoj pushed a commit to szjemljanoj/react-spring that referenced this pull request Mar 29, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants