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

Move ZODB and Zope setup and teardown to the layer setup and teardown #109

Open
Rotonen opened this issue May 4, 2019 · 6 comments
Open

Comments

@Rotonen
Copy link
Contributor

Rotonen commented May 4, 2019

I did a bit of profiling, and contrary to a widely held belief, most of the wallclock time spent in the tests is not spent starting up or closing the browser (WebDriver), but rather at setting up and tearing down the plone site (ZODB, Zope) at every suite setup and suite teardown.

To me this'd seem like a big win to move those setups to the layer setup and layer teardown, as they're shared across all of the suites.

@mauritsvanrees
Copy link
Member

This would still be very useful. I think I tried this years ago but failed.

One place where it is noticeable, is in the test console output, where every info/warning/error message is displayed lots of times. Currently I see only one (I opened issue #147 for that), so maybe we fixed enough deprecation warnings by now, or are simply not printing them. There used to be a time where this drowned out all other informative output.

@gforcada
Copy link
Member

I don't have numbers, and anyway it is running locally, but I have the feeling that with playwright it is a bit faster: running one single robot test of plone.app.discussion takes around 10 seconds in my ~5 years old laptop. Running 4 of them ~20 seconds.

But it would be a nice improvement whenever the tests start to be more robust to look at performance improvements. 👍🏾

@Rotonen
Copy link
Contributor Author

Rotonen commented Jun 28, 2023

If the setups are moved around, one thing to keep in mind is that then the assumptions of the tests can be wrong: state builds up between tests on the site from the tests which are not read only.

A clear testing strategy of what to use browser tests for would be advisable. They're cumbersome and fragile and ultimately optimally mostly happen read only without a backend against simulated requests (so could move from whole stack to just testing Volto with the recorded responses from plone.restapi tests - or something in that rough direction).

A quick interim workaround could be to split the read only tests out.

@gforcada
Copy link
Member

Hopefully the fragile part is being less and less of a problem with playwright based tests, one of the topics of the Midsummer sprint that is happening this week in Finland, see plone/Products.CMFPlone#3813 for details

@Rotonen
Copy link
Contributor Author

Rotonen commented Jun 28, 2023

The fragility I saw back in the day is also on Plone: plenty of frontend race conditions which trigger by clicking too fast. That stuff is way easier to catch with unit tests on the frontend side of things.

I'm way out of the loop these days so hopefully things are better now.

@mauritsvanrees
Copy link
Member

Last year I added some keywords in plone.app.robotframework that help against clicking too fast: Wait For Element, Wait For Then Click Element, Wait For Then Click Invisible Element, Wait For Elements. This seems to have gotten the tests a lot more stable, without requiring extra Sleep commands.

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

No branches or pull requests

3 participants