-
Smoke Tests: We are gonna make sure that it is gonna be able to run without error, or be used without any kind of error. Here are some examples that I think are Smoke Tests;
- If I use this component and pass the props (if needed) will it render?
- Calling this method/function will cause my app to break or it is OK -- Note that we are not talking about what it returns, we are just interested in being callable, we will test its logic in Sanity Tests.
-
Sanity Tests: Simple tests that check if it is the way it should be and sanity wise it makes sense. Let's look at some examples;
- Does it have the right css class.
- Does it behave as it should or it is misbehaving.
-
Integration Tests: They are testing different pieces of a system assembled together. Let's clarify it with more tangible scenarios:
- backend app needs FusionAuth, MongoDB, and PostgreSQL to function and work properly. Without one of them it will not. So when we say Integration Tests written for backend app we mean that it is gonna test backend and see if is working.
- frontend needs backend, in a sense you could say it is higher level than Integration Tests written for backend app, but I think they can be categorized in the same league since we could have a microservice and backend could be a collection of different NestJS apps that have their own e2e tests but all of them shape what we call backend.
Caution
It might be a little confusing hearing backend as a name for an app. But think of it as a crude name for a NestJS app 😞.
- Unit tests: It can be Smoke Test or Sanity Test.
- E2E tests: I consciously decided to use e2e tests and Integration Tests interchangeably.
- Security Tests: Tests that assess authentication and authorization layers, we are also checking our RESTful API interfaces and if we can call them by passing invalid data or miss some part of them that are necessary.
- System Tests: Here is where actually business lives, from registering a user to logics for whatever it might be. But make no mistake, we are not gonna test everything here. We will only tests CBP here and try to spread the burden to unit test layer. If each unit works as expected there are little that might go wrong.
- Regression Tests: in System Tests we said "there are little that might go wrong" when we have well tested units but if something might go wrong, it will. So that's where Regression Tests comes into picture. We will thoroughly test bugs, UI/UX issues, and functionality enhancements in regression tests.
Caution
Note: these are all only Functional Testing and not Non-functional Tests. Non-functional Tests covers things like: Compatibility Tests, Performance Tests, etc. We are covering Security Tests partially thanks to efforts done in backend's e2e tests but not enough to speak about Security Tests as if we've taken them seriously, we're barely scratching the surface and we are not tests it thoroughly as of now.
I used these resources to draw the lines a define boundaries and a little bit of my personal knowledge:
- https://testsigma.com/blog/the-different-software-testing-types-explained/
- https://stackoverflow.com/a/4069450/8784518
Keep them:
- Easy:
- Easy to implement.
- Easy to run.
- Isolated:
- One scenario should NOT affect another scenario.
- In other word, they should not rely or interfere with each other.
- Should NOT matter in which order the different integration tests are executed.
- Structured:
- Do not write very huge test cases.
- Repeatable:
- Same input, same output no matter how many times I run it.
- Understandable:
- What are you testing with that integration test should be answered clearly.
- Setup a test DB: this ensures your tests are repeatable.
- Create a docker container.
- Create a database dump from your production database.
- Do not dump all of it, a subset of it would suffice.
- Then restore the dumped data in your local instance.
- Then write your tests in Jest.
-
Then we can capitalize on its snapshots feature to check that something stays the same during different runs.
-
Of course if we change our implementation or initial data snapshots would break but that is a different story.
-
And on a relate note, you need to check the generated snapshot first to see if the returned data makes sense to you.
-
Just double checking, you're committing your Jest snapshots, right?
-
-
Reuse the same tool that we love to use in unit testing.
-