-
Notifications
You must be signed in to change notification settings - Fork 87
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
Migrate to Vue Testing Library #510
Comments
Hi @EshaanAgg, thank you for the proposal, I think you've raised some good points here. We will discuss this. |
Hi @EshaanAgg, we'd be really happy to see the library in action as we believe that the basic idea and all its many features would be really helpful. It'd be great to see a proof of concept here in the KDS repository. We'd then looked at it, few of us tried it too, and then considered if we'd like to migrate fully (it's a part of larger discussion of the whole ecosystem of testing tools in all our products). From what I can say right now, it looks promising. Please let me know if you're still interested. Thanks so much for raising such a valuable suggestion, personally I'm really impressed by the library. |
@EshaanAgg By the way, do you have any experience with migrating larger test suites? Here in KDS, it wouldn't be such a big deal to refactor everything if such a decision is made, but for example in Kolibri we have hundreds of unit tests. So in case we'd want to use it widely, I wonder what would be a good strategy to approach it. I assume that many tests may fail because of
By any chance, is there a way to limit Vue Testing Library usage just to new test suites? |
Hey! I'm really glad that you liked the suggestion! Also, I would be totally interested in migrating a component or two in KDS to VTL, so that the team can review it and see how it fits into the ecosystem here. We can then work on adopting it partially or completely as the team decides! I'll get started on it!
I myself, have not migrated any large test suites, but have seen many large OpenSource organizations do so. One example is the Jaegar UI project by CNCF. You can look at a few PRs here to see how we do not need to migrate the whole test suite simultaneously, and what the incremental migration process may look like (it's for On a high level, the adoption process would look like:
Yup totally. As I mentioned, it's totally our call as to which testing library we want to use in which components! |
Ah, that's unfortunate. Thanks @EshaanAgg. I am going to find out more about #439 and will reach out back to you. |
@EshaanAgg And thanks for explaining more about the migration, that's great news. |
So @EshaanAgg, in regards to blocking #439, it's possible that @rtibbles will open some sub-tasks and labels them as help wanted, but overall we will need to deal with it internally. Thanks for asking. |
@EshaanAgg We had an idea that we could experiment with this in Kolibri which uses Node 18. There are lots of test scenarios and many have troubles that the library could help with. If you'd be still interested in preparing a proof of concept for a couple of test files, but in Kolibri, please let me know. |
Hey! Even I had been looking for an opportunity to contribute to Kolibri recently, so this falls right into that ballpark. I'll open an issue in Kolibri regarding the same, and refer this there. Are there any files that you want me to take on first or do any work? |
@EshaanAgg Wonderful. I think you don't need to be opening a new issue in Kolibri and just reference this one which I've just assigned you.
Feel free to have a look around and choose. Some are more complex and some less. One idea I had that it may be good to refactor at least one file that uses Vue store, router, and perhaps some mocks too, so we can see how to best transition tricky parts? I also wanted to note that depending on the test suite you have open, you are definitely not required to follow exactly the existing scenarios - I'm pretty sure that in some tests we test internals, use lots of global states, etc. and we'd ideally move away from this over time. So if needed, if it's simpler you could also just look at what's being tested and come up with a different test for the corresponding part of a workflow. If you needed some help with choosing a test scenario, you can let me know. |
This is now unblocked :)! |
@EshaanAgg I unassigned you because it appeared to be a stale assignment but if you're still around and interested to get back to it, we'll welcome it |
@MisRob Can you assign it to me , i will research the issue till Learning Equality closed!!! If @EshaanAgg agrees. |
Hey @RONAK-AI647! I see that you currently have some other issues assigned, so lets make sure to close them before jumping into this one 🤗. |
Hello @MisRob I would really like to work on this issue. Can you please assign it to me? |
Hi @Pandaa007, thank you. I will assign you. I recommend closely studying @EshaanAgg's similar pull request in another repository learningequality/kolibri#11833 |
Hello @MisRob thank you for assigning me this issue. I look forward to start working and get back with updates. |
Hi @Pandaa007! Please be sure to let us know in case you have any questions or comments. We look forward to collaborating with you too. Thank you! |
Hello @MisRob I've made a PR please review it and let me know if any changes are required. |
Thanks @Pandaa007, we will have a look! |
Blocked by
#439
Context
Vue Testing Library is a lightweight wrapper that builds on top of the DOM Testing Library by adding APIs for working with Vue components. It is built on top of
@vue/test-utils
, which is currently used in the KDS.As per the documentation, Vue Testing Library does three things:
@vue/test-utils
methods that conflict with Testing Library Guiding Principle.Product
KDS
The Value Add
I personally advocate for VTL because of two major reasons:
@testing-library/jest-dom
to use the custom Jest matchers for the DOM, enabling us to write better and more expressive tests.Possible Tradeoffs
Refactoring the existing tests is additional work, but it would also provide a good foundation for the future if we want to invest heavily in testing.
PS
I would be happy to migrate an existing test to VTL to provide a proof of concept for the approach.
The text was updated successfully, but these errors were encountered: