8:20 pytest also prints out whatever was written to stdout whenever a test fails. So if you're debugging a failing test you can read the output even without using -s.
-v{1,3} is also very helpful when tests with a more complex comparison fail, e.g. long strings, lists/tuples/dicts with many items. It shows you exactly where the difference occurred, what item is missing etc. It helps me a lot breaking this down
Nice video, just checked I was sure unit test wasn’t in Python 1. Python predates junit by about 7 years and unit test was inspired by junit. python 20 February 1991. JUnit was born on a flight from Zurich to the 1997 OOPSLA in Atlanta.
Nice video, exactly what I was looking for and the right amount of detail and explanation. The only downside is you have not done a video on Allure reporting :)
Great video! I've quickly tested some time ago unittest from python and I found out that writing assertion keyword is not strictly prohibited, maaaaybeee they changed something? I don't know. But pytest is by far most useful 3rd party tool downloadable from PIP! Thanks for sharing this tutorial!
TIL about -s for print debugging an incorrectly passing test. I've normally just gone with the tried and true 1 / 0 in the test if it comes to that. haha The plugins certainly make the tool shine brighter than it already does. Off the top of my head, pytest-randomly and pytest-repeat are two I use regularly to shake out and expose tricky pollution.
I honestly prefer unittest. It is just nice to have it integrated in the language. Other than that I don't use it very differently from how you use pytest in this video.
i did learn OOP way in Python just to understood pretty well unittest code examples. Now i just accidentally here Pytest and saw your video, while i did research on youtube how it looks like. And i like that pytest , it does not strictly used Class Based written test. I also enjoyed my learning on unittest framwork using Class Base. But i do believe in unittest you can do it in by writing functions instead like the Pytest. But not really good idea since the documentation does not mention something like that, i could also be wrong since i am still fairly new to writing unit test code, when i did my first python project, all i did was like intuition. No written test and it was horrible experience because it was hard to identify the bugs on the project. But yeah lesson learned and i better write a test whenever i write a functionality of the program. Your video showing pytest was pretty great, i have no idea how great is pytest in general. looks more simpler in terms of usage compare to unittest in my opinion. I have still to open my OOP book in Python, just to make myself not getting lost in the middle. Thanks for creating the video of demonstrating pytest. Just notice you type in terminal: " babi .py " what is that "babi"? It looks like nano text editor, i guess it is? you just make some alias for nano text editor?
@@anthonywritescode It is running in staging but its blackbox level test script, but i was just curious how would one manage test data in this situation.
Thanks for the video! Many of your repos have testing directory, what do you store there? A code that is related for tests but you keep it separate because tests directory should contain only tests? Or my guess is wrong
Hey Anthony! Why do you not like oop? 😊 its a battle am fighting to learn or not but i checked many of your repos and didnt see you using classes, so was hoping to hear your thoughts
it's terrible for large code cases and tends to encourage poor patterns. when a lot of people say "I'm doing oop" I find most of them are instead doing "I'm too lazy to import what I need so I'm using inheritance for convenience"
Great video. Thank you for it! One thing that I was wondering about is that, as you mentioned in the video, for basically every python file, you create a corresponding test file. Personally, this makes a lot of sense to me and keeps everything in order, but previously in a clean code video, I thought they stated that this could result in overcoupling. Part of the video: ua-cam.com/video/58jGpV2Cg50/v-deo.html Are they talking about something fundamentally different, or how would you explain this?
I've heard about this great tool, pre-commit. It's from this really cool guy, you should definitely give it a try *wink*. It would be nice to have a "getting started with pre-commit".
8:20 pytest also prints out whatever was written to stdout whenever a test fails. So if you're debugging a failing test you can read the output even without using -s.
-v{1,3} is also very helpful when tests with a more complex comparison fail, e.g. long strings, lists/tuples/dicts with many items. It shows you exactly where the difference occurred, what item is missing etc.
It helps me a lot breaking this down
Thanks!
Ohhhhh! I've been on your stream and I didn't realise that you're one of the folks behind PyTest. Good on ya!
Didn't know that including __init__.py would resolve name collisions - thanks!
One of the top python packages! 🙂
Truly one of the python packages of all time
Awesome video! can we also have a video on Mock, patching, monkey patch..etc please!
Thanks a lot for the video. Coming from other language backgrounds, it helped a lot to clarify some info. Plus, it was short and enlightening
11:57 actually, when I run pytest from the command line, it doesn't work without the __init__.py
Nice video, just checked I was sure unit test wasn’t in Python 1. Python predates junit by about 7 years and unit test was inspired by junit. python
20 February 1991. JUnit was born on a flight from Zurich to the 1997 OOPSLA in Atlanta.
I assume the `-s` and suppression of I/O extends to the code not only in the test file (t_test.py) but also the original file (t.py)?
yep yep, i/o is controlled globally
Nice video, exactly what I was looking for and the right amount of detail and explanation. The only downside is you have not done a video on Allure reporting :)
Great video!
I've quickly tested some time ago unittest from python and I found out that writing assertion keyword is not strictly prohibited, maaaaybeee they changed something? I don't know. But pytest is by far most useful 3rd party tool downloadable from PIP! Thanks for sharing this tutorial!
there's nothing stopping you from using plain assert, but your error messages will be useless
@@anthonywritescode Oh, okay then. thanks! :)
Thanks, Anthony. Can you make a video about 'indirect' in parametrize?
And also request param in fixtures?
personally I don't think anyone should use indirect
TIL about -s for print debugging an incorrectly passing test. I've normally just gone with the tried and true 1 / 0 in the test if it comes to that. haha
The plugins certainly make the tool shine brighter than it already does. Off the top of my head, pytest-randomly and pytest-repeat are two I use regularly to shake out and expose tricky pollution.
And I have been using the infinitely more verbose --capture=tee-sys :-!
I honestly prefer unittest. It is just nice to have it integrated in the language. Other than that I don't use it very differently from how you use pytest in this video.
please explain the plugins for pytest!! great video!! thumbsed upppp!!!
whats with the keyboard view?
I never knew there was a name to call how you name your variables:
camelCase
snake_case
PascalCase
kebab-case
# just in case
flask app is dockerized. Uses rq worker, redis, postgres as compose services. How should one thing about testing such application?
you mock the output from those services to test your logic
i did learn OOP way in Python just to understood pretty well unittest code examples.
Now i just accidentally here Pytest and saw your video, while i did research on youtube how it looks like.
And i like that pytest , it does not strictly used Class Based written test.
I also enjoyed my learning on unittest framwork using Class Base.
But i do believe in unittest you can do it in by writing functions instead like the Pytest. But not really good idea since the documentation does not mention something like that, i could also be wrong since i am still fairly new to writing unit test code, when i did my first python project, all i did was like intuition. No written test and it was horrible experience because it was hard to identify the bugs on the project.
But yeah lesson learned and i better write a test whenever i write a functionality of the program.
Your video showing pytest was pretty great, i have no idea how great is pytest in general. looks more simpler in terms of usage compare to unittest in my opinion.
I have still to open my OOP book in Python, just to make myself not getting lost in the middle.
Thanks for creating the video of demonstrating pytest.
Just notice you type in terminal: " babi .py "
what is that "babi"?
It looks like nano text editor, i guess it is? you just make some alias for nano text editor?
I made my own text editor :D
Why all files of pyupgrade starts with _?
it's a commandline tool -- there is no intended python api -- but people still reach into the internals and muck with them nonetheless
why do you put an underscore infront of main like _main.py, and the other files
it is an attempt to tell people to not muck with the internals
great video, do u have any idea on best way to configure test data for different environments (dev, staging etc) in pytest?
I would hope you're not running pytest in staging?
@@anthonywritescode It is running in staging but its blackbox level test script, but i was just curious how would one manage test data in this situation.
Thanks for the video! Many of your repos have testing directory, what do you store there? A code that is related for tests but you keep it separate because tests directory should contain only tests? Or my guess is wrong
if you search my channel I did a video on my project structure
Hey Anthony! Why do you not like oop? 😊 its a battle am fighting to learn or not but i checked many of your repos and didnt see you using classes, so was hoping to hear your thoughts
it's terrible for large code cases and tends to encourage poor patterns. when a lot of people say "I'm doing oop" I find most of them are instead doing "I'm too lazy to import what I need so I'm using inheritance for convenience"
@@anthonywritescode thank you for responding and everything you share through this channel.
thank you!
Thanks for the video!
It would be helpful to get a more advanced follow up video about fixtures, patches and so on :)
check out the description :P
Great video. Thank you for it!
One thing that I was wondering about is that, as you mentioned in the video, for basically every python file, you create a corresponding test file. Personally, this makes a lot of sense to me and keeps everything in order, but previously in a clean code video, I thought they stated that this could result in overcoupling.
Part of the video: ua-cam.com/video/58jGpV2Cg50/v-deo.html
Are they talking about something fundamentally different, or how would you explain this?
"clean code" is a lie -- and you should be immediately skeptical of anyone trying to sell you that lie
@@anthonywritescode Could you maybe detail this a little more?
@@anthonywritescode dirty code is more fun anyway
great video
I want that keyboard!
I try to imagine that the hands are from someone else and trying to move according to what you say hahaha
they're onto us!
He didint showed whats inside test.__init__.py
it's empty
@anthonywritescode haha, im really stupid
😁
I've heard about this great tool, pre-commit. It's from this really cool guy, you should definitely give it a try *wink*.
It would be nice to have a "getting started with pre-commit".
yeah I've recorded this and thrown it away few times -- maybe the next recording I'll be happy with