Transcript #172: Floating high above the web with Helium
Return to episode page view on github00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.
00:05 This is episode 172, recorded March 4th, 2020.
00:10 And I am Brian Okken.
00:12 And I'm Michael Kennedy.
00:13 And this episode is brought to you by DigitalOcean.
00:16 And they've got all sorts of cool stuff we'll hear about later.
00:20 Who's going first? I always forget.
00:21 You know, I guess I'm going to jump in on this one because I've got some cool stuff from Hank.
00:25 Hank! He even messed his name up worse than I do.
00:29 Hennyk?
00:30 Okay, cool.
00:31 All right. Sorry, Hennyk.
00:32 I have to give you a bad time because he gives me a bad time all the time.
00:34 Yeah, well, it's a cool but unusual name, which is probably going to result in some mispronunciation.
00:40 He's got a cool article he tweeted about a little while ago, a week or two ago.
00:47 And I just thought it was really interesting.
00:48 And basically, it's his thoughts on running Python in production.
00:54 So it's kind of a look back on some places.
00:59 He heard interesting discussions on people running Python in production, as well as maybe some got some nice little call outs on things that seem solved, but aren't solved that are interesting to talk about and whatnot.
01:12 So I just thought I'd maybe talk about that a little bit.
01:14 Yeah.
01:15 Yeah.
01:15 I mean, I definitely relate to this being someone who runs Python in production.
01:19 So in order to keep the two podcasts, the courses and various other things, other services running, there's like eight servers and whatnot.
01:28 So there's a non-trivial amount of DevOps production architecture stuff.
01:34 It's not anywhere near Facebook, Google or whatever, but it's way more than, you know, a $5 host running some like WordPress thing.
01:40 Right.
01:40 So it's meaningful, I guess.
01:42 So anyway, his article, basically the premise is that he's missing a key part of the public Python discourse in that it seems like people really aren't talking about running Python in production.
01:55 Although maybe the exception of Instagram or Spotify, right?
01:58 Yeah.
01:59 That's pretty interesting.
01:59 And he listened to this podcast episode.
02:01 He recommended, or I guess listen to this podcast episode, sort of kicked him off down this path of thinking about it.
02:06 Like there was this podcast and I'm trying to remember what was it called?
02:10 Here, I'll pull it up.
02:11 It's called, well, running in production.
02:13 Actually, it's a pretty interesting one by Nick Gentakis.
02:18 Probably mispronounced that name as well.
02:21 But Nick's got an interesting thing where he talks to people from all sorts of different technology backgrounds, JavaScript or Ruby or Python or whatever.
02:29 And he interviewed this guy named Gareth Thomas from the UK where they have some Plone, I believe it's Plone app, that is actually running like 10% of, getting like traffic from 10% of the UK schools or something really interesting in this.
02:48 But it was more interesting to just think about listening to that episode, looking at Hank's article and saying, when do I agree with them?
02:58 When do I disagree?
02:59 And he said, look, I disagree with a lot of their choices, actually.
03:03 I think they're using microservices a bunch.
03:06 And he was like, thank goodness, I'm not doing microservices, basically.
03:11 And it's really interesting, even if you disagree, to think about the trade-offs that people made.
03:15 Because while you might make different trade-offs, that might be because you have different goals or different things you're optimizing or different experiences or things that you need over what they need.
03:27 Right?
03:27 So I just think this idea of exploring how people are running Python in production, how they're solving problems, it's pretty interesting.
03:32 Yeah, I also kind of have to agree that I like the idea of hearing more about the pathway of why people are where they're at, what decisions they made and what things they faced and why they made those choices.
03:45 Because that's almost more interesting than what end product they came up with is what the path they took to it.
03:53 I mean, like Lord of the Rings would be nothing without the path to the end, right?
03:57 Exactly.
03:58 Oh, yeah, and they get the ring back.
03:59 Yeah.
04:01 Yeah, so his article, like all good complaints, comes with a suggestion.
04:06 And he says, at the end, here's a bunch of things that could get discussed more.
04:11 And so here's an offer.
04:12 I would love to encourage people doing interesting stuff with Python, running websites or APIs and whatnot, to tell them basically to do talks at PyCon, at meetups, and in blogs.
04:24 And I think he even offered to help mentor people to get those kind of talks accepted more frequently at conferences.
04:30 I think that's a great idea.
04:31 I think it's a great idea.
04:32 And, you know, maybe we should do that at the PDX Python West meetup.
04:37 That'd be fun.
04:38 Yeah.
04:38 Yeah.
04:39 We think about that.
04:40 But yeah, I definitely like this idea because on one hand, if it's kind of always the same story, it's not that interesting.
04:46 But I do think there's a lot of trade-offs that people are making.
04:49 And I think it's pretty fun to see what's working.
04:52 And it's clearly going on.
04:54 We're just not talking about it because we're, I mean, you and I have noticed that there's a lot of people in the Python community that are in the website or the website of the Python community.
05:05 And it's way more than just the Instagrams and Dropboxes of the world.
05:09 Yeah, absolutely.
05:11 Absolutely.
05:11 Yeah, it's really cool.
05:13 And there's a bunch of more stuff that I'm not covering in this article.
05:15 But I mostly covered it because I love his offer of like, hey, let's get more of this conversation out there.
05:21 You know, we could do open spaces.
05:23 We could do Python, PyCon talks, suggestions, you know, proposals, things like that.
05:29 I guess one final thing to throw out there is Dan Bader and I did have this conversation for Talk Python and the training and Python Bytes and whatnot, as well as for RealPython over on Talk Python episode 215 at the last PyCon.
05:44 We recorded that one.
05:46 So we'll see what happens with this PyCon.
05:49 But that's a small contribution towards that.
05:51 And that was a really popular episode.
05:53 But I definitely want to encourage people to take Hennick up on this, up on his offer here and get the word out a little bit more.
06:02 All right.
06:03 Yeah.
06:04 Yeah.
06:04 So, Brian, when I think about testing and whatnot, I feel like you should really be honest and like testing to tell a true story.
06:11 And you should never like cheat with testing, should you?
06:14 Yeah, only, yes, you should definitely cheat.
06:16 Cheat as much as you can.
06:17 Tell us about this next one.
06:19 So this comes from, I think it's Simon Willison.
06:22 The article is called How to Cheat at Unit Tests with pytest and Black.
06:26 It's got all my favorite things, testing, pytest, Black, and well, I'm not a fan of the unit part, but we'll get there.
06:35 So the premise is, I'm going to quote this, in pure test-driven development, you write a test first and you don't start on the implementation
06:43 until you've watched a test fail.
06:45 Okay.
06:46 So the idea is you, it's the red-green refactor thing.
06:50 So you write a failing test, you write code to make it pass, and then you refactor it so you're happy with it.
06:55 And if I don't do that, I'm cheating?
06:56 Yeah, apparently.
06:57 I think I might have cheated accidentally, recently.
06:59 Okay.
07:00 Well, yeah.
07:01 My thoughts partly on that is there is no such thing as pure test-driven development.
07:07 Even Kent Beck himself says he didn't make this stuff up.
07:10 He rediscovered it from previous best practices.
07:14 So there's no pure in test-driven development.
07:17 We can't even agree on, like, whether a mox are good or evil or what a unit is.
07:21 So whatever works for you, man.
07:23 So Simon's process really was to cheat on this.
07:26 And the way, and I think this is just clever pragmatism.
07:30 His cheat method was to write a pytest test that calls a function that he's, so he's been working on a function, and he thinks he's happy with it.
07:39 And he writes a test that calls it, but then compares the output to, you know, something he knows won't pass.
07:46 Like, just the output equals false or something.
07:49 And you know that a cert's going to fail.
07:51 So you run the test, and when it fails, you take a look at the output.
07:55 And if you're happy with the output, you just copy that, just highlight it, copy and paste it into your test, and now your test should pass.
08:02 So this feels like cheating, but it's really just taking a manual test and turning it into an automated regression test.
08:11 Especially when you're exploring stuff, I think this is a great way to build up some of your test coverage.
08:17 The bit about black is that the output might be this big, long blob something, like a dictionary or a big list or something, and it might not be formatted well.
08:27 And that's where he just turns black on his test code and reformat it nicely and makes sure it still passes.
08:33 So I think this is a good time saver.
08:35 This is interesting.
08:36 I was working on some tests recently where I had a big chunk of test data that I wanted to compare against something, kind of like he's describing here.
08:46 And I was really torn.
08:47 I'd love to hear your thoughts on this.
08:49 You know, I put this at the top of my test file so I could reference it, right?
08:54 I didn't put it in the test.
08:55 I put it kind of separate because I'm like, well, this thing is, you know, it basically fills the screen.
08:59 So I didn't want it to generate a huge test.
09:01 I want to say compare against that thing, right?
09:04 And one of the thoughts I had was creating like a, I don't know, a test data module where I could pull those things out, like put it completely into a different file and pull it back.
09:13 And it sounds like that might also be a nice way to organize things here.
09:18 But at the same time, it takes what you would see as I'm comparing against this and it hides it away behind, you know, a label of whatever that test module is.
09:26 What are your thoughts on that?
09:27 Good, bad, indifferent?
09:29 I think there's lots of times where that is a good thing, especially like you said, it's a data, a big structure or something that you're comparing against.
09:39 One common method to do something like that is if there's like, for instance, it isn't really what you're asking, but if there's, instead of comparing a whole bunch of different fields or something, to actually compare structures.
09:51 So to create the expected data structure, especially with data classes, it makes it pretty easy.
09:56 You can just say, this is my expected object.
09:59 And what I got back was this thing and compare those two.
10:03 Now, if that thing, if all the data is huge and it makes it more clean to work with your test, to stick it in a different file, then go for it.
10:12 I think that's fine.
10:13 I mean, there's a method of regression testing, which is kind of the model of, I know it works now and I'm going to modify the code for some reason.
10:23 So I, instead of trying to come up with thorough tests for everything, just running it with a bunch of logging and stuff and capturing all that.
10:31 Yeah, absolutely.
10:32 And then running it again and make sure all of your output and logging is the same and just comparing against that.
10:38 It's yucky to work with in the long run, but in the short term, it's a pretty handy, quick thing to do.
10:44 Yeah.
10:44 Instead of changing your entire architecture so you can mock out everything and then who knows if you get that right.
10:49 You're just like, all right, I don't want it to change.
10:51 Let's just start from like, keep it where it is.
10:54 And if it breaks, then we'll figure out if that's a change we wanted.
10:58 Right.
10:58 But just to know that it didn't change is really helpful.
11:00 And that's a quickies way.
11:01 I like it.
11:02 Right.
11:02 And I mean, change detector tests are a smell that you need to be aware of because they're not.
11:07 You want to be able to change your architecture.
11:09 As long as you can make sure that you're checking for, you don't want the behavior to change.
11:14 Sometimes those are good things.
11:16 Yep.
11:16 I agree.
11:17 Be a pragmatist.
11:18 For sure.
11:18 Good advice.
11:18 You know what else is good advice?
11:20 Work with DigitalOcean.
11:21 Yeah, definitely.
11:22 We've been working with DigitalOcean and we've got a lot of our infrastructure there and we've been really happy with it.
11:27 And so one of the things they've got, they've got Kubernetes clusters and all sorts of stuff.
11:32 So, however, getting started with hosting and running Linux servers or Kubernetes clusters and all that stuff can be a little tricky.
11:40 And getting into that, going from just building on your own computer to dealing with all of this, some people might not know how to do that.
11:47 And so that's one of the reasons why DigitalOcean launched their new support center.
11:52 So the support center makes it easier to find the answers to your questions and to get help that you need right when you need it.
11:58 You can search across product docs or community tutorials and forums and it's all in one place and you can get all your answers.
12:05 So I'm sure that's going to help a lot of people really a lot.
12:08 So check this out.
12:09 You can visit pythonbytes.fm/do support to see their tutorials.
12:15 And of course, you can use pythonbytes.fm/digitalocean to get $100 credit for new users.
12:22 Their tutorials are pretty awesome.
12:24 And I just want to tell people like how helpful they have been.
12:29 So typically, you know, especially when I was getting started, I'm like, man, how come this micro whiskey thing won't start?
12:36 It seems like it should work when I run it, but it won't.
12:38 It's probably something like the logging file didn't have permission to write through or something weird like that.
12:44 You go search for that and it's very likely that one of these tutorials is going to come up.
12:47 But, you know, I just went and put micro whiskey into their tutorial thing here.
12:51 And it comes up how to serve a flask app with micro whiskey and Nginx on Ubuntu 18.04.
12:56 But then it has a dropdown.
12:57 Oh, would you like to do that on 16.04 or 14.04 or maybe on CentOS 7 or whatever?
13:04 And you can actually change the operating system it's running on and the tutorial will adapt.
13:09 I mean, it's ridiculous like how involved it is.
13:11 Yeah, they've really done a lot to help.
13:14 Novice users come up to speed to get things running well.
13:18 Yeah, I just remember how helpful that stuff was for me.
13:20 So, yeah, check them out at pythonbytes.fm/digitalization.
13:22 Get that credit, but then use their support center to actually get going.
13:26 You know what I'm glad I don't have to support?
13:27 Hundreds of microservices.
13:29 Yeah, me too.
13:32 So, I think I found this from Mahenyuk's article when he was talking about how people were running in production and whether or not they should have microservices or not.
13:42 And that podcast I told you about, I believe those people were using microservices.
13:46 He's like, yeah, no way.
13:47 No, thank you.
13:48 And referred to this article by Alexandra Noonan, who works for a company called Segment.
13:56 And this is like a retrospective on their experience.
13:59 So, they had started out with a monolith app.
14:01 I believe they're doing JavaScript, but it doesn't really matter.
14:03 Basically, it's like package managers and maintaining versions that talk to APIs.
14:08 The same story for Python.
14:10 You know, you just switch the code samples or whatever, and they're not really relevant.
14:14 So, there's this article called Goodbye Microservices from 100 Problem Children to One Superstar.
14:21 And it talks about how Segment was founded during the height of microservices as the architecture du jour, right?
14:30 Architecture of the day.
14:31 And how to sort of decided that was going to solve all their problems.
14:36 And at first, it did.
14:37 But as they grew and grew and grew, it turned out to be such a huge headache.
14:42 So, they had three software developers.
14:44 And eventually, they said, basically, their three software developers were spending almost all their time tracking down broken tests across these hundreds of different variations of microservices and all sorts of stuff.
14:58 And they were just going nowhere.
15:00 So, it talks about how all the benefits that microservices should have, like prove modularity, reduce testing burden, better functional composition, isolation, team autonomy, and all that.
15:12 And how many of those things turned around to actually become like molasses in their world and slowed them down instead of letting them work faster.
15:20 So, basically, it's a really concrete story about how they took a step back from microservices, how they actually made that step backwards.
15:28 Because with 100 microservices into one app, that's kind of a beast to pull off.
15:33 And how it helped them basically get everything under control again.
15:37 So, what's really interesting is basically the places where things broke down.
15:41 So, for example, each microservice was talking to a similar but slightly different API, like customer integrations and stuff.
15:50 And they had slight different needs.
15:53 So, over time, some of the core bits of those libraries were slightly different across the different APIs.
16:01 And it became, instead of having things you manage separately for each endpoint, you actually ended up with 100 different services, all of which you had to manage.
16:10 And, like, if you're going to make a big change, you've got to test it against all these variations.
16:13 Their tests were super slow to run.
16:15 And there's just a lot of things.
16:17 Like, also dependencies, you know, as in requirements.txt type dependencies.
16:22 Yeah.
16:23 They wouldn't upgrade all of them at the same time because they wanted to make sure that they had to test it and whatnot.
16:29 And so, if you're going to, you know, be running on, say, requests 2.1 over here and 2.2 over there, are you sure, you know, like, if there's a problem with that?
16:40 Like, how do you deal with that?
16:41 Now, I'm a big fan of the big monolith type apps and keeping a little more control over it that way.
16:49 So, I'm all behind this sentiment.
16:51 But I do feel like they could have actually done a lot of work on the DevOps side to make this dramatically better.
16:57 And maybe, who knows, maybe they would have never switched.
16:59 Yeah.
17:00 Did somewhere I catch that there was a limited number of developers?
17:03 I think there was, like, three or something.
17:05 At one point, there was three working on all these things.
17:08 And, you know, microservices are often touted as being really great ways for dev teams to have autonomy.
17:15 But when your dev team consists of three, you know.
17:18 You don't really need autonomy.
17:19 You're already autonomous.
17:20 Exactly.
17:20 Yeah, exactly.
17:21 Like, that's one team.
17:22 It doesn't need more than one thing to be autonomous, right?
17:24 Generally, basically speaking.
17:27 But, you know, so let me just, like, take a step back and say, for example, like, one of the big problems I said is we've got 100 different services that behave similar but not the same with slightly different integrations against different API endpoints.
17:39 And we're feathering out or fanning out requests to those services based on which thing they're kind of integrated with.
17:45 And the big problem was the dependencies.
17:48 Well, if they had used something like Docker and Kubernetes.
17:51 And they forced them all to say, we're going to install the same runtime environment with the dependencies pre-configured.
17:59 And the only way you get to release a new version is you get your little thing to work with the latest image that has a uniform set of dependencies across the board.
18:10 Well, that sounds like that would have completely taken out one of these problems to me, right?
18:14 I mean, sure, you might have to do a little work to replace a new version of some thing, but you're keeping it in sync, right?
18:20 So it seems like there's a couple of things like that that they could have done.
18:23 There's other issues on the testing side that were caused by these variations.
18:27 And I feel like there could have been some uniformity stuff done, especially around Docker.
18:31 That could have made this a lot better.
18:34 But still, I think there's a lot of interesting lessons there.
18:37 Yeah, I think I'm looking forward to reading this because that sounds like an interesting story.
18:40 Yeah, yeah, it's pretty good.
18:41 Well done.
18:42 Has nice pictures.
18:42 Yeah, neat.
18:43 Oh, I like pictures.
18:45 Speaking of tests and running them on the web.
18:46 Yeah, so one of the workhorses of front-end web testing is often Selenium.
18:52 And Selenium's awesome, but it can be abused.
18:56 And also, it takes a little bit of knowledge.
18:59 So I think we've covered others.
19:01 There are some higher-level APIs that use Selenium under the hood but have a different interface.
19:06 And I'm a fan of a lot of this sort of stuff because if it simplifies your life, go for it.
19:14 One of the things we're going to cover today is Helium.
19:17 It's a newer...
19:18 Oh, it's very much newer.
19:19 It's only a few months old.
19:20 Python library for automating web browsers.
19:23 It's a project that's built on top of Selenium.
19:27 And even though it's fairly new, it's already got like over a thousand stars on GitHub.
19:33 That's cool.
19:33 The claim is Selenium Python 50% easier.
19:38 Helium is the best Python library for web automation.
19:41 Well, of course, it's saying that to itself.
19:43 But it does look pretty clean.
19:45 There's some pretty clean drivers to be able to control Chrome, control your browser, and navigate some stuff.
19:52 So it looks good.
19:54 Yeah, I really like this.
19:55 I think Michael Herrmann did an interesting job on this.
19:58 And the reason that I think this is neat is it takes you away from working at the structure level.
20:07 So for example, just like Selenium, you say, I'm going to open up this website, right?
20:12 So you say start Chrome, GitHub.com slash login.
20:15 But instead of doing some kind of CSS selector to find the text box, you just say write.
20:22 If you want to set something to a text box, you say write this text into.
20:27 And you just, you know, give it like a short bit of text, like the label that is right before, immediately before the text box.
20:33 All right.
20:34 So write something into username.
20:37 And that'll just fill out the username thing.
20:39 Then write something into password.
20:41 And that'll type in the password and then click the button.
20:43 They say click sign in.
20:45 And it just finds the button with the text sign in.
20:47 What is nice is like what a human sees about the page is how the code interacts with it.
20:53 And you might say, well, that's unstable, right?
20:55 What if somebody changes the text?
20:57 Well, if you've ever had to work with CSS selectors and then somebody redesigned the site and your automation stopped working, it's not a whole lot better.
21:04 So you might as well make it easy for humans as far as I see it.
21:08 Yeah.
21:09 And the, I mean, the API is like so clean and short.
21:12 So you've got like, think like function calls, like click man with, you just give it like the tag of thing, the, the button tag that you're going to click on.
21:22 So like, yeah, it's pretty sweet.
21:24 And to fill in a username, for instance, in a username field, it just is right.
21:30 And then you give it two parameters that the name of the field that you're going to write into and then what you're going to write in there.
21:36 So this is pretty slick.
21:38 I like it.
21:38 Yeah, for sure.
21:39 Too many things get the for humans tag in Python, but this one kind of could get that.
21:43 Yeah.
21:44 And so since this is new, I'll be curious.
21:46 And there's a lot of web testing going on.
21:48 I'll be curious to see if, where this goes, keep an eye on it.
21:52 Yeah, absolutely.
21:53 And the easiest way, if you want to get a sense of like, whether or not this is interesting for you is just go watch the, there's a little GIF animated GIF.
22:02 Just watch that for 10 seconds and you'll have a quick idea what you can work with there.
22:05 We've said this before.
22:07 The animated GIFs of how things work are a good thing to get people excited about a project.
22:12 This project also includes a cheat sheet of some of the common things you might want to do.
22:17 Single page with a whole bunch of stuff.
22:20 It's kind of like an FAQ, but, but just sort of, no questions, just answers.
22:25 Yeah.
22:26 So I'm pretty certain that's a good idea, but sometimes you're not certain.
22:30 Yeah.
22:31 Lots of times.
22:32 So I remember, I don't know where I learned more about this.
22:35 Either this was in physics or this was in statistics or something.
22:40 I think it was one of my science classes in college.
22:44 I promptly forgotten it.
22:45 So there's no way I could, could work with uncertainties and measurements really well.
22:49 Maybe it was even engineering.
22:51 I'll tell you a quick example and then I'll ask you a question.
22:54 You can't look ahead and don't cheat because I have the answer in the notes further down.
22:58 So imagine we're back in school or you're solving a real problem.
23:02 Jane, she needs to calculate the volume of her pool.
23:04 So she knows how much water it'll take, right?
23:06 So she measures the length, the width and the height.
23:09 Now, of course you can't measure it ultra precisely.
23:12 And also there's probably some variation in there.
23:14 So she determines the length is 5.56 meters plus or minus 2.5%.
23:20 Like that's her guess on the inaccuracy.
23:22 And the width, 3 meters plus or minus 2.6%.
23:25 And the depth, 3 meters plus or minus 3.7%.
23:29 So what is the uncertainty, right?
23:33 That plus or minus a little bit, that uncertainty.
23:35 What is the uncertainty in the volume?
23:37 Which is the length times the width times the depth.
23:40 Oh, I can't even remember.
23:42 Is it right?
23:42 Do you multiply them together?
23:43 Yeah.
23:44 Do you multiply them?
23:45 Do you add them?
23:47 Do you average them?
23:48 Like what the heck?
23:49 Do you take the max?
23:50 I don't know.
23:51 Well, there's actually very strict rules about how you do it.
23:55 So when you multiply things, apparently, I didn't remember this, but I've looked it up.
23:59 Apparently, you add the uncertainties when you multiply things.
24:04 So in this case, it's 2.5 plus 2.6 plus 3.7 is 8.8% uncertainty.
24:09 That is super tricky.
24:11 And these kinds of calculations are the kind that ends up with spacecraft burrowing into like a desert or into a moon.
24:20 Because they're like, oh, did we get that wrong?
24:23 Whoops.
24:23 Right?
24:24 Did we use the wrong units or did we get the wrong uncertainty or whatever?
24:27 Right?
24:27 Yeah.
24:28 So there's this really cool library called uncertainty.
24:31 And it comes with all these different math operations.
24:34 Like it has values, like a float.
24:37 And it has a sine, right?
24:40 Which is like, you know, sine, cosine, tangent sort of thing.
24:42 So you can do mathematical computation.
24:45 But instead of having a regular float, it has an uncertain float, a u float.
24:50 So you create like x would say like a u float of 1 is the value.
24:53 And then comma 0.1 is the uncertainty.
24:56 And then if you were to do math with it and print it out, it'll say like 2 times x would be 2 plus or minus 0.2.
25:05 And so it always carries its uncertainty.
25:07 And then as you take like the sine of it or you multiply or you square it, it will actually integrate and consider all those different uncertainties to give you a final uncertainty in your output.
25:18 Isn't that awesome?
25:19 That's very cool.
25:20 Yeah.
25:21 This is useful in lots of fields.
25:23 Yeah.
25:23 If you ever have to compute with uncertainty, this seems so glorious.
25:28 This and pint, right?
25:30 If you could put this and pint together, then it's on.
25:32 Because pint lets you work with different units of measurement and then add and multiply and divide them.
25:38 And then you throw the uncertainty on top of that.
25:40 Boom, you're golden.
25:41 Yeah.
25:41 Yeah, that'd be cool.
25:43 We had worked with once with a measurement value that it was a power level for a cell phone.
25:48 And the uncertainty ended up being plus or minus like the amount of power that the sun produces.
25:56 So it's like we essentially don't know the answer if that's the uncertainty.
26:01 Right, right, right.
26:02 It could take a AA battery or it could melt the earth.
26:05 We're not really sure which.
26:06 We're not sure which.
26:07 Yeah.
26:08 Not ready for shipment yet.
26:10 Exactly.
26:11 Maybe we've got to get more accuracy there.
26:13 Anyway, this comes from Tim Head who mentioned it on Talk Python where we recently did an episode on Binder,
26:20 which is super interesting but not yet released.
26:22 So eventually we'll talk more about that there as well.
26:24 Anyway, uncertainty, cool little library if you've got to do any sort of computation with this kind of stuff.
26:29 Yeah, I think it's cool but I'm not sure about it yet.
26:31 Yeah, well, can you ever be?
26:33 No.
26:33 But you can be sure about the level at which you can't be sure using it.
26:37 Yes.
26:39 Awesome.
26:39 I'm pretty sure that I wish my Python prompt was cooler.
26:43 Well, I'm okay with my Python prompt.
26:46 Are you?
26:47 I don't know.
26:48 I mean, come on.
26:49 Think of all the options.
26:50 You could do anything you wanted and I never thought to do that.
26:55 I mean, I do it with my like a bash prompt and stuff.
26:58 You know, we put our virtual environment name in there.
27:01 It's stuff like that.
27:03 Get status, get branch, all that kind of stuff.
27:05 Yeah, definitely.
27:06 So you can change those things.
27:07 So why not?
27:08 This article comes from, I think, Arpete Bayani and it's called Personalize Your Python Prompt.
27:15 Those three right angle, right, what is it?
27:17 The right, left, greater than signs that are together when you're doing interactive Python.
27:23 Apparently you can muck with those.
27:24 There's a sys.ps1 variable that if you sign to that, you can change it to whatever you want.
27:30 And of course, the author didn't stop there.
27:38 You have a non-string object.
27:38 You have a non-string object to make it dynamic.
27:42 So he gives a little example to where you can, and the way you do that is you have an object that has a dunder stir method.
27:49 If that has dynamic action, that gets called every time.
27:53 So for every prompt.
27:54 So this is pretty neat.
27:55 He has an example of doing some stuff, but I wanted, I didn't have time to do it this morning, but I was working on it.
28:01 I was trying to get a prompt that would mimic the Windows command prompt because apparently I want that on my Mac because that would be fun.
28:11 You just want to confuse people like, what are you doing?
28:14 This isn't.
28:15 I mean, I mean, the C colon backslash greater than was easy, but I wanted to also put the Windows, the path in there and flip the direction of the slashes and stuff like that.
28:28 Yeah.
28:28 Yeah.
28:28 That's really cool.
28:30 And I didn't, one didn't know that you could just set that, the Sys, you know, import Sys, Sys.ps1 equals something.
28:37 And that now is your prompt.
28:38 But I didn't really think that it could be a dynamic object like that has a stir, dunder stir.
28:44 That's pretty cool.
28:45 Yeah, that is neat.
28:46 You could easily set up something like the Jupyter.
28:48 You have Jupyter notebooks.
28:50 You have bracket one, bracket two, bracket three for your various calculations, like five lines.
28:55 You got that in your Python prompt if you want it.
28:57 It doesn't have quite as much value because you can't change the order, but still, it's pretty interesting, I think.
29:01 Yeah.
29:02 Yeah, that's cool.
29:03 Yeah, quite cool.
29:04 All right.
29:04 Well, that's a good little find.
29:05 A quick and easy to play with.
29:07 Well, do you have any extra stuff for us?
29:09 Oh, not really.
29:10 I'll go and throw one thing out for you.
29:11 So, I finished my Python for Absolute Beginners course.
29:13 And so, now I'm starting a new course, which is like adding a CMS to a proper data-driven web app.
29:21 So, if you've got a Flask app or Pyramid or Django or something like that, and you want to let other people write part of the site, and the rest is more like Amazon would be with, you know, here's the categories, here's the products, here's the product page, and here's the review page.
29:35 Like, you know, very structured, but you want to just let them like write freeform stuff.
29:39 So, I'm working on a course that lets you kind of add that to existing sites.
29:44 So, that'll be fun.
29:44 I'm having a lot of fun working on that.
29:45 Okay.
29:46 Interesting.
29:47 Yeah.
29:47 Is this kind of where the markdown work that you were working on comes in play?
29:51 Yes, exactly.
29:53 So, I decided the work that I did for TalkBuyLon training to build out the landing pages and like the interesting stuff to basically make a whole section of that site just driven by markdown and just editors and whatnot.
30:08 I'm going to like take that, extract it, and sort of take it to the next level like with rich markdown editors and, you know, database backends and stuff like that.
30:17 It'll be fun.
30:17 Nice.
30:17 Okay.
30:18 Cool.
30:18 Shall we close it out with a limerick?
30:20 Sure.
30:22 I'm not very good at limericks, so I'll give this a shot.
30:25 But this comes to us from Alexander A.
30:27 He sent this over.
30:29 He had written it.
30:30 This is his.
30:31 He wrote it recently.
30:32 And this is submitted.
30:33 Apparently, there's some kind of limerick contest at Manning.
30:36 You win free content like books and whatnot if you submit a winning programming limerick.
30:44 All right.
30:45 So, here goes.
30:45 Coding environments in three parts.
30:47 To this day, some prefer BBEdit.
30:49 VS Code is now getting some credit.
30:51 Vim and Emacs.
30:52 Vim and Emacs are fine.
30:53 So are Atom and Sublime.
30:54 But it doesn't matter much if you don't let it.
30:57 But wait.
30:58 Let's not forget IDEs.
30:59 Using PyCharm sure is a breeze.
31:01 Komodo, Eclipse, and Idea.
31:04 Sea Lion is my panacea.
31:06 And Xcode leaves me at ease.
31:08 But Jupyter Notebook is also legit.
31:11 Data scientists must prefer it.
31:13 In the browser you code.
31:14 Results are then showed.
31:16 But good luck when you try to use Git.
31:21 I love it.
31:22 It's good, right?
31:22 This is great.
31:23 Yeah.
31:24 Oh my gosh.
31:24 It's so good.
31:25 Especially that last line.
31:28 I love it.
31:28 Definitely makes the whole thing worth it.
31:30 Yeah.
31:31 Yes, indeed.
31:33 So, well done, Alexander.
31:35 Thanks for sharing that and letting us use it on the show.
31:37 That's great.
31:37 All right.
31:38 Anything else?
31:39 Do you got anything you want to share with folks?
31:40 I guess I jumped ahead of you and did my limerick.
31:43 No, no.
31:44 No, it's good.
31:45 We've got a whole bunch of great feedback from the recent testing code episodes.
31:49 So, it's been good.
31:52 Yeah.
31:52 What are some of the ones?
31:53 No, you just did one with Anthony Shaw.
31:56 Yeah.
31:57 And his plugin.
31:57 Yeah.
31:58 So, we talked about security.
31:59 We've talked about Django recently.
32:02 And just the most recent one is talking about the most downloaded pytest plugins.
32:10 So, Anthony Sotili and I talked about 28 of the top plugins.
32:14 That sounds like the perfect show.
32:16 That's really great.
32:17 Yeah.
32:17 Really geeked out on a lot of stuff.
32:19 I found some super interesting ones that I'm going to talk about in the next show.
32:22 But we'll leave it at that.
32:23 Awesome.
32:24 Thanks.
32:24 Cool.
32:25 All right.
32:25 Yeah.
32:25 Well, thank you as well.
32:27 Happy to be here with you like every week.
32:29 Bye.
32:29 Bye.
32:29 Thank you for listening to Python Bytes.
32:31 Follow the show on Twitter at Python Bytes.
32:34 That's Python Bytes as in B-Y-T-E-S.
32:37 And get the full show notes at Pythonbytes.fm.
32:40 If you have a news item you want featured, just visit Pythonbytes.fm and send it our way.
32:45 We're always on the lookout for sharing something cool.
32:47 This is Brian Okken.
32:48 And on behalf of myself and Michael Kennedy, thank you for listening and sharing this podcast
32:52 with your friends and colleagues.