-
Notifications
You must be signed in to change notification settings - Fork 16
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
Documentation for running pytest with a different MAIL_BACKEND when using Celery and the app factory pattern #16
Comments
@nickjj I am not very knowledgeable but can't you override the |
Based on one of your tests using that here: flask-mailman/tests/test_backend.py Lines 95 to 104 in 1f6ff7e
For example, imagine this flow:
And now you have a test which makes a POST request to reset your password. At this point the mailing is done inside of that task file, not the view so there's no way to override I also wouldn't want to mock out the task function in the test because I'd like to assert the email I'm sending out has the correct information (correct recipient, subject, template text, etc.). |
In that case pardon me for bringing that up. I haven't used Celery ( I just used plain threading module with flask-mailman) so was not aware of this. Might still not be useful suggestion or a bit hacky but can you not use a fixture to yield a new |
Do you have any suggestions on how to set up that fixture? |
I think since MAIL config is already initialized you might have to create a different app with the config for email. I wrote some tests to test my configurations for production and development like this https://github.com/Abdur-rahmaanJ/shopyo/blob/dev/shopyo/tests/conftest.py and this https://github.com/Abdur-rahmaanJ/shopyo/blob/dev/shopyo/tests/test_configs.py which might not be what you want. If My email test don't use Celery but in case they are useful: https://github.com/Abdur-rahmaanJ/shopyo/blob/dev/shopyo/modules/box__default/auth/tests/test_email.py Is it possible to see your pytest that you wrote? |
In the most simple test case, it's: def test_home_page(self, app):
current_celery_app.send_task("myapp.user.tasks.deliver_reset_password", ["[email protected]"]) This is running in a class that has the original fixture applied from the issue (the "app" one). As for the Flask factories themselves outside of the tests, here's example Edit: I think the issue is the Flask app itself ends up having the correct settings applied due to the fixture, but the Celery app does not and since the email is sent through Celery, those settings have no effect. It ends up running through the |
I see. So it more of how to setup the celery_app configs and integration. Sorry I was unable to help. |
Yeah, but only during tests because it works fine outside of tests (I can control which backend to use with |
I've never used celery, so I'll need some time to investigate the problem you describe. |
Just came across this package while reviewing alternatives to the no-longer-maintained flask-mail. What attracts me to this package is the ability to create custom backends. Locmem is very useful when developing locally. However, in the event of testing with celery I think it would be worthwhile developing a SQLite backend that stores sent emails. This would allow you to check the emails sent across processes (the main/pytest process and the celery worker process) |
Hi,
When running tests it's a great idea to use the
locmem
back-end to avoid really sending out emails through your SMTP provider, but if you happen to use Celery and the app factory pattern it's not straight forward on how to accomplish this.Normally you'd have a pytest fixture like this:
And if you weren't using Celery you could drop a
MAIL_BACKEND = "locmem"
in theparams
and you're good to go.But if you're using Celery this changes because when you create your Celery app as part of starting your Flask app, it won't be running with
TESTING = True
, which means it never gets set and suddenly if you have a test that hits a Flask URL that sends an email (reset password, etc.) then the above app fixture never gets used.Having to set the MAIL_BACKEND in development and restart everything just to run your tests with a different backend doesn't seem like a fun workaround either because you have to remember to keep changing this and often times in dev you want a different backend than test.
How would you solve this problem?
The text was updated successfully, but these errors were encountered: