Brought to you by Michael and Brian - take a Talk Python course or get Brian's pytest book


Transcript #406: What's on Django TV tonight?

Return to episode page view on github
Recorded on Monday, Oct 21, 2024.

00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.

00:05 This is episode 406, recorded Monday, October 21st, 2024.

00:11 I'm Michael Kennedy.

00:12 And I'm Brian Nockin.

00:14 And this episode is brought to you by Scout APM.

00:17 We would love to tell you more about them later.

00:20 If you want to stay in touch with us, send us show ideas.

00:23 We love it when people send us ideas like, hey, you should check out this because...

00:28 Brian, usually it starts with, I'm sure you've heard of this, but here it is.

00:32 I'm like, I've not heard of that.

00:33 And I really appreciate you sending it.

00:34 So keep that kind of stuff coming.

00:36 It helps us a lot, right?

00:37 Definitely.

00:38 And even if we have, we at most get a couple duplicates.

00:42 That's fine.

00:43 Yeah, yeah, exactly.

00:44 If you want to stay in touch with us or send us things, find us on Mastodon or shoot us an email.

00:48 Links at the top of the show notes.

00:51 And do consider signing up for the newsletter.

00:56 The newsletter that Brian sends out every week just after the show comes out with everything

01:01 we've talked about written down there.

01:03 So you have it.

01:03 Just get an email if you don't have a time to listen.

01:06 Although we prefer people to listen.

01:07 That's always fun.

01:08 Yeah.

01:09 I just think it's nice that people don't have to like write notes down while they're listening.

01:13 They can just get it from the email later.

01:14 Yeah.

01:15 So pythonbytes.fm, click the newsletter button, enter your email.

01:18 Everything will be good.

01:19 Brian, I want to listen to what you want to tell us about first.

01:22 What's up?

01:23 I think people should pay more money to open source.

01:25 So I'm going to cover open source pledge.

01:29 And I'm going to hop over to the Django site to begin with, because that's where I found out about it.

01:35 Because the Django community, Django Software Foundation announced that they are supporting the open source pledge.

01:43 And what does this mean?

01:45 Well, the open source pledge is really simple to do.

01:48 All you have to do is you have to say that you're going to pay open source maintainers.

01:54 Minimum to participate is $2,000 per year per developer at your company.

02:00 So you don't have to count your salespeople.

02:02 You don't have to count the janitor.

02:05 Stuff like that.

02:06 But how many devs you have, $2,000 per year seems like more than reasonable, because you know you're getting that much value out of open source.

02:12 So you self-report.

02:15 So you pledge this, and then you self-report annually, click a blog or make a blog post to say how you've paid.

02:22 Well, there's a whole bunch of, if you take a look, there's a list of members already.

02:28 And I'm not sure how long this has been out, but the list of members includes people like Sentry, have 135 devs.

02:38 And they're pledging 3,704 per dev, which is pretty cool.

02:44 Laravel's in there, so it's not just Python people.

02:47 And yeah, a bunch of great names in here.

02:50 So what is this?

02:52 Oh, button down.

02:52 That's nice.

02:53 Even one dev.

02:54 They're doing 5K per developer, but it's just nice.

02:58 Anyway, so Django says, let's do that also.

03:01 And to help make the Django community more sustainable.

03:06 And I think this is great.

03:09 So they're pledging it.

03:10 I don't know how many devs the Python Software Foundation has now.

03:15 We know they have at least two full-time, but I think it's growing.

03:20 So that's pretty cool.

03:21 So I think this is a great idea.

03:23 And it's neat.

03:24 I pledge your support for open source.

03:26 It's an interesting time for money and open source.

03:29 And I do think it's a good idea as well.

03:31 But there's some crazy stuff.

03:32 Yeah.

03:33 See WordPress.

03:34 It's so insane.

03:36 But that's not pledging money to open source.

03:38 That's something else entirely.

03:40 I do want to put this up there, but I do want to point out there's a cool post by Armin Roeneker

03:47 who talked about the inevitability of mixing open source and money.

03:50 And also just give a shout out to Sentry, who I believe this open source pledge was their idea.

03:55 And Armin was behind the launch of it.

03:57 So well done, Armin.

03:59 Well done, Sentry.

04:00 You know, Sentry's a big sponsor.

04:02 Yeah, a big sponsor of Talk Python.

04:04 So, and I believe they sponsored Python Byte some as well, but certainly Talk Python.

04:08 But there's, if you want to see a bunch of interesting reading, I'll put that article in there as well.

04:13 But moving on, let's talk about TV.

04:17 Let's watch some TV, Brian.

04:18 Okay.

04:19 What's on tonight?

04:20 Catch the nightly news, Three's Company, Four, maybe some Django.

04:25 So I believe this project is put together by Jeff Triplett.

04:30 So well done, Jeff.

04:31 And it's called Django TV at DjangoTV.com.

04:34 And the idea here is these are videos from, it's like a kind of a little mini YouTube-like thing, sort of,

04:41 but for all the conferences.

04:42 So, you know, you want to see the conferences at DjangoConUS of 2023.

04:49 Boom.

04:49 There they all are.

04:50 You want to find all the videos about HTMX.

04:53 There are many because HTMX is awesome and so on.

04:56 Search for it and see friends of ours up there speaking and doing things like that.

05:02 So not a big, deep thing to go into.

05:04 However, it's nice, right?

05:06 Basically, it's a curated list with the descriptions.

05:09 You know, you always want to know, like, when is something published, right?

05:13 That's often the thing with conferences.

05:15 Like, I saw there was going to be a cool talk.

05:17 It happened three months ago.

05:19 Eventually, somebody's going to put it on the internet.

05:21 Probably, we think.

05:23 We're not entirely sure.

05:24 So you can come down here and just hit the RSS feed and subscribe to that.

05:29 And it'll just, all the Django videos start popping up when you subscribe.

05:34 Pretty cool.

05:34 Yeah, it's pretty cool.

05:35 And this is pretty new.

05:36 So if you've got old videos or new conference videos that are not listed here, especially Django-related.

05:43 Yeah, fix it.

05:44 Fix it.

05:44 Fix it indeed.

05:45 All right.

05:46 Well, that is my main one.

05:49 Now, before we move on, let me tell you real quick about Scout APM.

05:55 They're big supporters of Python Bytes.

05:57 So we appreciate that very much.

05:59 So if you are tired of spending hours trying to find the root cause of issues impacting your performance, then you owe it to yourself to check out Scout APM.

06:07 They're a leading Python application performance monitoring tool, APM, that helps you identify and solve performance abnormalities faster and easier.

06:16 Scout APM ties bottlenecks such as memory leaks, slow database queries, background jobs, and the dreaded N plus one queries that you can end up if you do lazy loading in your ORM.

06:27 And then you say, oh, no.

06:28 Why is it so slow?

06:29 Why are you doing 200 database queries for what should be one?

06:32 So you can find out things like that.

06:33 And it links it back directly to source code so you can spend less time in the debugger and healing logs and just finding the problems and moving on.

06:40 And you'll love it because it's built for developers by developers.

06:43 It makes it easy to get set up.

06:45 Seriously, you can do it in less than four minutes.

06:48 So that's awesome.

06:48 And the best part is the pricing is straightforward.

06:52 You only pay for the data that you use with no hidden overage fees or per seat pricing.

06:57 And I just learned this, Brian.

06:59 They also have they provide the pro version for free to all open source projects.

07:04 So if you're an open source maintainer and you want to have Scout APM for that project, just shoot them a message or something on their pricing page about that.

07:12 So you can start your free trial and get instant insights today.

07:16 Visit pythonbytes.fm/scout.

07:18 The link is in your podcast player show notes as well.

07:21 And please use that link.

07:22 Don't just search for them because otherwise they don't think you came from us.

07:26 And then they'd stop supporting the show.

07:27 So please use our link, pythonbytes.fm/scout.

07:30 Check them out.

07:31 It really supports the show.

07:33 Brian, over to you.

07:34 Yep.

07:34 So I'd like to talk about dependencies a little bit.

07:38 So projects have dependencies.

07:40 We often stick them in requirements.txt files or PyProject.toml files.

07:45 But there's a new PEP that just came out.

07:48 Well, it's been out for a bit.

07:50 It was created in 2023, November, but it just got resolved.

07:54 And so I think it just got accepted recently.

07:56 So the resolution date of 10th of October.

07:58 So PEP 735 is dependency groups in PyProject.toml.

08:04 And my first glance at this, I'm like, don't we already kind of have that in extras?

08:09 But that's addressed by this PEP.

08:14 So the idea is that we have other dependencies, not direct project dependencies, but extra stuff,

08:22 like when you're building your docs or you're running your tests or things like that.

08:26 So how do we specify those?

08:28 And there's a couple of ways that people have done it in the past.

08:31 One of them is the extras in PyProject.toml.

08:35 But preceding that, even before we had that, there were extra requirements.txt files.

08:40 So some projects have a main requirements.txt file.

08:43 And then some of them have a requirements.dev file or requirements.doc file or something or several.

08:51 And the problem with that really is that there's no standardization around it.

08:58 And then also there's not really a standardization about the requirements.txt file.

09:04 It's just whatever you can pass to pip install.

09:07 And so like even flags and stuff, which is actually kind of fun.

09:11 Anyway, tangent.

09:13 But so that's, I don't think a bunch of requirements files is the right answer.

09:19 How about extras?

09:20 Well, I was surprised to find out that the extras that you can put in extra dependencies

09:26 or optional dependencies, these are, these might not, I learned that they're, they're using,

09:33 they're, they might not be resolved.

09:36 What am I trying to say here?

09:38 They, they're not guaranteed to be statically defined.

09:42 They could be dynamically defined.

09:44 And, and that I just didn't even know.

09:46 So we do need it to be statically defined so that, so that, you know, tools can read it easily.

09:52 And there's other limitations around using the extras as well.

09:57 Also, I think it's just, I think extras confuses people.

10:00 I know it's a feature of pyproject.toml, but I was confused by it at first, had to like, like

10:06 study it for a bit.

10:07 And it just somehow doesn't, doesn't fit right away with a lot of people's mindset.

10:12 But these dependency groups look pretty good.

10:14 So let's take a look at one example.

10:16 So their example in the PEP just shows you get a block of dependency groups section.

10:22 And then there's stuff like test with a list of, a list of things like pytesting coverage.

10:27 Docs might have Sphinx and, and the Sphinx read the docs theme.

10:31 Typing for doing type checking, like my py and type requests.

10:35 So these all totally make sense.

10:37 And then there's a, there's an extra bit about being able to group others.

10:41 So you could have a dependency group that includes other groups.

10:44 That's pretty cool.

10:45 And then there's some details around like, well, what happens if they conflict with each other

10:49 and stuff?

10:50 So that's well-defined, which is good.

10:52 But I just think like having something like this, like a small block that say, Hey, for tests,

10:57 we use pytesting coverage for docs.

10:59 We use these and have that be nice and succinct in a dependency group section.

11:03 I like it.

11:04 So this has been accepted.

11:05 I'm not sure when it's going to come to a pip near you.

11:09 But it's pretty cool.

11:11 There, there's an example of how it might work at the end.

11:14 Like how, I don't know, reference implementation, how it might work of like saying maybe pip install

11:21 dependency groups and be able to install that.

11:24 But, but that's up to PIP, the pip maintainers to figure out how, how that's really going

11:29 to be used.

11:29 Other interesting thing is extras are extras.

11:32 Extras are on top of the normal thing, everything needed for the, for the system.

11:37 But for example, like when you're doing the documentation build, you don't actually have to build your

11:42 thing to build the docs.

11:44 So these dependency groups do not, they're not extra, they're independent.

11:49 So you could build the, install the documentation dependencies without installing the project,

11:55 which is pretty interesting.

11:56 So anyway.

11:57 That's, that's one of the differences they highlight is the extras require, they add onto the base

12:03 requirements.

12:04 Whereas this, you can have one set of things installed for one scenario and another for another

12:08 without necessarily overlapping them, which you might think, whatever, right?

12:12 It doesn't matter.

12:13 Just install some extra stuff.

12:14 But there's certain things that say work in production, but won't install on windows.

12:18 For example, right?

12:20 I think last I looked, UV loop didn't work on windows, but it was like a speed up for async

12:25 IO on Linux.

12:26 Well, there also might be a, an incompatibility of a dependent library on like your, if you're

12:32 using Sphinx, maybe Sphinx depends on something that's a different version than what your project

12:37 depends on.

12:37 Yeah.

12:38 Yeah.

12:38 Yeah.

12:38 Good point.

12:39 So indeed Henry on the audience throws in that extras are public.

12:43 These are not, unfortunately we lose the ability to guarantee the package was installed.

12:47 Sometimes you want this.

12:49 Sometimes you don't.

12:49 Thanks.

12:50 Yeah.

12:50 hat tip to a transition.

12:52 You didn't know what's coming.

12:53 So overhead talk by the on training.

12:57 We have a free course called static sites and API docs with Sphinx, Python and Markdown done

13:02 by Paul Everett.

13:03 And he unwittingly introduced me to this next topic through that course on here.

13:09 Live reload as in pip install live reload.

13:13 Do you know this?

13:13 No.

13:14 So it's kind of a generic file watcher, mostly focused on web apps, but you could use it for

13:19 literally anything.

13:20 And it's just, you can say, here's a set of file patterns, multiple ones.

13:26 And it can, you can use the star star slash something to like look at sub directories and

13:32 whatnot.

13:32 You know, the, the file pattern craziness to however much you want.

13:38 And then if something changes, it will just run an arbitrary shell command for you and potentially

13:45 restart your web app as well.

13:46 If you give it a web app, like a flask or Django, a whiskey app type of thing.

13:51 So that's pretty cool.

13:51 If you look at the documentation, you will find it to be sparse.

13:55 Like the description of it literally is about eight words, one sentence.

14:00 It tells you how to install it, but like, well, okay.

14:04 But why would I install it?

14:05 You look at the API reference and it's, it's basically just a signature.

14:08 So if people are looking to contribute to a project, you know, maybe given this a little

14:12 example, a little bit of a, a few paragraphs would be awesome.

14:15 But, I gave you an example that we can all use from Python bytes and from talk Python,

14:21 similar apps.

14:22 So similar use here.

14:23 And so I, I'm sharing a gist with folks that will, if you run it a little file here, you

14:30 can just run this as in your terminal or just however you start it and just leave it running

14:36 while you're working on a project and what it'll do.

14:39 It'll track down using pathlib.

14:41 It'll track down the root folder and then find a CSS folder and a JavaScript folder.

14:45 And then it'll run Python against some file that does bundling.

14:51 So for example, at Python bytes, we take maybe six or seven CSS files and minify and bundle them

14:57 into a single one in a certain order.

14:58 And then share that over a CDN.

15:00 Yeah.

15:01 And so depending on how it's running, you may or may not see those changes if you're doing

15:07 like CSS design stuff, same thing for JavaScript, right?

15:10 So what you can do is you just set this up, pointed the right places on your file system,

15:15 say, watch the CSS folder, watch the JS folder and run a shell command, which is tell Python

15:22 to run that Python script that does the bundling.

15:25 Boom, off it goes.

15:26 And you just run that in the background while you're working.

15:28 What do you think?

15:29 That's pretty cool.

15:30 So with this, if you change the JavaScript and CSS, it just automatically updates then?

15:34 Right.

15:35 It looks for any file change within the search pattern, like star star slash CSS slash dot

15:43 star dot CSS or whatever, you know.

15:44 And then if it sees that, it just runs the command, which the command that I gave it is

15:49 to run Python to rebundle our assets.

15:52 So for whatever reason, because one of the things that can happen is, you know, change something

15:57 about a CSS file, forget to bundle it, publish the site.

16:01 And you're like, huh, why does that look so weird?

16:03 Like, why is that not changed?

16:04 But the, you know, the, the, the, the packed version of that one that runs in production,

16:09 but not in development is out of sync.

16:11 And then it's weird.

16:12 Right.

16:12 So if you just, as long as you have this running somewhere, just chilling, then you're good.

16:16 Cool.

16:17 But it doesn't have to be, I mean, the context is web and it's very focused on static websites,

16:22 which is super annoying.

16:23 Like the way you run it, as you say, server dot serve, and it literally starts up a web

16:27 server at some route you give it.

16:29 But I don't want to look at it.

16:30 I'm not trying to look at the website through it.

16:32 I literally just wanted to run the file.

16:35 So there should be some secondary command, like just start watching or something like that

16:40 in the background.

16:41 But it starts a little web server.

16:42 You can just ignore it and, or point it to nowhere and ignore it.

16:46 And then you could get it to do basically when a file changes, run a shell command of

16:51 your choosing, which is pretty flexible.

16:52 Yeah.

16:53 It does.

16:54 I guess to give them a little credit, they do have pages for how to, how to use this with

17:00 Django and Flask and Bottle.

17:02 I don't know anybody that uses Bottle anymore, but.

17:04 No, no, I know.

17:05 But I mean, the pages for it.

17:07 But unnecessarily the right details.

17:10 Yeah.

17:11 It doesn't like, it doesn't really tell you what happens.

17:13 Okay.

17:14 It just shows you what to do.

17:15 And then you can imagine, well, will it restart the app or will it not restart the app?

17:19 Will it just restart the CSS?

17:21 Will it reload the templates?

17:22 There's options of what could be happening, but it doesn't really say.

17:25 Anyway, it's a cool project.

17:27 I would love to see a little bit more description just so that I can get a little more traction.

17:31 But yeah, there you go.

17:33 Paul was using it for when he changed a markdown file in the course.

17:37 It would run make HTML out of Sphinx to automatically rebuild the website as you just typed in it.

17:44 Oh, that's cool.

17:45 Yeah.

17:45 All right.

17:47 Well, do you want to jump into extras?

17:49 Let's jump.

17:50 Okay.

17:51 Do you want to hit yours first?

17:52 Yeah, I'll go first.

17:53 Mine are super short.

17:54 So, a couple of things.

17:56 First of all, I was looking at our Umami.

17:59 That is Umami Analytics.

18:03 Is it .is?

18:04 I think it is.

18:05 Umami.is.

18:06 Analytics.

18:07 Yeah, perfect.

18:08 And I noticed something unusual, that 14% of our listeners are from Germany.

18:14 Oh, that's cool.

18:15 That's pretty interesting, right?

18:17 Especially given, you know, this is in English.

18:19 It's not their native language.

18:21 But, like, more than Australians, the Germans are listening to our stuff.

18:24 So, thank you, Germany.

18:25 Maybe we should have a competition to try to get the country.

18:29 Exactly.

18:29 Exactly.

18:30 And then, not that I intended this to be a German episode, but here are German extras.

18:37 But, the German company, Hetzner, have you heard of them?

18:40 They're like DigitalOcean, Linode, so on, AWS.

18:43 So, I've heard a few people talk about them.

18:46 And they have really interesting hosting models.

18:49 Like, they'll give you super affordable VMs, lots of bandwidth, so on.

18:54 So, for example, for an 8 gig, sorry, 16 gig, 8 CPU server in DigitalOcean, it's $112.

19:04 And it's hard to tell exactly on AWS and Azure, but I believe AWS is $200 and Azure is $350 per month, okay?

19:12 Okay.

19:13 I go over here to Hetzner, prices, and you pick, say, shared AMD, and you pick your country to be US.

19:21 Come here.

19:23 Oh, where'd you go?

19:24 Same server is $25.

19:26 Wow.

19:26 And it comes with 20 terabytes of bandwidth, which, quick math, I believe that's about $2,000 at AWS.

19:35 Okay.

19:36 And that's included in the $25.

19:37 Cool.

19:38 So, the news is, why am I even mentioning this?

19:40 The news is, they recently came to the US.

19:42 All right.

19:43 They used to be just a European company.

19:46 Now, they're available in the US.

19:48 So, that opens up a lot of interesting hosting possibilities.

19:51 Are you switching anything?

19:53 I'm thinking about playing with it.

19:55 We'll see how it goes.

19:56 I actually asked people in Mastodon, what do you guys think about this company?

20:00 And I got a lot of German folks who said they're having a lot of good experiences with it.

20:05 So, we'll see.

20:06 Okay.

20:06 But I'll let you know if we do.

20:08 I haven't switched anything around.

20:10 But it's pretty interesting, right?

20:11 That you can get so much compute for so affordable.

20:14 Yeah, that's pretty cool.

20:15 Anyway, those are my extras.

20:16 Over to you.

20:16 A couple blog posts that I wanted to highlight that were kind of neat.

20:22 K.J. Miller.

20:23 Personal blogs are no longer personal when AI gets too involved.

20:28 So, I know people are using AI and chat-like things to come up with some ideas and stuff.

20:35 And that's pretty much what K.J. Miller is talking about.

20:39 It's not necessarily terrible to do that.

20:42 But be careful what you're doing and why you're doing it.

20:46 So, for instance, coming up with ideas or if you're stuck on how to phrase something,

20:52 having somebody help with that is great.

20:55 And writing is hard.

20:57 So, getting some advice, fine.

20:59 But it should still be your voice.

21:01 So, I love, I was wanting to hop down to his advice.

21:05 It says, obviously, if you're reading this and not, obviously, if you're reading this and

21:12 not getting ChatGPT to summarize it for you, you care about my words to some degree.

21:18 So, you are reading somebody's blog for their voice.

21:21 So, keep that in mind when writing your own blog.

21:23 So, especially if you're writing a blog to try to get hired later, it doesn't help you

21:28 any to just regurgitate some ChatGPT stuff and copy and paste it.

21:33 We don't need more people like that.

21:35 I mean, if you're doing it to try to fill up your blog for selling something, I still don't

21:41 like that, but you know, your business.

21:43 But if you're trying to do it to highlight what you write like, then you need to write it.

21:49 And also, if you're doing this to help your future self, make it personal.

21:53 Also, like, if you're not writing it or at least rewriting it, writing it in your voice,

21:58 it's not going to stick in your head.

22:00 So, you're not doing yourself any favors.

22:02 There is a bit about, he talks about if you're doing this to create content in another language,

22:08 learn about that community's writing style, which makes sense.

22:12 But I kind of think there's translation tools already built into some browsers.

22:18 And if somebody from another country really want to read your stuff, maybe they probably

22:22 will anyway and translate it if they want to.

22:25 So, I got really no interesting opinion about that.

22:28 But I think I like these ideas about if you're doing it to gain, you know, build your personal

22:34 brand or put yourself up as an expert in an area, using AI to do that's really not helping

22:40 you.

22:40 I think people can figure that out because there'll be an inconsistency in writing styles in different

22:46 posts.

22:47 And then also, it's your personal thing.

22:51 People are trying to reach you.

22:53 So, be you.

22:53 Anyway, that was one extra.

22:56 The other one was something that I just didn't think about, and I probably should, is mind your

23:01 image metadata.

23:01 This is an article from Stephanie Molin right there at the top.

23:09 She presented at PyCon Estonia.

23:11 Anyway, the talks about the EXIF interchange format.

23:17 Basically, pictures have tons of metadata in it.

23:20 And if you don't want to have that published everywhere, and you might not, you might not want personal

23:27 locations for exactly where your photos are.

23:29 She talks about how to tell using tools to figure out what's in there and also talks about tools

23:36 to rip them out.

23:38 And then even talks about using a pre-commit hook to strip out pictures that you're including as your

23:44 static images or in your Git repo.

23:47 That's cool.

23:48 If you're putting your Hugo static site, just none of it has any of that in there.

23:52 That's a pretty cool idea.

23:53 I like that.

23:54 Those are just my two extras.

23:56 Excellent.

23:58 I'm having Stephanie on Talk Python Thursday.

24:01 Cool.

24:01 Three or four days from now.

24:02 Sweet.

24:03 Yeah.

24:03 All right.

24:04 How about our joke?

24:06 Let's do it.

24:07 Okay.

24:07 How are you?

24:08 This is a dumb joke, but I love it.

24:09 It's an oldie, bitty, goodie.

24:11 I'm linking to a savvy programmer blog, but I've heard it before.

24:17 Essentially, it's, okay, a programmer's partner asked them, hey, would you go get a loaf of

24:24 bread from the store?

24:25 And if they have eggs, grab a dozen.

24:27 So while later, the programmer returns with 12 loaves of bread and says they had eggs.

24:31 So literal.

24:34 I love it.

24:34 Anyway, there's a handful of jokes here.

24:39 Pretty decent.

24:40 Okay.

24:41 I didn't read very many.

24:42 I'm going to go check some of them out.

24:44 That's awesome.

24:44 Anyway.

24:45 Excellent.

24:46 Yeah.

24:47 Very funny.

24:47 Thanks again for the show together.

24:50 And everyone, thank you for listening.

24:51 Talk to you later.

Back to show page