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


Transcript #76: Goodbye zero-versioning

Return to episode page view on github
Recorded on Thursday, May 3, 2018.

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

00:05 This is episode 76, recorded May 3rd, 2018. I'm Michael Kennedy.

00:09 And I'm Brian Okken.

00:10 And this episode is brought to you by Datadog. Check them out at pythonbytes.fm/Datadog.

00:15 They're doing awesome stuff. Tell you more about that later.

00:17 Brian, I think, you know, we're on the eve of PyCon.

00:21 We're literally, in terms of podcast releasing, podcast episodes, this is PyCon Eve.

00:26 And PyCon is a place where people seem to really care more than most developer communities about sort of welcoming newcomers.

00:34 And you've got something that kind of ties into that angle as well, right?

00:37 I ran across this article, and it looks like it's called Unlearning Toxic Behaviors in a Code Review Culture.

00:44 And this is, apparently this came from a talk at AlterConf and then turned into this.

00:53 So there's the slides are available, but there's an article with all of the information.

00:58 And this is something that trying to have good manners and be a good human while also helping each other out in code reviews is sort of an interesting balancing act.

01:10 Because you've got to actually teach people and if you need to teach and everything.

01:15 So anyway, I'm going to jump into some of the ideas around this.

01:18 And it's an interesting idea to go off.

01:21 It's a discussion of some of the unhelpful behaviors that people have seen and then some of the helpful things that you can do.

01:29 So I'm not going to list all of them, but there's a few of them that jumped out at me.

01:34 Like, passing off opinion is fact was the first one.

01:38 And, you know, it's people saying, oh, this should be implemented this way.

01:41 But there isn't really a should often with software.

01:44 Those are opinions.

01:46 And so just make sure you state it like that.

01:49 One of these things, next up is overwhelming with an avalanche of comments.

01:55 So, like, for example, if somebody made the same mistake a whole bunch of times, like, I don't know, there's spaces in the wrong place or some formatting issue or, you know, not using underscores and doing camel case instead, commenting every place.

02:10 I mean, one comment is sufficient to don't put like, yeah, you did it here too.

02:14 Yeah, you did it here too.

02:15 Yeah, you did it here too.

02:16 All over the code review.

02:17 And there's actually just reading through all of these.

02:21 They're good just reminders of how to be helpful instead of being hurtful during a code review.

02:27 And then popped out some of the helpful things that one of the things that popped out at me is collaborate and don't backseat drive.

02:35 And this is one actually that I need to work on because it's hard when I see some code that I think should be another way.

02:41 I don't really want to just tell everybody, tell somebody what's all wrong with it.

02:45 My instinct is to just do it the right way and show them, say, it should have been done like this.

02:50 But that's, you know, that's not the right way to go.

02:53 But anyway, do you have any comments on some of this?

02:56 So one of the things I think that people need to be really careful about is when in some of these code reviews, especially for junior developers, this can be like a really sort of sensitive time emotionally, right?

03:07 You put together some work and like it's one thing to criticize the code.

03:12 But at the same time, it can come across as feeling like criticizing that person or their skill set.

03:17 And, you know, when you're a junior developer, your feeling is like you maybe don't feel like you can keep up with your team because they've been doing it for 10 years and you've been doing it for two.

03:25 And you just feel a little bit like you're always trying to catch up.

03:28 Right.

03:28 And so if somebody comes in just matter of factly says, we're going to throw a bunch of comments on this stuff.

03:34 You should do it the way I've been doing it for 10 years, et cetera, et cetera.

03:37 Like it can I think it can be perceived as a personal attack or attack on your credibility in your newfound career.

03:44 So I just think, you know, being real, real sensitive to that, especially for junior developers.

03:49 Right.

03:50 I mean, I'm sure people who've been doing it for a long time feel that way as well.

03:53 But the longer you do it, the thicker your skin gets.

03:57 And you're just like, you know, the more you're kind of used to having these sort of debates and differences of opinion.

04:03 But, yeah, I would sort of second this and say, you know, be cautious of the junior developers and make it more about learning and bringing them along instead of like, hey, I'm going to show you how to do this because you did it wrong.

04:13 Also depends a lot on personality because I'm when I was a junior developer, I actually was more open for people saying, wow, this sucks.

04:20 You should do it this way.

04:21 And now that I'm I think of myself as an experienced developer, there's still a lot of stuff that I'm learning in new parts.

04:28 And I sometimes will take a comment of like, oh, you should do it this way as like we're talking about.

04:34 I'm a senior developer, you know, but I got to check the ego a little bit.

04:39 And one of the things that helped my team a lot, it shows up on this list, too, is to automate what you can.

04:46 Like, for instance, we use I mean, whatever your standard is, just define that and codify it with PyCode style or FlakeAid or something.

04:56 Our team uses FlakeAid, the FlakeAid defaults.

04:59 We at work, it was helpful for us to increase the the line length and a couple other things that we turned off.

05:07 But agree on that and just automate that.

05:09 And just so sometimes something will come through a code review.

05:13 And just a simple comment of, hey, can you run this through FlakeAid first before we start the review is easier.

05:20 I totally agree with that because people you don't feel personally criticized by a computer.

05:25 Yeah.

05:26 Right.

05:26 It's just like the algorithm, it formats it this way and it checks that the line length is this and the format is that.

05:32 And if it's wrong, then you fix it.

05:34 But it's not like it's, you know, it has an opinion about that.

05:38 Not really.

05:39 Right.

05:40 Maybe someday computers will have opinions like that, but they don't right now.

05:43 Yeah.

05:43 And another thing, sort of adding on what you're saying is with black, I believe, remember black, the formatter that comes in any color you want, long as it's black?

05:51 Yeah.

05:51 That one, I believe, will modify the code, not just suggest fixes.

05:56 So you can say black, reformat this the way we like it and just do that.

06:01 I still haven't tried to hook that up as a commit hook or something like that.

06:04 Exactly.

06:05 That'd be nice.

06:06 I think it's pretty cool.

06:07 Definitely worth thinking about these issues.

06:10 So, Brian, do you remember a few episodes ago that project, that new versioning project that Mahmoud and Mahmoud Hashemi and a few of his friends put together about zero version?

06:21 Was it zero for?

06:22 What was it called?

06:23 I think it was zero for.

06:24 Yeah, I think it was zero for.

06:25 So it was like sort of celebrating in a sarcastic poking fun that maybe you should not be zero version.

06:31 The zero dot whatever version of things like Flask, Pandas, et cetera.

06:37 Right.

06:38 Things that have been around for eight years and are super stable and are still like zero dot one for their version.

06:43 Well, either that article or this episode or that episode covering it somehow may have had some kind of effect because Flask had been on like zero dot something small for eight years.

06:58 And now Flask 1.0 is released.

07:00 How about that?

07:01 I think it's a great thing.

07:02 It was interesting that there were some people that like actually commented of like, why bother if it's already stable?

07:08 I think it's a good.

07:09 I think it absolutely makes sense.

07:10 I mean, I know that there are people out there in the world who see it's been around for a long time.

07:15 It's had many releases.

07:16 Does that mean stable?

07:17 If it's not stable, you put the little beta, the little B on the end of the version or something like that.

07:21 But there's a large portion of the development world that comes to Python from outside of the core ecosystem of Python and sees zero dot one and goes, can't use it.

07:32 Not ready.

07:32 What is this?

07:33 Right.

07:33 And so I think it I think it really makes a lot of sense just changing the version because they got some pressure.

07:38 There's actually a lot of stuff here.

07:39 I'm going to try to go through this quickly because there's actually a lot of stuff here.

07:43 So the CLI is more flexible for creating a flask app.

07:48 And actually, you can do things like, say, it's in development mode or production mode, and that can replace like flask debug settings and environment, stuff like that.

07:56 That's great.

07:57 You can get the environment variables from a dot flask env file.

08:01 So instead of having to export them in your shell when you like launch the shell, like ZSHRC or bash RC, things like that, you can have it just in these files and it'll actually load them as if they're from the environment.

08:16 That's cool.

08:16 Development server is multi-threaded.

08:19 So now you can more properly test concurrent requests during development, which is what you would experience if you were released it to a proper threaded server like micro whiskey.

08:28 Flask EXT, which was deprecated, has been removed.

08:32 Some stuff around forms is pretty nice.

08:34 Better error handling, more finer grained stuff there, more logging.

08:38 For you, the test client gained a JSON argument for posting JSON and a response test object, a get JSON for decoding JSON so you can have like test your JSON methods better, a test CLI runner for testing your app's command line options.

08:54 Pretty cool, right?

08:55 Yeah, very cool.

08:56 So all of this stuff is in Flask 1.0.

08:58 Nice.

08:58 Actually, that very much deserves a bump in the version.

09:01 Right.

09:01 And it's time.

09:03 It's definitely time.

09:04 So well done, Flask team.

09:06 Yeah.

09:07 I'm just getting into some more Flask stuff, too.

09:09 So that's good.

09:10 Yeah, it's pretty fun.

09:10 So have we gotten used to pip?

09:13 Like, I'm not used to it.

09:14 I literally yesterday typed pip install-r requirements.txt a lot because I was rebuilding some servers.

09:20 How about you?

09:21 I understood it.

09:22 I think it's really cool.

09:23 But I had trouble really grokking what problem it was solving that I didn't have yet.

09:28 So I ran across an article that's called Pipenv, a guide to the new Python packaging tool.

09:37 And so since everybody's like, actually, not everybody, but it is being more recommended now to use pipenv where appropriate.

09:45 And so this article actually presented it in a way that I think it made me understand it a lot more.

09:54 For instance, using pipenv, it's like using pipenv virtual environments, but it does a lot of the stuff for you.

10:01 There is some workflow differences that I'm not going to cover here.

10:07 But there's a video up on the site that I think the pipenv readme or the, I don't know, the documents have.

10:15 Like the GitHub page.

10:16 Yeah.

10:16 Yeah.

10:16 It has this little video.

10:18 This is great.

10:18 It shows you the workflow.

10:20 But what problems does it solve?

10:22 So the requirements.txt has an issue.

10:25 And this article talks about the current, without pipenv, what the problems are.

10:29 So requirements.txt is, you can set it up as just, these are the required packages that my application uses.

10:35 But it doesn't really have versions.

10:37 You can put versions in there, but your mileage may vary.

10:41 Now, if your dependencies have dependencies themselves, then those versions, you know, how do you keep track of those?

10:48 So that one of the ways people have done that is use pip freeze, which does both your dependencies and all of the sub dependencies and freezes all of those.

10:57 And you can use that as your requirements file.

10:59 But then you've got to keep track of it.

11:02 So every time one of the sub dependencies updates, you've got to make sure it works.

11:06 And that's just sort of a pain.

11:08 Yeah, I mean, the requirements is supposed to show you what you depend upon, not the transitive closure of what you depend upon, really.

11:15 Right?

11:15 Oh, math words.

11:17 Not all, not your dependencies, dependencies, not the dependencies of your dependencies of your dependencies.

11:22 How's that?

11:23 Okay.

11:23 The gist of it is, in file-wise, there's two files that get generated, pip file and pip file.lock.

11:30 pip file is the, these are my requirements, kind of, but it also does more than that.

11:35 And then pip file lock is, like, all of the pinned requirements with all the versions.

11:41 And it also includes hashes of the downloads so that you don't have to worry about corrupted installs or anything like that.

11:48 And then it does so much more than that.

11:50 But this discussion really helped me understand why this is useful, especially the subdependency thing is something, yeah, nobody wants to deal with that themselves.

11:59 So let Pip-Enf deal with it for you.

12:01 Man, pretty cool.

12:01 I got to study, I got to get my workflow zen around this new way.

12:07 One of the catches, which is that it's recommended for use for applications and not for packages because your package is used by something else.

12:16 You don't want to pin anything.

12:18 It's the application that should pin things, not packages themselves.

12:22 But you can use it while you're developing packages.

12:25 And if you're really confused on how to set all this up, there's a new cookie cutter for it.

12:30 So we're also going to include a link.

12:32 There's a package somebody did for a generic Python project that uses pipenv.

12:40 There's a cookie cutter for it.

12:41 Nice.

12:41 So basically, if you're going to start a new project, you can run that cookie cutter to generate it with the proper structure using pipfile and pipfile.lock.

12:49 And it's kind of a fun way to just get your hand like, okay, how is this all supposed to work?

12:54 Even if you don't use this for a project to pull down pipenv in a project and play with it and say, oh, yeah, this makes sense.

13:02 I think that's a really cool way.

13:03 It kind of gives you the essence of what you need for the structure, which is always something that's fun to debate.

13:08 And we have a few times.

13:10 So before we get to our next item, which is probably going to surprise people a little bit if they haven't heard of it, I want to tell you about Datadog.

13:17 So Datadog is a monitoring solution that provides deep visibility and tracks issues that you might be running into with distributed applications.

13:25 So if I have an app that has maybe some services like microservices and it calls into the database and other things and it's slow, that can be really hard to figure out where.

13:35 But with Datadog, you can just investigate the bottlenecks in your code, explore graphs and dashboards and really figure out where your app is spending its time across processes.

13:45 Right.

13:45 So not just profiling one thing.

13:46 So visualize your Python performance today.

13:49 Get started with a free trial at Datadog.

13:52 And you'll get a cool shirt, a little T-shirt with a Datadog mascot is the right word I'm looking for.

13:59 A Datadog mascot on there.

14:01 So check it out for yourself at pythonbytes.fm/Datadog.

14:05 So if you're going to think of a company, Brian, that was going to create like one virtual machine, one runtime in Python speak, the equivalent of interpreter to rule them all.

14:18 How about Oracle?

14:19 No, I wouldn't have thought Oracle.

14:22 No, I probably wouldn't either.

14:23 So there's this thing called GraalVM, G-R-A-A-L-VM.

14:28 And it says this is built to run Python code and other code that depends on virtual machines and run it faster.

14:36 So they said, look, we see this problem.

14:39 Like current production virtual machines and, you know, throw the CPython in there with that.

14:44 Provide high performance of only execution of only certain languages or a small set of languages.

14:50 They all repeat a bunch of stuff.

14:52 They all do compilation, memory management, tooling, et cetera.

14:56 So it kind of violates the don't repeat yourself, the dry principle.

14:59 They're heavyweight things usually that take a lot of memory.

15:04 So they're often difficult to embed, especially like JVM, stuff like that.

15:08 So over at Oracle Labs, they started a new project a while ago to create a single VM that would provide high performance execution for all of the languages.

15:16 Benefit being if I have, say, some sort of multilingual environment, like maybe we do Java and Python or something like that.

15:25 If you could put that within the same process and have them directly communicate, they would go dramatically faster than, say, over JSON-based microservice.

15:34 Like if it was literally in memory.

15:36 Yeah.

15:36 That's kind of the idea, right?

15:38 So the goals are basically to create this high performance single VM that can interoperate with zero overhead across these different languages and platforms.

15:49 So you can run all the JVM-based languages, Java, Catlin, and so on.

15:53 JavaScript, including Node.js.

15:54 Anything that you can do LLVM against, so C++ or Rust.

15:59 And Python.

16:01 So imagine you're doing some sort of interop type of thing, and you want to write some of your code in Rust and some of it in Python, and you want to try to get the best performance out of it.

16:13 Maybe putting it together in this thing would be pretty cool.

16:17 So it does, I don't know how much it'll help for Python in its current form, but maybe they'll get something really special.

16:24 But for some of the JIT compiled languages, it will ahead of time compile them to machine instructions and then run them.

16:30 So things like startup time and initial execution is super fast and unpredictable.

16:34 So it would be cool if they could do like PyPy pre-compiled or something like that.

16:38 Just to make sure I get my terminology straight.

16:41 The Grail VM, the VM is a virtual machine.

16:44 I'm used to virtual machines being like an entire desktop on a server or something.

16:51 Is that what this is?

16:52 No, often VMs are like the Java VM or the .NET CLR or things that are sort of managed memory process.

17:04 Okay, it's the thing between my code and my computer.

17:07 Yeah, and it is most commonly used around things that JIT compile.

17:12 Java, JavaScript, .NET, things like that.

17:16 Okay, so two completely different things.

17:18 Two different VMs.

17:18 Both called virtual machines.

17:19 Okay, got it.

17:21 Right now the Python support is experimental, but they're working on one of their main next steps is to make the support for Python better.

17:29 So if this sounds interesting to people, I think, you know, it's early days.

17:33 It's pretty interesting and check it out.

17:35 Actually, I'm like super excited about it because the combination of Python with C++ and Rust and R and other things and Kotlin, it's going to be, I think this is an exciting thing.

17:47 I think it is too.

17:47 And if you can do that with no interop within the same process that, you know, without translating between the layers and some kind of like CFFI layer type of thing, I think that would be really cool.

17:58 Yeah.

17:59 Okay.

17:59 We'll see.

18:00 It's early days, but it could be a pretty neat step in adding one more way to execute Python code.

18:07 Yeah.

18:07 All right.

18:08 What's your next one for us?

18:09 I am like totally in getting ready for PyCon mode and didn't have time to do a testing code episode last week or this week.

18:21 So this is a shameless time.

18:23 I'm going to take my last slot to do some testing related topics.

18:27 But one of them is Flask.

18:29 So we covered Flask already.

18:30 There's a brand new version.

18:32 You can test it.

18:32 Yeah.

18:33 There's an article that came out this week called Testing a Flask Application Using pytest.

18:39 And those are two of my favorite things, Flask and pytest.

18:43 And one of the third favorite thing is my own book.

18:46 And the book that I wrote was part of the inspiration for this article.

18:51 So shameless plug.

18:52 But it's a really nicely written article.

18:54 It's basically if you're writing, if you're working with Flask and you want to try to work with pytest also.

19:01 I mean, I've had questions about this, but I didn't feel qualified to answer yet.

19:05 Now I am because of this article.

19:07 But there's talks about both unit testing and functional testing through the test client that Flask provides.

19:13 But the unit tests don't have to be.

19:16 You can access things directly.

19:17 But the article goes through both a couple examples, a unit test and then a functional test.

19:23 Like, for instance, checking the making sure that a new user works at a unit test level and how to hook that up with pytest and Flask and everything.

19:33 And it's actually really nicely done.

19:36 After you read the article, I don't stop there.

19:38 I go out and look at the project that he's got on.

19:42 I can't remember if it's on GitHub or GitLab, but it's an open source project that you can take a look.

19:48 And it's got other more testing examples.

19:50 And it's really well done.

19:52 So good job.

19:53 I like it.

19:54 Yeah, it looks really, really cool.

19:56 And I see the project structure there again.

19:58 Like, here's how you set it up to do testing.

20:00 So that's very nice.

20:02 And it's cool that your book was an inspiration for it as well.

20:04 Another thing while we're on the testing topic, I wanted to bring up a new pytest plugin that just actually kind of blew me away.

20:11 This is a brilliant idea.

20:12 And I also learned the word stochastic.

20:16 I think I knew it at one point, but stochastic kind of means random and stuff.

20:20 But it comes up because it's in the readme for this project called pytest-CAPRNG.

20:30 So here's the idea is if you've used random, the random module or the numpy random is being used in your code or in your test.

20:41 Running a test, if you run a test and it fails and you try to rerun it and it passes, it might pass because the data is different.

20:48 This new plugin, what it does is before you run each test, it captures the state of the random modules so that the seeds are the same.

20:58 Next time you run it, if you rerun the failure, you'll get the same data again.

21:02 So you'll see the failure again.

21:04 And it's just kind of a small little plugin that is an awesome idea.

21:10 So I wanted to highlight it.

21:11 It's cool.

21:11 Yeah, it's cool.

21:12 I mean, coverage might change based on that value.

21:14 Success or failure might change based on that value.

21:17 So being able to lock it down, make it predictable.

21:20 Yeah.

21:21 But still have it start from something random.

21:22 That's pretty cool.

21:23 I like it.

21:23 All right.

21:24 I did say we were on PyCon Eve, right?

21:27 So the next time we release an episode is going to be at, well, at least it will have been recorded at PyCon.

21:34 We'll see if it happens there.

21:35 Anyway, there's a really nice article by Trey Hunter.

21:39 He was a guest co-host a while ago on how to have a great first PyCon.

21:44 So PyCon is maybe the big, I think it's the US one is the biggest Python conference there is.

21:52 It's certainly quite large.

21:53 And there's a lot of options.

21:56 It's a little bit of a paradox of choice there, right?

21:58 I mean, did you have that experience when you were there, Brian?

22:00 Yeah, definitely.

22:00 And I'm really having that time, that experience again, looking at the schedule.

22:05 I don't know what to go to.

22:06 I know.

22:06 I'm going to solve that by not going to anything.

22:08 Which is part of this conversation.

22:12 So he has a really nice, long, thoughtful write-up about sort of getting the most out of PyCon the first time.

22:20 You know, maybe if you've gone a few times, you can still read this and get something out of it.

22:23 So first of all, he mentions that the talks are typically recorded, available on YouTube within, I don't know, 24 hours?

22:32 Something like that.

22:33 Really surprisingly quickly.

22:35 So you don't feel like you have to attend every talk, right?

22:39 If there's something more interesting going on, don't feel like you're missing out.

22:43 You just watch it later.

22:43 I think one of my number one recommendations, which he touches on, is open spaces.

22:48 Yeah, that's actually something I didn't know about last year that I missed out on.

22:52 So that's a good thing to – what are open spaces?

22:55 There's a big board and there's a bunch of rooms.

22:58 And the rooms will hold like 20 to 50 people.

23:00 And there's probably five to ten of them.

23:03 I'm not sure exactly how many are available.

23:06 And there's parts of the conference where you can just – anybody who wants to have a group conversation about something, they fill out a little three-by-five-inch note, little card, and stick it up on the board and claim an hour in a room.

23:22 And then people just go and attend it like they would any other talk.

23:25 But it's much more high participation because there's not a proper speaker.

23:28 You just have to basically kick off the conversation.

23:32 And then it's just like a group conversation.

23:34 I think that's awesome because that's kind of what you go to PyCon for anyway is to meet with people that have similar interests.

23:41 Not just Python as a whole but specifically.

23:45 What specific parts of Python that you're interested in?

23:48 Right.

23:48 You might have like an IoT open space for people working with MicroPython or something.

23:53 Who knows, right?

23:54 That would be easily something you could put together.

23:57 The other thing is all the talks are recorded.

24:00 Almost none of the open spaces are recorded.

24:02 Yeah.

24:02 So you can't make those up.

24:04 So that's one thing I really like to do.

24:06 And Trey goes into that a little bit.

24:07 He says they're often more niche and maybe something really you want to focus – like you're really focused on.

24:12 It's all about interaction and discussion.

24:14 And they're not recorded.

24:16 So he pretty much has the same thoughts I do.

24:18 He has some tips for like conversation around breakfast, lunch, dinner.

24:21 Talks about the hallway track.

24:23 I'm a big fan of the hallway track partly because the sessions are recorded.

24:27 And partly the reason I go there is to meet people and to make connections and to have these interactions that I don't have outside of that space.

24:36 Right.

24:36 So I find almost always I'm having a great conversation with somebody and they're like, oh, the session is starting.

24:41 They're like, you know what?

24:42 Forget the session.

24:43 I'll watch it on YouTube.

24:44 Let's keep going on whatever it is we're doing because this is awesome, right?

24:47 And I find like I spend the whole conference that way.

24:49 Yeah.

24:50 It would be lame if nobody went to the talks though.

24:52 No, I know.

24:53 I'm going to go to your talk, by the way.

24:55 Okay.

24:57 I guess I think I guess more I'm saying you're right.

24:59 People, not everybody should just skip them all the time because then what would it be?

25:03 It wouldn't really be the same.

25:04 But don't feel bad about it.

25:06 Yeah.

25:06 Yeah.

25:07 Don't every one of them.

25:10 Right.

25:10 People find yourself in a really interesting situation that you're enjoying.

25:13 Just because it's time to go to the talks doesn't mean you have to go to the talks.

25:16 Right.

25:16 Yeah.

25:16 The other thing that I thought was interesting about this was this conversation, this concept

25:21 of a Pac-Man opening in a group.

25:24 Yeah.

25:24 I love that.

25:25 Yeah.

25:25 So the idea is like, you know, think of Pac-Man.

25:27 It's got the little open spot.

25:28 If you're in a group standing around, don't just like create a closed circle because nobody

25:31 can join or anything.

25:32 So always leave a little gap that says, you know, look for people or look for groups that have

25:37 Pac-Man openings and make sure that your group always has a Pac-Man opening.

25:41 So that's pretty cool.

25:42 Some advice for interacting online during PyCon, how to make the most out of networking and it's

25:48 not really a bad thing.

25:49 Things like that.

25:51 And also volunteering.

25:52 There's lightning talks.

25:53 Have you given a lightning talk, Brian?

25:54 Not at PyCon.

25:56 Yeah.

25:56 Neither have I.

25:57 Yeah.

25:57 It's just some general nice things.

25:59 And then finally, one I thought was interesting.

26:01 There was a person who commented on the post saying, if you're on Windows, it's helpful

26:05 to install a virtual machine image of Linux like the current Ubuntu on your laptop because

26:10 you might run into a situation, a talk or a training where something they're talking about

26:15 doesn't work on Windows and you might miss out.

26:17 That's both an opportunity for us to make the Windows experience better, but also maybe

26:23 good advice for the first person, you know, coming with your Surface tablet.

26:26 You might want to come prepared, I guess.

26:28 Or install Anaconda, something like that.

26:31 Yeah.

26:31 So one of the things I wanted to bring up that I didn't know about ahead of time is

26:35 there's certain sections of the day that is recommended that there isn't, there aren't

26:41 any talks scheduled, but what is the other floor called?

26:44 The place where we're at?

26:45 The conference hall or the?

26:46 The expo hall.

26:47 The expo hall.

26:48 But the expo hall is pretty much open all the time.

26:51 So during a talk, if there's somebody that you wanted to meet up, meet or a company you

26:56 wanted to talk to or something that you can't get to them because there's so many people

27:00 during the normal expo times, skipping one of the talks and going during a talk time, there's

27:06 way less people in the expo hall and you might be able to catch up with somebody a lot easier.

27:10 That's great advice.

27:11 Yeah, definitely.

27:11 So I think that leads us really well into our own news.

27:16 What do you think, Brian?

27:16 Yeah.

27:17 So you brought up my talk.

27:18 I do have a talk Friday and I actually forgot the time.

27:22 It's at five something.

27:23 It's to do with testing and you're giving that a co-presenting with Paul Everett, right?

27:28 Yeah.

27:29 Paul Everett and I are going to, so I love pytest, of course, but I also have in this last year

27:36 fallen in love with PyCharm.

27:37 So we're going to do them together.

27:39 We're going to show you how to make, be efficient and effective and speed up your test and development

27:45 time with PyCharm and pytest.

27:47 It'll be fun.

27:47 Your chocolates and my peanut butter.

27:49 Yeah.

27:49 That's awesome.

27:51 And we have a booth.

27:54 You and I and a few others have a booth.

27:56 I forgot the number, but you'll find us.

27:58 It's pretty easy.

27:59 All right?

28:00 Yeah.

28:00 And we have stickers.

28:01 Yeah.

28:01 I just got my stickers this morning.

28:03 So yeah, I'll be ready.

28:05 Yeah.

28:05 It's going to be a lot of fun.

28:06 I'm really looking forward to meeting people.

28:08 So I hope everyone comes to say hello.

28:10 Yeah.

28:10 That should be awesome.

28:11 And then another thing.

28:13 We talked about the open session.

28:14 Are we planning on doing a live Python Bytes recording?

28:17 Why not try?

28:18 Let's do it.

28:19 Yeah.

28:19 Let's give it a try.

28:20 So I think we're going to do an open session live.

28:24 The next Python Bytes is coming to you live from PyCon.

28:28 It probably won't be streamed live.

28:29 Maybe we'll stream it live.

28:30 I don't know if we can get the audio to work for that.

28:32 But we'll do what we can to do a live Python Bytes and then make that the show for next week.

28:39 So if people want to get notified, they want to make sure they don't miss the time.

28:42 Because it's an open session, we can't pre-schedule it.

28:45 Right?

28:46 We have to go find a slot on that wall there.

28:49 So if people just go to pythonbytes.fm at the top menu bar, clip friends of the show and sign up there,

28:54 then I'll send out an email once we have that time figured out that day.

28:58 I'm thinking Saturday would probably be best.

29:01 Yeah, I think so.

29:01 Yeah.

29:02 Okay.

29:02 So sometime on Saturday if we can pull that off.

29:05 So that would be awesome.

29:06 Hopefully as many people can come to that.

29:08 That'd be fun.

29:09 See how the sausage is made.

29:11 Also, I'm just in a couple days leaving for Seattle.

29:15 I'm going to be at Microsoft Build.

29:16 So neat.

29:17 Yeah, that'll be really interesting.

29:18 Hang out with some of the Python folks there.

29:21 If you're at Microsoft Build and you want to come say hi, just shoot me a message on Twitter or something.

29:25 And if we're there together, that'd be great.

29:27 PyGotham, the New York City PyCon, effectively.

29:32 has just opened their call for proposals.

29:34 And PyCon DE, which is held in Karlsruhe, Germany, which is a wonderful part of Germany, very beautiful,

29:42 is also just opening their call for proposals as well.

29:47 And that's running 24th to 26th in October in Germany.

29:51 So a lot of conference stuff.

29:52 It's like conference time.

29:54 Yeah.

29:54 Yeah.

29:54 We have Google I.O.

29:55 We have Microsoft Build and we have PyCon all next week.

29:58 It's like they're fighting for attention.

30:02 Yeah.

30:02 Awesome.

30:04 All right.

30:04 Well, anything else, Brian?

30:05 Have we covered it all?

30:06 Yeah, I think we did.

30:07 All right.

30:07 Well, wonderful.

30:08 Well, I'm looking forward to seeing you at PyCon.

30:10 That'll be fun.

30:11 Yeah, it'll definitely be fun.

30:12 Thanks.

30:12 Yeah.

30:13 All the listeners.

30:13 Yep.

30:14 Talk to you later.

30:14 Thank you for listening to Python Bytes.

30:17 Follow the show on Twitter via at Python Bytes.

30:19 That's Python Bytes as in B-Y-T-E-S.

30:22 And get the full show notes at pythonbytes.fm.

30:26 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.

30:30 We're always on the lookout for sharing something cool.

30:33 On behalf of myself and Brian Okken, this is Michael Kennedy.

30:36 Thank you for listening and sharing this podcast with your friends and colleagues.

Back to show page