-
-
Notifications
You must be signed in to change notification settings - Fork 8
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
[RFC] Upstream Alignment Reference Questions #2
Comments
@crutchcorn are you still looking for comments on this RFC? |
Hi @crutchcorn, first off, huge congrats on creating such an awesome library! 🎉 I wanted to jump into this discussion as the main maintainer of [React Native Testing Library(https://github.com/callstack/react-native-testing-library). I’ve noticed many similarities between our libraries as non-Web members of the Testing Library family, and I think there’s a lot of value in sharing ideas and experiences. Library mergingAs far as understand the React Testing Library started as integrated one, with DOM Testing Library and Jest DOM matchers being extracted later on as other TL were added: Angular, Svelte, etc. In case of RNTL we analysed this case and came to the conclusion, that as a non-Web Testing Library, which needs own implementation of Jest Matchers, User Event, etc It makes more sense to have this integrated inside our core package: The main pros we found:
On the cons side it was only: difference from RTL/DTL structure which users might be familiar to. We event made effort to re-integrated the previously existing |
Hey @mdjastrzebski! This is so cool to hear from y'all over Callstack - big fan of your work having led a RN shop as recently as last year. I came to much of the same conclusion. I:
There's likely more work I could do to extend out this package, but today it serves my needs well powering E2E tests in Plop, although feature requests and such are more than welcomed! |
As should be obvious, we're trying to match the upstream example of Testing Library ecosystem as closely as possible. This even extends so far as our source code and release/dev tooling.
However, there are some existing APIs in related packages that I'm admittedly not sure how they would fit/migrate into the CLI environment
General Questions
Library Merging
Currently, this library does the job that the broader Testing Library ecosystem would usually split into a few different packages:
jest-dom
for Jest matchersdom-testing-library
for queries, normalization, etcreact-testing-library
forrender
logic and additionsuser-event
forkeyboard
eventsOn top of this, we also have our docs stored in this folder, whereareas upstream has a dedicated repo and website.
Theoretically, we could break these into separate libraries but there's a few problems with this:
dom-testing-library
and dependents have the benefit of relying on W3C web standards, we do not. The only standards present for the CLI are, well, the CLI itself. There is many instances where, unfortunately, logic is interconnected by requirement. It makes little/no sense to split them when their logic is so interconnectedInstance
While we have an implementation present, it's unclear what a
TestInstance
properly should be, or if that should even be it's name.We've done our best; for example, to align with
container
of upstream, we have the return result ofspawn
set tocontainer
in CLI Testing Library.However, because there is no distinction between
stdout
andstderr
outputs (oftentimes a CLI app will output multiple items one-by-one to be visually similar to one-another), there's no way to have the same kind of parent/child relationship that the DOM has. This has many unintended consequences that we'll see shortly.Further, what should we be calling
TestInstance
? They're meant to be a replacement toHTMLElement
and returned byRenderResult
.Here are some alternatives I can think of:
Process
(not a huge fan of this one)CliInstance
CommandLine
Console
Window
Something that I think comes in handy, from a library perspective, is a global that keeps track of all running processes, like
window
in the DOM.While it wasn't needed in v1 (quite yet), it will make some refactor work possible. As such, I want to include it in v2.
Two questions related to that.
1: What should we call it?
Machine
(I like this one TBH)OS
Kernel
2: What should the shape look like?
window
has many helper methods, and such. We could do something like:dom-testing-library
Reference QuestionsQueries
While we have singular queries (such as
findByText
andfindByError
), we do not currently have multiple matcher queries.queryAllBy
findAllBy
getAllBy
This is because, as mentioned before, there is no reference for what these should return. There are no distinctions between
stdout
orstderr
lines, and there's no major parent/child relationship I can think of that would make sense.jest-dom
Reference QuestionsWhile we have some matchers similar to
jest-dom
(EG:toBeInTheConsole
), would it also make sense to add something like:toHaveANSIEscapeModifier
- Test to see if a related ANSI Escape Code applied to the lineThe text was updated successfully, but these errors were encountered: