Skip to content
This repository was archived by the owner on Jun 3, 2024. It is now read-only.

Unit tests with Jest + Enzyme and updates to Tabs component #315

Merged
merged 20 commits into from
Oct 17, 2018

Conversation

valentijnnieman
Copy link
Contributor

@valentijnnieman valentijnnieman commented Sep 26, 2018

This is a work-in-progress PR, rebased of off #299 - that needs to be merged first.
I'm comparing this branch to the update_scripts branch, so the commits are easier to reason about.

This adds support for Jest, a JS test runner, and Enzyme, testing tools for React. It allows us to write unit tests in JS for the components, hopefully lightening the load/dependency on our Selenium integration tests, and allowing for a more test-driven approach by running Jest in watch mode or as a VS-Code/Atom plugin.

I've written some basic unit tests for the Tabs component, and caught a couple of bugs that I've also fixed.

@plotly/dash

},
"test": {
"plugins": ["transform-object-rest-spread", "styled-jsx/babel-test"]
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here we use (a brand new) plugin babel-test, so that Jest will use Babel and styled-jsx, but won't parse the classes to jsx-1324 or whatever, so that we can make assertions on them!

command: |
. venv/bin/activate
python --version
npm run test-unit
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the only real difference apart from formatting - running the new unit tests in CircleCI.

this.NoChildrenError = {
name: 'NoChildrenError',
message: 'Tabs did not have any children Tab components!',
};
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not really sure about this - if you have suggestions on how to do error handling here in a better way, please let me know!

@chriddyp
Copy link
Member

I've written some basic unit tests for the Tabs component, and caught a couple of bugs that I've also fixed.

Just curious, what bugs did you find that weren't covered in the integration tests?

@rmarren1
Copy link
Contributor

I was getting an exception when the Tabs children is empty. Does this test that case?

@valentijnnieman
Copy link
Contributor Author

valentijnnieman commented Sep 26, 2018

I've written some basic unit tests for the Tabs component, and caught a couple of bugs that I've also fixed.

Just curious, what bugs did you find that weren't covered in the integration tests?

screen shot 2018-09-26 at 4 02 12 pm
This happens when you only have one Tab component as children
screen shot 2018-09-26 at 4 02 39 pm
I haven't tested if these are actual bugs that happen in Dash though. But at minimum these unit tests make the JS code more stable and less prone to breaking.

@T4rk1n
Copy link
Contributor

T4rk1n commented Sep 26, 2018

I think I broke dash 0.28.0 😞

Traceback (most recent call last):
  File "/home/circleci/project/venv/lib/python2.7/site-packages/flask/app.py", line 2292, in wsgi_app
    response = self.full_dispatch_request()
  File "/home/circleci/project/venv/lib/python2.7/site-packages/flask/app.py", line 1815, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "/home/circleci/project/venv/lib/python2.7/site-packages/flask/app.py", line 1718, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "/home/circleci/project/venv/lib/python2.7/site-packages/flask/app.py", line 1813, in full_dispatch_request
    rv = self.dispatch_request()
  File "/home/circleci/project/venv/lib/python2.7/site-packages/flask/app.py", line 1799, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/home/circleci/project/venv/lib/python2.7/site-packages/dash/dash.py", line 995, in _serve_default_favicon
    return flask.Response(pkgutil.get_data('dash', 'favicon.ico'),
  File "/usr/local/lib/python2.7/pkgutil.py", line 589, in get_data
    return loader.get_data(resource_name)
  File "/usr/local/lib/python2.7/pkgutil.py", line 252, in get_data
    with open(pathname, "rb") as file:
IOError: [Errno 2] No such file or directory: '/home/circleci/project/venv/lib/python2.7/site-packages/dash/favicon.ico'

@valentijnnieman
Copy link
Contributor Author

@rmarren1 Actually no it doesn't. I was thinking about it, and thought that the Tabs component should throw an error if there are no children. What would it render? Thinking about it now, perhaps the Tabs component should not throw an exception when there are no children, in the cases where you set the children later through a callback...

@rmarren1
Copy link
Contributor

I think either would be acceptable, but let's use .isRequired consistently with this choice so that users will see a nicer error via the validation PR.

@valentijnnieman
Copy link
Contributor Author

@rmarren1 Ah you're right, thanks! I'll update that.

@valentijnnieman
Copy link
Contributor Author

The Selenium tests are failing here because of this issue: plotly/dash-renderer#84

@valentijnnieman
Copy link
Contributor Author

@rmarren1 So I can remove these errors I'm throwing in favour of .isRequired and the upcoming validations?

@rmarren1
Copy link
Contributor

If you have .isRequired won't prop-types throw a nice exception similar to NoChildException anyway?

@valentijnnieman
Copy link
Contributor Author

@rmarren1 Yeah that's what I expected, but if I set it to .isRequired it will always throw an error, even if there are children. I think there might be an issue where Dash doesn't immediately pass the children on to the dash-renderer instance of components, or something else is going wrong in that pipeline. In the new unit tests here it's running as expected, by the way.

@valentijnnieman valentijnnieman changed the base branch from update_scripts to master October 15, 2018 15:26
@valentijnnieman valentijnnieman changed the title [WIP] Unit tests with Jest + Enzyme Unit tests with Jest + Enzyme and updates to Tabs component Oct 15, 2018
@@ -8,6 +8,7 @@ tox
tox-pyenv
six
plotly>=2.0.8
urllib3<=1.22
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This caused the Python 2.7 tests to fail, got this fix from #333

@@ -18,7 +18,7 @@ Tab.propTypes = {
/**
* The tab's label
*/
label: PropTypes.children,
label: PropTypes.string,
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Support for components/something else than a string for label will have to come later, anything else than a string doesn't really work now anyways, so best to set it to string for now.

Copy link
Member

@chriddyp chriddyp left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's also bump the versions and ship a release as soon as this is merged

@valentijnnieman valentijnnieman merged commit 0c7ffb4 into master Oct 17, 2018
@valentijnnieman valentijnnieman deleted the unit_tests_with_jest branch October 17, 2018 20:15
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants