Transcript #137: Advanced Python testing and big-time diffs
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 137, recorded June 26th, 2019.
00:09 I'm Michael Kennedy.
00:10 And I'm Brian Okken.
00:11 And this episode is brought to you by Rollbar.
00:13 I'll tell you all more about them later.
00:15 For now, Brian, I always wonder about, you know, you hear that Python is an efficient and expressive language,
00:21 and if you write code in C++, it'll be a lot longer.
00:24 But, you know, how can you quantify that?
00:25 Well, you can set up a whole bunch of people to write the same thing in a whole bunch of languages.
00:30 Well, that's awesome that people did that.
00:33 It seems like a lot of work, but yeah, I guess that's cool.
00:36 Tell us about it.
00:37 Like, this is your first item, right?
00:38 So this is an article called Comparing the Same Project in Rust, Haskell, C++, Python, Scala, and
00:46 how do you pronounce that?
00:47 OCaml?
00:48 O-C-A-M-L?
00:49 OCaml, I think, yeah.
00:50 So this was written up by Christian Hume, and this is about a university project, which is kind of a neat project.
00:58 Basically, they had to implement a big chunk of Java.
01:03 So it's a Java to x86 compiler as part of a compiler class.
01:09 And they were basically had to set up, get up teams, teams of people to do it,
01:14 and they could pick any language they wanted, which is kind of cool because, you know, people be better at different languages.
01:20 Yeah.
01:21 So let them use what they're good at.
01:22 Yeah, let them use what they're good at because then they'll do it properly and not just try to cram it one.
01:26 They'll have the most efficient use of that language for sure.
01:29 Up to three people on a team, and it was a multi-month project.
01:33 And then also tests were added.
01:35 So this is kind of a neat part of the process, which I think is an awesome way to teach people,
01:40 is have some published tests of, like, you're going to have to run these test cases and they have to pass,
01:45 but then also have some secret ones where people don't, they don't know what tests are going to be tested against it,
01:52 which is kind of nice because people will have to be able to make sure their implementation is robust without knowing,
01:59 without the test cases.
02:01 It's kind of neat.
02:02 Yeah, that's cool.
02:03 So I do love it that there's unknown tests.
02:06 Like, these are the specifications.
02:07 You can kind of get close with these tests, but to pass, you actually have to just work.
02:12 That's totally like real life, you know.
02:14 You'll write down some specifications, and there's some specifications that are not written down.
02:19 They're just supposed to be known.
02:21 And then there's other things that people, once they see the implementation, they go,
02:24 oh, yeah, I wish it did this also.
02:26 So I think that's a cool idea.
02:28 And they weren't shooting for lines of code or anything complexity.
02:33 They were just trying to finish the project.
02:35 So this analysis was done after.
02:37 They had a Rust, a baseline implementation written by two people that were familiar with Rust,
02:43 and then they compared everything against that.
02:45 So there was another Rust team that chose different design decisions, and it took, they had like three times the code.
02:53 So these are all just comparing lines of code.
02:56 The Haskell implementation was about equal, but depending on how you measure it,
03:01 one to 1.6 times the code.
03:04 Same for the OCaml.
03:06 C++ was bigger, about 1.4 times the baseline.
03:11 And Scala was a little bit less with about 70% of lines of code.
03:17 The big outlier was Python, which had a lot of standouts.
03:22 Python implementation was half the size, approximately, plus written by one person,
03:29 and had extra features past all the secret tests, plus others.
03:35 Somebody excellent at programming, of course, used some of the meta programming techniques.
03:40 And anyway, kind of a fun article.
03:43 One of the things I forgot to mention, one of the hindrances was they were only supposed to use standard libraries,
03:49 no extra parsing, and then not any parsing libraries, even if they were part of the standard library.
03:55 So even the parsing had to be kind of built up from scratch.
03:59 Yeah, how interesting.
04:00 I wonder if that would make things like Python even better possible.
04:04 I don't know about Rust, maybe as well.
04:05 But like C++ doesn't have parsing libraries built in that I know of.
04:08 Things like that, right?
04:09 There's a lot of mini-language parsing libraries around Python.
04:13 So it'd be interesting to do that with, you know, go wild and use whatever's available.
04:18 Right, like maybe take this project and then go, all right, well, what if we hit it with all the pip installable things?
04:24 What happens then, right?
04:25 Yeah, exactly.
04:26 Yeah, it sounds like a super intense project, though, right?
04:29 Like deep, deep into the language, right?
04:31 I mean, on one, you're writing the compiler.
04:33 You're understanding Java.
04:35 You're compiling to x86.
04:36 You're doing meta programming.
04:38 Like there's a lot of stuff going on here.
04:39 It's a pretty cool article.
04:40 Cool.
04:41 If that last one really connected with like your deep geek outlets, like go like really hard into the language,
04:47 this next one is going to connect with your, I just want it to work really quick and easy.
04:51 Yeah.
04:51 So this one is really nice.
04:52 So if I was a data scientist, I might use Matplotlib or just any kind of person who wanted some visualization of data.
04:57 I might use Matplotlib for that.
05:00 And that's great.
05:01 Except for at least I personally can't make Matplotlib look super good, right?
05:05 Like if I used Excel, like I put the data in there and I'd highlight the stuff and I would say,
05:09 okay, insert chart.
05:11 And I would pick the kind and then I would go and I would like right click and edit the chart.
05:15 And I would like maybe drag it around to size it correctly, double click on the axes to change the axes.
05:21 But in Matplotlib, you just write code and the picture comes out, right?
05:24 Yeah.
05:24 And I know you can do all this stuff, but it's not obvious.
05:27 And you have to look at everything, every little thing up and tweak it.
05:31 Yeah.
05:31 So there's this project that we heard about from one of our listeners.
05:36 And I can't remember.
05:37 I'm trying to remember who it was.
05:39 Oh, here it is.
05:40 I've got this is from Lee Wagner.
05:42 So thank you, Lee, for sending us in because this is killer.
05:44 So there's this project called PyLustrator for styling your Matplotlib plot.
05:51 So you just do your Matplotlib code, but you import PyLustrator and you say start at the beginning.
05:59 And what it does is it pops up when you show your plot an interactive thing, much like Excel,
06:04 where you can drag and drop and arrange your different plots.
06:08 You can like go to the properties and edit like the axes and the colors and just all the kind of stuff that you might do.
06:15 It even has like the cool design layout stuff where like it'll help you equally space stuff between each other.
06:23 So put those little bars to say right there.
06:25 If you drag and drop it, they'll be equally spaced or like align the tops and the sides.
06:28 Yeah.
06:29 And with that, the start thing, you can even fill it with some of your data to begin with.
06:34 So if you, you kind of know the data you want to plot, because that's going to affect how you're going to design it.
06:40 So you can pre-fill it and then drag it around and design it.
06:43 It's just totally cool.
06:45 It's totally cool.
06:45 I'm glad they have.
06:46 So the link we're going to show has a little embedded video.
06:50 And that's where, I mean, talking about it, you're like, yeah, I think this might be useful.
06:55 But you watch this video and you're like, oh, my God, I need to use this right away.
06:58 Yes.
06:59 I had the exact same experience.
07:00 I'm like, kind of interesting.
07:02 Oh, look at the video.
07:03 Oh, my God.
07:04 It's amazing.
07:04 Yeah.
07:04 So this is super cool.
07:06 And obviously, you don't save your changes to like an Excel workbook.
07:10 What you do is you save your changes.
07:13 And you can actually call save in PyListrator.
07:15 And what it'll do is it'll put the configuration in Python back into the file that ran it.
07:20 So that's pretty wild, actually.
07:22 Yeah.
07:22 And then you uncomment the PyListrator.
07:24 You don't have to import it later because it's not a dependency on your project afterwards.
07:28 Right.
07:29 It's just a little design tool.
07:30 So it's super cool if anyone's doing Matplotlib and they want to have it styled, especially if you're doing more than one plot and you want to put them like side by side.
07:38 Like, this is super cool.
07:39 So check that out.
07:39 I'm definitely a fan.
07:40 Another thing I'm a fan of, Brian, MongoDB.
07:43 Love it.
07:44 Since you and I are paying attention to a lot of projects, there's a lot of different release cycles.
07:49 And we kind of decided early on that we weren't going to try to track everybody's releases because that might get boring to people.
07:55 However, we covered MongoDB 4 because it came out with...
08:00 Transactions.
08:01 Transactions.
08:02 Among other things, yeah.
08:03 Which was a big thing.
08:04 But 4.2 is out and I'm kind of excited about a couple of features that it came out with.
08:10 So the transactions are there, but now they're multi-doc.
08:14 They're distributed transactions.
08:15 So they're transactions that cross sharded clusters and replica sets.
08:21 And that's just really cool.
08:23 Yeah, that's super cool.
08:24 I mean, you could use a cool transactional set before, but you're kind of limited, right?
08:28 And now it's like, no matter what crazy cluster with scaling and sharding and replication you have set up, you just do a transaction and it's all good.
08:35 Pretty cool.
08:36 They're a good idea anyway.
08:37 But with testing, you can set up a complex database full of stuff.
08:42 And then at the beginning of your test, start a transaction.
08:46 And then after your test, and you roll this into a fixture, you can just roll back and your next test has the same data.
08:52 It saves time.
08:53 So that's cool.
08:54 Yeah, and it's probably got isolation if for some reason they ran in parallel or whatever.
08:58 Yeah, it's really cool.
08:59 Yeah.
08:59 The other feature that's pretty amazing is the field level encryption.
09:03 And this is encryption done on a per field basis on the client side.
09:09 So the server doesn't even have, it doesn't do the, it's not doing it on the server.
09:15 So there's like system administration can be done without having to make sure everybody signs NDAs and all that stuff that you can just, you can manage your database without even being exposed.
09:28 Yeah, that's awesome.
09:29 Yeah.
09:29 Yeah, that's awesome.
09:30 Like most databases, most of what's in them is not sensitive.
09:33 But there's often like a little bit that is, that's really, you don't want, you don't want anyone to get access to.
09:39 And yeah, this is really cool.
09:39 Because like you said, it's done in the library that talks to MongoDB.
09:45 So in PyMongo for the Python folks.
09:48 And you just set the encryption key or decryption key over there and the server cannot decrypt it.
09:55 So if somebody breaks into the server or you lose it, or it's like you set it up on the cloud for like testing, you forget that it's there.
10:01 All the kind of random stuff that happens to databases.
10:03 It doesn't matter in terms of this encrypted stuff because like literally the database doesn't know how to read it.
10:09 It's the drivers that on the client side that have the keys.
10:13 So with GDPR stuff, if the customer says, hey, delete my stuff, that's always been an issue with databases.
10:20 It might be in a whole bunch of tables.
10:22 But if you destroy the customer key, the data might still be there, but it's unreadable to anybody.
10:28 So it may as well be garbage.
10:30 Absolutely.
10:31 And it gets to be really tricky because even if you set up the right code to delete all the customer data out of your database, what about the backup?
10:43 That somebody made when an older admin was hired and they stored that in the S3 buckets so it was offsite, right?
10:50 How do you delete the data out of there?
10:52 You know what I mean?
10:53 But if it's encrypted, then you can just throw away the encryption key and then it's just gobbledygook.
10:59 Yeah.
10:59 Cool.
11:00 Pretty cool.
11:00 I like it.
11:01 Speaking of cool, Rollbar, happy to have them come along and sponsor the show.
11:05 We use Rollbar on pythonbytes.fm, among other things.
11:09 So if anything goes wrong and it's kind of fortuitous, I guess, I woke up this morning with a ton of Rollbar messages because there was a data center failure that caused some connectivity between MongoDB and pythonbytes.fm.
11:27 How about that for a funny thing?
11:29 So some network card broke, right?
11:31 And like the site couldn't talk to the server.
11:34 So the database server.
11:35 So it was freaking out.
11:35 How do I know?
11:37 And nobody complained to me.
11:38 They probably should.
11:39 Like, Michael, your site's down.
11:40 What's going on?
11:40 It's really messed up.
11:42 But I just opened up my email.
11:44 I'm like, whoa, there's a lot of Rollbar stuff going on here.
11:46 So if you want to be notified right away, even when users don't tell you, check them out.
11:51 They have a free tier.
11:52 They have some great paid tiers.
11:53 Visit pythonbytes.fm/Rollbar.
11:55 Super easy to integrate into Python, into the web frameworks.
11:59 They've just got like one or two lines you enter or maybe a little configuration.
12:02 A few settings.
12:04 Off you go.
12:04 It's really, really nice.
12:05 So check them out, pythonbytes.fm/Rollbar.
12:08 Nice.
12:08 So kind of like PyListrator, that sounds kind of useful and interesting.
12:12 This next one also sounds useful and interesting.
12:15 But like PyListrator, it's like, as you look into it, you're like, whoa, this thing does a lot, man.
12:20 Look at it go.
12:20 So there's this project that was recommended by Francois LeBlanc.
12:25 Thank you for that, Francois.
12:27 And it's called Deep Difference.
12:29 It's just called Deep Dif.
12:31 And so it does deep differences in search of any Python object graph.
12:36 So I've got an object which holds a list.
12:39 That list points to a bunch of objects.
12:41 Those have other pointers.
12:42 Like I want to know, is this thing somehow referenced by that?
12:46 Let me do a search on it.
12:47 Where is it?
12:48 Is this giant crazy data structure same or different than other giant crazy data structure?
12:54 And you could compare them.
12:56 So that's pretty cool.
12:57 So it has Deep Dif.
12:58 It has Deep Search.
12:59 And it also has Deep Hash.
13:01 So if I've got some giant crazy data structure, you would like to know that if the data is the same across two of those, that the hash result is identical.
13:10 And if any part of the data changes, that the hash then changes.
13:14 Oh, yeah.
13:15 Possibly, right?
13:16 So it will do that on object graphs that are not even hashable themselves.
13:20 Really?
13:21 Yeah.
13:21 So that's pretty wild.
13:24 I have just a lot of nice touches in here that kind of made me realize like, wow, this is wild.
13:29 So, for example, it'll give me the differences in a list, ignoring order and duplicates.
13:36 Right?
13:37 Just what is the essence of this data?
13:40 Or you can say, is any data repeated in this list or in this, you know, dictionary or something like that?
13:46 You can exclude certain types.
13:48 Right?
13:49 Like, maybe I want to know the data is the same, but they're both using like a thread object.
13:53 And the thread object is different.
13:54 So, of course, they're going to be different.
13:55 But say, don't check on the thread object.
13:58 Just check the other stuff.
13:59 Right?
13:59 So you can explicitly opt in or out data types that you might use.
14:04 You can say, I'd like to compare these things, but only to like four significant digits because I computed them slightly differently.
14:09 And maybe they're, you know, I can't get them like to the decimal accuracy to be exactly the same, just the way they're done.
14:16 Right?
14:16 You can exclude parts of your object tree that you're going for compared.
14:20 I mean, isn't this insane?
14:21 Being able to do like significant digits in a deep data structure.
14:26 That's amazing.
14:27 That's really cool for a lot of the stuff I work with.
14:30 Yeah, I can imagine exactly.
14:32 And you know what?
14:33 I bet this would be really good to mix in with testing.
14:35 Like you create your test data and then you deep diff it against the result.
14:39 Yeah, exactly.
14:39 Because there may be noise in the system and you know some of the signals are noisy.
14:44 So, yeah, this is awesome.
14:46 Cool.
14:46 It's super simple.
14:47 But, yeah, it's pretty cool.
14:49 So if that sounds like problems you're trying to solve, it sounds like you are, Brian.
14:52 And I think it's definitely worth having a look at.
14:54 Yeah, thanks.
14:55 Yeah, you bet.
14:56 See, we just do this podcast to help each other out.
14:58 Like people can listen in.
14:59 Yeah.
15:01 Speaking of testing.
15:01 Josh Peek is somebody that we, I'm sure we met him before at a previous PyCon, but he stopped by at PyCon.
15:08 And this last year and met us and a really great guy.
15:12 He wrote this great article called Advanced Python Testing.
15:16 And it's kind of incredible.
15:17 He goes through his, he got in a situation at work where he was asked to do complex tasks where he had to, he knew that testing and making sure that he was doing things properly would, and do good coding practices would, would help the entire process and make it go smoothly.
15:34 So this is sort of a start to finish summary of it.
15:39 But it's not that long of a read, but he talks about his learning journey, which he includes some great podcasts, including ours.
15:46 Also an awesome book on testing.
15:48 And I know the author for that one.
15:50 Not just plugging our own stuff.
15:52 He's got some great stuff in here.
15:53 He talks about, he starts off with just a basic, for people new to testing, what a basic test function looks like and having good structure.
16:02 But then he talks about, he wanted to ensure, you know, do static analysis and code style.
16:09 So he uses black within his testing.
16:12 And when he was talking about using PyLint, I don't use PyLint every day.
16:17 So I didn't know that there was, it's a very comprehensive check, but it takes some time for large code bases.
16:25 I didn't know that.
16:26 But he has a cool hack that he puts in place to only, for like check-in tests, only lint modified files.
16:34 Oh, that's cool.
16:35 Yeah, because of course, if they're unmodified, then why would they have a different outcome?
16:39 Yeah.
16:40 Right.
16:40 And then he uses incorporating flake 8 to do doc string testing to make sure that people are using consistent doc string styles.
16:48 He covers all of his tox any configuration changes.
16:52 He was trying to increase his code coverage.
16:55 So he includes coverage.py, but then also has a cov fail under flag that he adds for testing to make sure that if code coverage drops below,
17:09 a certain point, it fails the test.
17:11 And then just generally gradually ratchet that up.
17:15 So the increase, his target was 75%.
17:18 So it even goes into fixtures and mocks and spies and stubs.
17:23 And then even a cool tool called pytest VCR, which records your network interactions and then replays those for future test runs.
17:32 And he saw a 10x speedup in that.
17:35 That's really cool.
17:35 There's so much cool stuff in here.
17:37 pytest VCR.
17:37 That's really cool.
17:38 I think the only problem with it is like maybe a lot of folks using it have no idea what VCR means.
17:43 Oh, yeah.
17:44 That's true.
17:46 I mean, even, yeah.
17:47 So.
17:48 Yeah.
17:48 But no, it's awesome that you just record the network interactions and don't have to depend on anything at all.
17:53 I love it.
17:53 And the recordings are done based on a per test basis.
17:57 So if you rerun an individual test, it only plays back the recording for that portion.
18:04 It doesn't have order dependency built in, which is cool.
18:07 Yeah.
18:08 Super cool.
18:08 I love it.
18:09 Yeah.
18:10 That's a really nice article, Josh.
18:11 Well done.
18:12 The last one I want to talk about was sent over by Kevin Books.
18:15 Now, we've covered a few of the language, sort of language level learning things recently.
18:21 We talked about the CPython byte compiler either last time or the time before that.
18:27 How it doesn't really optimize stuff.
18:28 And maybe there's some opportunities there, but more just to understand what's going on.
18:33 So Kevin sent in a message, said, hey, I'm basically a C, C++ guy.
18:38 And I saw the Dell keyword in Python.
18:41 And it threw me for a loop because Dell seems like delete in C++, which means free memory.
18:48 But it doesn't necessarily mean that in Python.
18:51 So it even seems like some of the books out there are kind of being a little misleading,
18:56 at least according to Kevin's reading of them.
18:58 So I thought I'd just pull up an article that he sent over and then talk a little bit over some of the uses for Dell.
19:05 Great.
19:05 I don't use it.
19:06 So this would be good.
19:07 Yeah.
19:07 So the context where I know Dell is I want to get something out of a list or I want to get something out of a dictionary.
19:15 Right.
19:16 Okay.
19:16 And it's a little bit weird.
19:18 It's like in keyword.
19:19 Right.
19:19 A lot of times I would expect some operator to be on the object I'm modifying.
19:25 Right.
19:25 Like list or, you know, string dot in or something and you give it the value.
19:31 Right.
19:31 But you say string space in space, the variable.
19:35 Right.
19:35 So it's a little bit funky that you apply it not on the object, but as a keyword in the language.
19:40 And Dell is like that.
19:41 Right.
19:41 So if I have a dictionary and I want to remove a key, not set it to nothing, but make it not be in the keys collection,
19:46 you can say Dell dictionary of bracket, like as if you're accessing that value, but putting the Dell there takes it out.
19:53 Oh, okay.
19:53 Yeah.
19:54 And you can also do that for lists.
19:55 So I can go in and remove it, remove something from a list if I want.
19:59 There's a remove function on the list, but somewhat confusingly, potentially it's by value.
20:05 Right.
20:06 So I could say remove Jeff from the list and Jeff will no longer be in that list wherever he appeared.
20:11 But if I want to say remove the third thing, there's no remove at or anything like that.
20:17 Right.
20:17 I can't pass to that's not a value.
20:19 Right.
20:20 So Dell will let me remove that.
20:22 You can also use pop for that, I believe on the list, but Dell is a little more general purpose.
20:26 And you can also delete slices.
20:28 So I could say, go to this list and take out everything from two to five, you know, two colon five like that.
20:34 All right.
20:35 So these are all pretty interesting.
20:37 Now I'm linking over to the official docs that talk about it.
20:41 And this article that kind of talks through some of these examples and shows you how to use it.
20:44 You can also delete a variable out of like a local or a global namespace.
20:48 So if there's a variable that's been defined and you want it to not be defined,
20:52 I can say Dell space variable name.
20:53 And now it's as if I didn't do that line that defined it, right?
20:57 That created it.
20:58 Does it remove it from the namespace?
20:59 It removed.
21:00 Yeah.
21:00 It doesn't free the memory necessarily, but it takes it out as a global variable.
21:06 Okay.
21:06 Or a local one.
21:08 Right.
21:08 Yeah.
21:09 So does it actually free any memory?
21:10 Right.
21:11 It depends.
21:12 Right.
21:12 So if I have it in the global names, let's say it's a global, right?
21:17 It has obviously the thing that has a value at that variable.
21:21 It's taking up some memory.
21:22 If nothing else is pointing at it, right?
21:26 It's still going to be around because that global variable is pointing at it.
21:28 But if you call Dell that variable, you'll dereference that one reference to it, putting the reference
21:33 count to zero and freeing it up.
21:35 So theoretically, you could free up memory using Dell.
21:38 Similarly, if it's in a list and the only place that points to it has a reference to it is that list itself.
21:43 And you delete it out of there, out of the dictionary, it goes away, right?
21:46 Memory wise.
21:47 But if something else is pointing at it, then obviously it's not going to go away.
21:49 Yeah.
21:50 We also talked about how the CPython bytecode compiler is dumb.
21:53 Dumb as in not super optimizing, maybe on purpose.
21:57 And I think you could also, you know, if you're like really dealing with memory issues and you're like,
22:02 I really wish this thing would just go away sooner in this one little edge case,
22:07 you could probably use Dell to put in some of the optimizations that you might hope that the compiler itself might do,
22:14 but it doesn't like dereference a thing as soon as it's used within a function before you can get to the end or things like this.
22:21 Yeah.
22:21 Okay.
22:22 So is it for memory?
22:23 Sort of.
22:24 Not really.
22:25 But maybe as a side effect.
22:27 Yeah.
22:28 This has been a long time, but I do remember it tripping me up because I was like,
22:32 it seems a lot like delete, which should have a matching new to it.
22:37 Exactly.
22:37 Exactly.
22:38 We both done the C++ thing, right?
22:40 Like where's the new that goes with Dell?
22:41 I've never seen a new.
22:43 Anyway, it's pretty cool.
22:44 There's a couple of links here.
22:45 There's a visual documentation.
22:47 There's the article understanding Python's Dell.
22:49 And then there's the reference to that bytecode compiler people can check out.
22:53 Yeah.
22:53 In C++, I don't think there's a way to remove a name from a namespace.
22:58 Yeah.
22:58 I don't think so either, right?
22:59 Yeah.
23:00 You can like make it point at null, but that's about it, right?
23:04 Yeah.
23:04 But I mean, you got to think about it, right?
23:06 Like classes, you could delete a field out of a class, right?
23:09 Because it's just a dictionary, right?
23:11 So much of Python is built on like dictionaries, right?
23:13 Like the variables are their variable names or the keys in the dictionary and their values
23:17 are their value.
23:19 So you just take it out of the global dictionary effectively, right?
23:21 Yeah.
23:22 Okay.
23:22 Cool.
23:22 Pretty sweet.
23:23 So those are our main items for today.
23:25 You got anything else you want to chat about, Brian?
23:27 I'm just, I'm glad it's summer.
23:29 It's starting to feel nice.
23:30 It feels like summer.
23:31 But other than that, not much.
23:33 How about you?
23:34 Summer is awesome.
23:35 It makes programming hard because programming is indoors.
23:38 Although some of my friends and I who work from home, we try to get out and program
23:42 in like a coffee shop or a cafe by lake or something.
23:46 And periodically we have the weird experience of getting a sunburn while writing code.
23:50 And yeah, we've dubbed it a code burn and it's kind of a badge of honor.
23:54 That's funny.
23:55 Cool.
23:56 Yeah.
23:56 So there's actually a couple of things I want to throw out here.
23:59 We recently had Max Sklar from the local Maximum podcast.
24:02 And afterwards he had me onto his podcast.
24:05 So I'll be on episode 73, which should be out.
24:09 Not yet, but thanks to time shifting when this episode comes out, it should already be out.
24:13 I'll put a link to that.
24:14 Josh Thurston sent over a cool video of the popularity of languages on Stack Overflow over
24:23 time as a bar chart race.
24:25 I didn't know about bar chart races, but these are basically animated bar charts over time.
24:29 And you just watch the bars grow and shrink.
24:32 And it's really cool.
24:33 Python is kind of like a little tiny consideration at the bottom.
24:36 And obviously we know that Python is crushing it on popularity and Stack Overflow and all those
24:40 things.
24:41 So it's like a minute and a half video.
24:43 I think everyone will appreciate watching it if they just got a minute to kill.
24:45 No, it's a fun video.
24:47 And one of the things I enjoy about it is early on, you see the Java bar going up and down based
24:54 on the time of the year because it was used in education a lot.
24:58 That totally made sense.
24:59 Exactly.
25:00 You're like, oh, there's a huge spike in September.
25:02 I wonder why.
25:03 Maybe a bunch of people got a job.
25:06 No.
25:06 Like CS 101 is now back in session.
25:09 Yeah.
25:10 Exactly.
25:10 Then the last one I want to throw out is this thing called Pine Source.
25:14 So what this does, this comes to us from Anders Klint.
25:18 It's basically a UML diagram creation tool for Python code.
25:24 So you give it some Python files, it will generate a UML diagram that shows the relationship of
25:29 all the classes in there.
25:30 Oh, that's cool.
25:31 Yeah.
25:32 It's pretty cool.
25:32 There's a free, maybe even open source version.
25:35 And then there's also a paid version.
25:37 So you can buy it and, you know, I'm actually not a huge fan of UML, but if you have Python
25:44 code and you think a UML diagram would help describing it, this thing's pretty cool actually.
25:49 And it's a little GUI app.
25:50 There's a bunch of screenshots.
25:51 You can check it out and see if it'll help you.
25:53 But it looks pretty neat.
25:54 And it does, you know, proper UML, not just like sort of visualization of classes.
25:59 So that's kind of nice.
26:00 My favorite use of these kinds of diagrams is to print them out and pin them to your wall,
26:05 your cubicle wall so that other programmers think that you're smarter than they are.
26:09 Absolutely.
26:11 Put some little cryptic notes on them, like as if, you know, you're marking them up.
26:16 Yeah, absolutely.
26:16 Love it.
26:17 Yeah, so you can do this with your project.
26:18 Yes, this huge thing is our project.
26:20 Anyway, it's pretty cool.
26:22 And there's a free version, like I said, so maybe I'll help some folks out there.
26:24 All right.
26:25 You ready for some jokes, Brian?
26:26 Yes, definitely.
26:27 All right.
26:28 I have a, you've heard about the glass being half full and half empty and like, oh, I'm a
26:32 half empty sort of person.
26:33 I kind of see the world as slightly negative.
26:35 Yes.
26:35 So here's the developer version.
26:37 So we have an optimist who says the glass is half full.
26:40 We have the pessimist who says the glass is half empty.
26:43 And we have the programmer who says the glass is twice as large as necessary.
26:47 Yes, definitely.
26:48 So I wanted to extend that.
26:51 Okay.
26:52 With the pragmatist that says that I'm just allowing enough room for requirements, oversight,
26:56 scope creep, and schedule overrun.
26:58 That's right.
26:59 It's perfect.
27:00 I love it.
27:01 And then you have this other one about software startups.
27:04 Yeah, man.
27:05 It's not really any startup, but I watched the upside with Kevin Hart last night and it
27:11 was a joke that I couldn't help but sharing.
27:13 I can't remember the characters, but Kevin's character said, would you invest in my business
27:18 idea?
27:19 And the other guy says, that seems too niche.
27:23 Kevin, what's niche mean?
27:25 Oh, it's the girl version of nephew.
27:30 I love it.
27:31 I love it.
27:31 That's bad.
27:31 If you got to ask, that's a pretty good answer.
27:34 Yeah.
27:35 Yeah.
27:35 Cool.
27:36 Cool.
27:36 All right.
27:36 Well, thanks for putting all the cool topics together as always and being here.
27:40 Yeah.
27:40 Thank you.
27:40 Bye.
27:41 Thank you for listening to Python Bytes.
27:43 Follow the show on Twitter via at Python Bytes.
27:45 That's Python Bytes as in B-Y-T-E-S.
27:48 And get the full show notes at pythonbytes.fm.
27:51 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.
27:56 We're always on the lookout for sharing something cool.
27:58 On behalf of myself and Brian Okken, this is Michael Kennedy.
28:01 Thank you for listening and sharing this podcast with your friends and colleagues.