-
Notifications
You must be signed in to change notification settings - Fork 11
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
Testing databases that are not controlled by your domain #60
Comments
Hey @nathanjisaac! Please be conscious that when you open an issue on this repo, 2000+ people get an email about it 😬 Happy to try and help but I'd prefer to reserve issue for specific questions about something in the course to make sure we're not abusing peoples' inboxes 😄 That said here's a few thoughts: Question 1: I think both options you presented are valid; it really just depends on what you are trying to test. If you have separate high quality integrated tests for your PostRepository and you are just interested in testing that your routes and controller are formatting and returning the data properly, using a test double for the repository is totally fine. If you don't have separate tests for the PostRepository or you'd just prefer to write your tests in more of a black box style to give you more freedom to refactor, I think your best bet is to figure out a way to setup a test version of the same database. I used this package at a previous job once to generate migrations from an existing database: https://github.com/Xethron/migrations-generator If I remember right it's a little rough around the edges, but it was good enough to get me something to work with. I wouldn't pull that package into your actual project, just create a new dummy project, pull that package in, point the project at the right DB, then generate the migrations and copy those over to your real project and commit them to the repo. It will probably save you a bit of time vs. doing it all by hand. Question 2: I can't quite tell from your example where you'd like to use the I think the most important lesson to take away is this: In Laravel, a lot of work has been done for you to provide lots of what I call "test support" code; features and functionality designed to make it easier for you to write simple, expressive tests. When you are working on a non-Laravel project or integrating with another system, you should be prepared to invest in writing a lot of your own test support code to make your life easier. For example, I worked on a project once that relied heavily on Elastic Search. I wanted to be able to easily seed the Elastic Search database in my tests, clear the whole database at the beginning of my test suite, etc; the sorts of things we do in Laravel with factories and the DatabaseMigrations or DatabaseTransactions helpers. So I spend half a day building out some tooling to make it easier for me to do that, kept it all in a folder called So when you run into situations that feel hard or cumbersome to set up, think of ways you can make that easier for yourself by creating your own support code for your test suite. I do it a lot even in Laravel, where most of the basic test support code is already provided for you 👍 Hope that helps! |
@adamwathan I have a few testing questions for you that I have been struggling with for a while now.
I have two questions.
factory()
function for non Eloquent models.1. Database calls to other custom database
Note: In this example the Eloquent models are connected to a non default database connection.
Code examples
I think it would be nice to write a test like this.
Unfortunately, I can not write something like this because I don't have migrations for this other connection since it is managed separately. Should I create migrations only for testing so I can use Eloquent?
Here is the other solution.
Drawbacks:
factory()
features to build up fake data.2. Database calls to enterprise database
I wish I could use some type of
dataFactory()
function that has a lot of the same features as Laravel'sfactory()
function.Conclusion
Does all this make sense? Can I explain anything in more detail?
What am I missing? Am I making things to complicated? Should I just deal with it? Just part of me feels like there is a better way. Any feedback is greatly appreciated.
The text was updated successfully, but these errors were encountered: