Learn Python with Talk Python's 270 hours of courses

#123: Lessons from 100 straight dev job interviews Transcript

Recorded on Wednesday, May 31, 2017.

00:00 What if you could take the experience and insight from 100 job interviews and use them to find

00:05 just the right job? You'd be able to weed out the bad places that are not a right fit.

00:09 You'd see that lowball offer coming a mile away and move right along.

00:13 But no one could really do 100 consecutive interviews, right? That'd be like a full-time

00:18 job in and of itself. Well, this week you'll meet Susan Tan, who did just that.

00:23 This is Talk Python to Me, recorded June 5th, 2017.

00:28 Developers, developers, developers, developers.

00:31 I'm a developer in many senses of the word because I make these applications, but I also

00:36 use these verbs to make this music. I construct it line by line, just like when I'm coding another

00:41 software design. In both cases, it's about design patterns. Anyone can get the job done. It's

00:48 the execution that matters. I have many interests. Sometimes it can flex.

00:51 Welcome to Talk Python to Me, a weekly podcast on Python, the language, the libraries, the ecosystem,

00:57 and the personalities. This is your host, Michael Kennedy. Follow me on Twitter where I'm at

01:02 mkennedy. Keep up with the show and listen to past episodes at talkpython.fm and follow the

01:07 show on Twitter via at Talk Python. Susan, welcome to Talk Python.

01:11 Hi. Hi, Michael.

01:12 Hi. Yeah, it's great to have you here. You had such a fun PyCon talk and I'm looking forward

01:17 to sharing your story with everyone.

01:18 Cool.

01:19 Yeah. So before we get into that though, maybe introduce yourself really quick and let's

01:24 talk about your story. How did you get into programming in Python?

01:26 Yeah, sure. My name is Susan and I moved from New York City, Brooklyn, New York City to San

01:33 Francisco back in fall 2012, specifically to part of tech industry. And so I've been here

01:40 ever since for the past couple of years. And I really love everything in San Francisco.

01:45 The weather's amazing and lots of really good people here.

01:49 It's a really special city, but I've heard that New York has a pretty good startup scene

01:53 and a pretty good tech scene and whatnot. But you think San Francisco is where it's at, huh?

01:58 I feel like when I was in New York, the startup scene was like tech industry was just starting.

02:03 So it's still like in its input stages at the time.

02:06 I see.

02:06 Like the early 2010s. And so I said, Hey, like, there's a lot of like really cool stuff

02:11 happening in San Francisco as well. Explore. And it was like pretty much like my first thing I did,

02:15 like right after college, I wanted to like explore and like see the other side of the coast.

02:20 Yeah, that's definitely a different city. Awesome. Okay. So how about programming?

02:23 Like take a little bit of a step back. Like how'd you get into programming in the first place?

02:27 So I was doing an internship, a very large biomedical diagnostic company. So I was a little bit bored

02:34 with my internship. And so like during the off hours, like in the evenings, I was working,

02:38 I was exploring this online, massively online class called machine learning taught by professor Andrew

02:44 Ng from Stanford University. And that was when I really like, that was my first introduction to

02:49 artificial intelligence and machine learning. And it was a really good class. Like he's able to break

02:53 down complicated concepts with something that's like bite sized, and easy to understand. So use

02:59 Octave, which is a word domain specific language. And it was a really good experience, like applying

03:04 linear algebra into like actual programming examples. And so I was like, when I really got hooked into

03:09 programming, like, hey, I want to do more of this. Like, how do I get started to do more of this?

03:14 That's really cool. Like, I want to, I want to control the machines. I want to build the machines.

03:18 It's amazing. And was that you said Octave was Python involved in that so far?

03:23 So that was all in Octave, which is an open source version of MATLAB. That's something I use in

03:29 school. So I got my degree in general engineering from a very small liberal arts slash engineering

03:34 school called Harvey Mudd College. It's a very technical school, but they also consider themselves

03:39 a good liberal arts undergraduate school as well. And so I come from a pretty technical background.

03:44 As part of like the first semester, everyone had to take the introductory programming class. So that was

03:50 like my, like even years before that was like my first real step into programming, where they,

03:55 by requirement, they had everyone, regardless of their major, take their first programming class in

04:00 the first semester. And everyone was pretty much like on the same page in terms of like,

04:04 and if you're brand new to programming, you would understand like what's going on. Or if you're

04:08 already advanced, like, they'll put you in a different class, or you'll be able to more people with more

04:13 advanced knowledge, they can go for that class. So it was a really good way to get into programming.

04:17 And they got a lot of new, like CS majors, the introductory program.

04:21 Oh, that's really nice. You said all the people, all the majors take that even if I was like,

04:27 like studying literature, I'd have to take a programming course?

04:29 Yeah, pretty much. Well, just for some context, a lot of the people who are coming into the school

04:35 are pretty much set on like doing something of STEM, or they're like bio majors or chemistry majors.

04:40 It's already kind of an engineering school anyway. So it leans that way. Okay. Yeah, yeah.

04:45 Yeah, well, that sounds really cool. So that first course was in Python, but it was really this

04:51 experience at your internship, you're like, okay, this is actually what I want to be doing.

04:54 Right. So I was doing that class in addition to like doing the internship, which is more on the

05:00 electronics and hardware side, as opposed to like the, like more programming. So it was a different

05:06 side, like I switched over from working with like programming with Arduinos and working with winners

05:11 and like PCBs to like working with software entirely. Sure. All right, cool. So given the topic that we're

05:18 going to cover today, which I think is really fun, like I said, I think it's especially interesting to

05:23 ask, what are you doing day to day now? So I'm a software engineer at a software as a service company

05:30 called Berkeley Electronic Press. The short name is VPress. They're located in downtown Berkeley,

05:35 and they offer a suite of products for universities. So all of the customers are universities. So let's

05:42 say if you are like Harvard, and you want to have an academic profile for various faculty members and

05:50 researchers, you can pretty much use our tools to be able to show off the works of students and faculty.

05:55 That's really cool. I'm always blown away when I go to university websites to academics websites and

06:01 researchers websites, how often they're like really bad, like really, like from 1994 straight out of like

06:08 the web is one year old, you know, and which the reason it surprises me is these people are really

06:15 dedicated. They've got like five papers and two research projects, and they've like dedicated 10 years

06:20 of their life to this. Like surely it needs a better showcase than what it's getting, right?

06:24 Yeah. Library science is a pretty big thing. A lot of librarians are university administrators are

06:30 modernizing their systems. They're pushing ahead, like the digital agenda, like let's like modernize

06:37 these websites, like make it so that it's easy to use for everybody. And we get more users to use the

06:42 platform. And so a lot of like the librarians who are our customers, they're advocating for this on their own

06:47 campuses. Okay. Yeah. So you see a lot of like librarians learning technology skills to be able to

06:53 handle lots of data pretty quickly and be able to have this digital literacy.

06:58 Yeah. Do you feel like that's kind of the story of like all jobs these days that this thing that used

07:04 to be pretty low tech in terms of computer skills required is now like almost requires programming to

07:10 like really take it to the next level? Yeah, I think so. Where, especially in this space,

07:15 there's a lot of opportunity where like, whereas before, like people weren't thinking about like,

07:20 how, how do we use technology to like better improve, to make our lives easier? So this is

07:25 like a space where I found out about it. And I thought this is such a cool like product,

07:29 a suite of products that librarians use. So I just like went into it.

07:33 Oh yeah, that's great. Yeah. You can definitely make a big difference in this space.

07:37 So let's take a step back. How long ago did you start this whole project of looking for,

07:44 for doing a bunch of interviewing and looking for this job?

07:47 So I left my job at Cisco back in mid late August of 2016. So I left a full time job to do the full

07:56 time job searching. And that was like quite an adventure that I do want to talk more about in

08:02 depth. Yeah, absolutely. So I think it's worth pointing out that you worked at a couple of major

08:07 San Francisco style companies before this. This is not your, your first job, your first time looking

08:14 for a job or anything like that, right? You, so you just said you were at Cisco and the way you got to

08:18 Cisco was through a acquisition sort of aqua hire type thing at what was that piston or what was the name

08:24 of this place? So I used to work at a small 40 person cloud computing store called piston where, and

08:31 the product itself is an operating system and it enabled companies that happen to have on-site

08:36 servers to be able to coordinate the resources on those servers. So it's pretty much like orchestration

08:43 and like, it's what people, yeah, DevOps, automated DevOps for people who are in the

08:48 apps business. And so I was working primarily on the web application side. So I was usually one of

08:53 the only applications engineers in a room full of distributed systems engineers.

08:58 A lot of auto operating system people around, huh?

09:00 Yeah.

09:00 So you had a, I'll link to your PyCon talk, but you had like a pretty amazing stylistic photo

09:08 taking the people that work there. Tell me about what it was like to be at that place.

09:11 Yeah. So it's a very chaotic, quirky environment, lots of like energetic

09:16 people. And what really struck me the most was the people around me. I feel like they were not

09:21 the stereotypical type of like, oh, like they're wearing hoodies or jeans. Like these are people

09:26 like from all across various age groups. And especially the men who in the startup were like

09:33 very much into like the steampunk style and like the golden age of Hollywood, like menswear style.

09:39 So like sometimes you'll see them in like three piece suits or like amazing bow ties.

09:44 And they kind of want to like change things up and they don't want to look like something from

09:48 stereotype.

09:49 Not all about the hoodies and the ripped jeans or whatever, huh?

09:53 Yeah. They, they like having, you know, an aesthetic style that, you know,

09:56 and I feel like the entire culture is, is around that as well. Like there's a lot of people

10:01 who like love design and marketing and the arts. It's like, it's a good group of folks.

10:07 Yeah.

10:07 And they're pretty quirky. And I feel that of all the companies, I feel like of all the past

10:12 companies, it's my favorite workplace because I felt like really comfortable in this sort of environment

10:17 where like, I'm not afraid to just be me. And I'm pretty quirky as well.

10:22 And so I had a lot of fun with the culture of the company. And it's just also my first workplace

10:28 where I was coding in Python and I got to learn from like really great, smart people.

10:33 I learned how to do unit testing, learned how to like write idiomatic Python. So that's a really

10:38 good intro for me.

10:39 Yeah, for sure. And the web app you're working on, is that Django?

10:42 Yeah, it's built in Django. So a lot of the code base is upstream code base from the OpenStack

10:49 Horizon code base. So a lot of like the code is actually from, from OpenStack. And then we

10:54 pretty much repackage OpenStack into something that's a lot more manageable to people in terms of

10:58 like the UI and the design.

11:00 Sure. Okay, cool. And so you you went from there to working at Cisco and Cisco is a slightly larger company than 40 people.

11:08 I personally have spent 17 years of my career at small companies. And by small, I mean, 10 people,

11:17 30 people, 40 people, something like that. And I really enjoyed working in those places. You got to

11:23 have lots of leeway in the technology. You got to have, you got to be able to make a pretty big impact

11:28 in the company with what you were doing. And I've also worked at companies that had like

11:33 thousand people. And that's a different experience. So did you find when you went to Cisco that you're

11:38 kind of like, I kind of need to change after a while?

11:40 Yeah. So I think the biggest change, like when I first joined versus like a year and a half later,

11:46 was that I was on an all remote team. So that was like a really different experience because

11:50 pretty much throughout my career, I was pretty much like an all in person team.

11:54 And then all of a sudden I was on like all remote team where like there are seven people and

11:58 they're from like Texas and Canada and Hawaii. So things got, it wasn't something I was expecting,

12:03 like walking in.

12:04 Yeah, sure. Okay. So eventually for whatever reason you decided that's it,

12:08 I'm going to go look for something new. And then how did you decide that like,

12:13 I'm going to go and just start interviewing full time and like really try to find that perfect fit?

12:20 I think after a while, like I decided, well, like I was working on a very small component of a very

12:26 large system. So after a while I was like, okay, maybe I should really do something different. Like

12:31 do something where it's completely outside of this industry where something that's not DevOps related

12:36 or not operating system related. And I really wanted to go to work on a product where people really need to

12:42 use that product, where it's a place where they really need software engineers.

12:46 Right. The level of benefit you can bring to like helping librarians do more technology is a much

12:52 bigger impact than like making that one button do its feature slightly better or whatever that is.

12:57 Right?

12:58 Yeah. Yeah. That's part of working in a large company. There's a lot of different teams and

13:01 lots of different people, lots of different projects.

13:04 A lot of different meetings as well.

13:05 Yeah. Yeah, that is true. I've seen that.

13:08 All right. So, so your talk was basically lessons learned from going through a hundred

13:15 interviews. And at one point you showed your calendar and you're like, look at this. I'm

13:20 like 20 interviews scheduled or 10 interviews scheduled this week. It's like crazy, right? You

13:25 were really going after it.

13:26 Yeah. That was like one of the busiest times in my life probably.

13:30 Yeah.

13:31 And going through that many interviews, I felt like it gave me a good experience of

13:35 different tech products and really understanding what are recruiters looking for? What are engineers

13:39 looking for? It's gave me a really good overview of the industry in particular. So I think that

13:44 in with all like that, I talk a lot about the bad, frustrating aspects about interviewing in my talk,

13:50 but there are some like shining light in the tunnel in this whole process and that you get to go

13:55 and look at cool like tech offices that normally the public would never see.

13:59 Yeah. Yeah. Yeah.

14:00 Yeah. That's really neat. And, and sometimes you get to see demos of some products that are in

14:05 like beta version or alpha version that haven't been released yet to the public.

14:08 So that's cool. And with the chance to maybe be part of that team, right?

14:11 Yeah. Yeah. Yeah. Very nice. So when you started, did you think this is going to take me

14:16 three or four months and a hundred interviews, or did you think it would not be so intense?

14:21 I thought it would finish pretty quickly when I first like really got into the interviewing. And

14:27 then like, if someone asked me last year, if I would do like a hundred interviews, like I was like,

14:31 no way. Like I did not think I would do as many interviews, but strangely, this is how life turned

14:37 out for me. And I just like, you know, was like focused on the next thing, the next company,

14:41 kept moving forward.

14:43 So do you feel like you got like this really interesting life experience or would you,

14:47 like, if you could change it, would just go, I'd rather just have that, find that good job after the first week.

14:51 It's hard for me to answer that because like, wow, like I think I felt, I felt that really grown

14:55 and like really learned a lot from this whole process. And like, I've seen ways that interviews

14:58 are so broken and, and I've met some really great people along the process. And like, I've seen

15:05 really kind people, for example, there's this one time when I was talking to a dirty party recruiter

15:10 and she knew I didn't have like a quiet, like space at home. And so she was like, Hey,

15:16 like, why don't you go to the office and you can use the conference room to take like phone calls

15:20 and interviews there. And that was like really kind of her. And so I did that for a good number

15:25 of mornings for a few hours.

15:27 Oh yeah. That's really nice. Did you work with one person that was trying to get you a job or

15:31 was it just like randomly reaching out and connecting with like the recruiters on the other side or?

15:37 So I know a lot of people recommend that it's better to like the easiest way is like,

15:42 go for a friend. If you know a friend, just have the door. That's an easy way in. But for me, like I,

15:47 I knew a lot of people in the tech industry who are working at the larger companies. And I was like,

15:51 pretty much like set on like networking at more of the larger companies. I was like, okay, like I,

15:57 I should, so I couldn't really ask my friends for connection.

16:01 Yeah. You would get a job where you didn't want to be.

16:03 Right. Yeah. And so it was pretty much me like applying like straight code,

16:07 emails and applications to various tech companies that I found were pretty interesting.

16:11 Yeah. You must've learned a lot of interesting ways to reach out to people you don't know.

16:15 Oh yeah. A lot of it is from like 90% of the time is from the normal application process. There's like

16:21 a number of fields and a lot of them look pretty much the same. There's like,

16:25 fill out the resume, fill out like cover letter and technology makes that easy for applicants to

16:31 like all fill out complete a lot of different fields.

16:34 Yeah. Yeah. For sure. So your comment on the big companies, maybe that's worth going into

16:39 your list of no criteria, because if you would just take any job out there, you probably could have

16:46 gotten one quicker, but like you were saying, you were kind of looking for what you felt would be a

16:49 really good fit. So you had six things, six rules. You're like, I'm not even going to talk to companies

16:56 that fit into one of these areas, one or more of these areas, maybe two areas, right?

17:00 Pretty much if they meet, I try to avoid companies that are any of the above.

17:04 Okay.

17:05 And there's also, I have another list too, where there's like, okay, things I do want to,

17:08 criteria is definitely looking for. So I had like two sets of criteria, the no criteria and then like,

17:12 okay, things I'm definitely looking for, like a good strong culture, a good like culture of code

17:17 review and a good like testing infrastructure and other things like that. But at the same time,

17:21 like I was also, you know, the no criteria is like, was something that it was definitely a

17:25 do for good for me because I didn't want to be in a place where I might get frustrated or

17:29 the top, maybe the culture would be more toxic than I imagined.

17:33 Yeah, sure. So you had no large companies, no homogeneous culture. What does that mean?

17:39 So one of the things I care about is that it's about like diversity in terms of like age, gender,

17:44 race, like all of them, all of the things. And that's something I care deeply about. And I,

17:49 and if I see that a company, they may be like a few years out in business and they don't have

17:55 a diverse workforce. I feel like that may be a warning sign. And there's certain recruiters

17:59 who have been really honest about the fact that I like, if I work there, I may be the first female

18:04 engineer there. And that's kind of scary to me.

18:06 That was not a thrilling concept to you to be the first person to break that ice.

18:11 It is. It is pretty scary.

18:13 Yeah, I would think it would be as well. I mean, I've talked to other women in tech who were like,

18:18 I totally fit and fine. It's no big deal. But just, you know, I didn't connect in the same way,

18:23 like maybe a bunch of young white guys who are programmers who just came out of, you know,

18:29 college or whatever. Like I wasn't interested in land parties. So there goes a big part of my,

18:35 my connecting with my coworkers and whatnot. So yeah. Did you find that it was easy enough to find

18:42 places that were heterogeneous cultures or was it really challenging?

18:47 Well, that's one of the questions I asked recruiters on the first conversation. And I also pretty much ask

18:52 more or less the same question to the engineering director or like the tech lead to see like,

18:59 oh, like what are the ratio, women engineers, male engineers in the environment. So that's like one

19:04 thing amongst many other things I'm looking for.

19:07 Yeah. Yeah. You said also no stupid apps, which is a kind of cut ties back to like,

19:12 you want to make a difference with what you create. Right.

19:15 Yeah. I've seen a lot of stupid apps. Oh God.

19:17 I mean, I've seen apps that like seem pretty implausible. And like, once I think about it,

19:22 I was like, wait, like, why, why would you do this?

19:25 Yeah. I'm a big fan of a lot of stuff happening in San Francisco, but there are certainly some

19:29 companies just like, well, the world does not need this. Come on. I find one of the

19:36 more frustrating things, like maybe near the top of my list of frustrating things in a job as a

19:43 programmer is nobody uses the thing that I built. You put your heart and soul into writing software and

19:50 coming up with something and just, it's like a creation of art almost as a team. And if you

19:56 launch that and then just nobody comes, it's just like, I find that really frustrating. So I think the

20:01 stupid apps may also like tie back to unused apps.

20:05 And I was also pretty careful about companies that are more about like the hype and the marketing and

20:11 the media. And you know, it's, they may not have like the product to be able to fulfill that hype.

20:17 So, so I'm looking for like real companies that have real business value, like to have like proven business success for the long term.

20:23 Yeah. Yeah. So speaking of proven business success, you said you didn't want to be the first,

20:29 like the single technical co-founder or the first tech person, first engineer at a,

20:35 at some kind of startup, somebody's wild dream.

20:38 Oh yeah. I'm pretty sure that is like a dream from a lot of people in the Bay Area to be like the first like founder or CTO of their like first startup.

20:46 But I feel like I like working on a team and on a team environment and like having all of the,

20:53 the advantages of being on a team where like you're tracking people, you're discussing with other engineers.

20:58 It's really important for growth and like technical growth, personal growth.

21:02 Yeah. I think that is really important for personal growth.

21:04 I think being the single tech person is probably okay.

21:09 Once you're more established, you've already got connections with other people in the industry.

21:13 You're pretty confident in yourself.

21:14 You can go to like meetups and conferences and all that.

21:17 But when you're, when you're pretty new, it's certainly, I think it's, it's a really tough place to be because you want that.

21:23 I've always, at least personally wanted to be the least knowledgeable experienced person in the room because I felt like, all right, that,

21:31 that is going to get me in a place where I can just like learn more.

21:34 I agree with that too.

21:35 Yeah. Yeah. I mean, So my current company, I think I'm like more of the, I guess like mid-level younger engineers to give some context.

21:42 Like the company working at has been around since 1999 and they've been profitable since then.

21:48 And a lot of people, like a lot of the employees have been there on average of like seven to 10 years.

21:54 And so to me, that's like, wow, like that's a, that's a long time.

21:57 Yeah. That's a really, really good sign.

21:59 Actually, it is a long time, especially in San Francisco, but it's also a good sign.

22:02 That means like people who work there like to work there.

22:06 Right.

22:07 I went to work at a, like a trading company in New York, actually.

22:12 And went there and it was a training gig that I was doing, teaching some stuff for those guys.

22:19 And there's, there was a pretty big team of people.

22:21 I think it was probably 30 people.

22:23 And this guy came up to me and said, look, I'm the most senior person on this team.

22:27 I've been here for two years.

22:28 I thought, whoa, there might be something wrong in this company.

22:32 It's like, you can't keep anyone out of a group of 30 more than two years.

22:37 This is, this is like a, it was a pretty intense place to work.

22:39 So I think the, the people being there longer is, generally a good sign.

22:43 There's also drawbacks, but pretty good.

22:44 So that was something I was looking forward to.

22:46 All right.

22:47 So great.

22:47 And then the last one you said, you just didn't want to travel too far, which makes total sense.

22:53 This portion of Talk Pythonry is brought to you by us.

22:55 As many of you know, I have a growing set of courses to help you go from Python beginner to novice to Python expert.

23:01 And there are many more courses in the works.

23:03 So please consider Talk Python training for you and your team's training needs.

23:08 If you're just getting started, I've built a course to teach you Python the way professional developers learn by building applications.

23:14 Check out my Python jumpstart by building 10 apps at talkpython.fm/course.

23:19 Are you looking to start adding services to your app?

23:22 Try my brand new consuming HTTP services in Python.

23:26 You'll learn to work with RESTful HTTP services, as well as SOAP, JSON, and XML data formats.

23:31 Do you want to launch an online business?

23:33 Well, Matt McKay and I built an entrepreneur's playbook with Python for Entrepreneurs.

23:37 This 16-hour course will teach you everything you need to launch your web-based business with Python.

23:42 And finally, there's a couple of new course announcements coming really soon.

23:46 So if you don't already have an account, be sure to create one at training.talkpython.fm to get notified.

23:51 And for all of you who have bought my courses, thank you so much.

23:55 It really, really helps support the show.

23:57 All right, so that was your no list.

24:00 And then you went on all of these interviews, and you had a number of interesting stories.

24:06 So maybe we could go through some of your stories.

24:09 Sure.

24:10 So a lot of my interviews are I would send out a job application, fill out the online forms, and click the send button.

24:16 And then I would not hear back from most of the employers for a couple of days or weeks.

24:21 And if I did hear back from them, it would be like this very impersonal email reply.

24:25 Oh, sorry, dude, some of our candidates.

24:27 We can't have you move forward.

24:29 So I felt pretty mildly disappointed.

24:32 But at the same time, I knew that they can't get back to me with a detailed personal response, even if I wanted them to.

24:39 So that's when I go, okay, it's time to move on to the next opportunity.

24:43 So it can get pretty grating at times and a little bit frustrating.

24:46 But I understood where they're coming from, that they're pretty busy people.

24:50 Yeah.

24:50 So you get the serious silent treatment.

24:53 Yeah, but you said one of the things that was kind of funny was like, people would pick it up later and like come back to you much later, right?

24:59 Oh, yeah.

25:00 That was really unusual.

25:02 Like, that's something I was not expecting.

25:04 Usually in the Bay Area, a lot of people get back to me if they're interested in like a few days or up to a week at most.

25:10 But to get back to me like months later.

25:12 And like literally, I once got this email from a company and they're like, oh, like we found your resume several months later and we wanted to be you.

25:20 But they're like, I've already accepted a job months ago.

25:24 Yeah, yeah.

25:25 Too late.

25:25 Yeah, this is a little bit weird.

25:27 I certainly see how people get overwhelmed.

25:29 Like I put up ads for jobs and, you know, got to so many applicants.

25:33 It's like, oh, my gosh, I don't know if I could deal with all this.

25:36 Certainly not like detailed responses.

25:37 But yeah.

25:39 So another one was this AI startup that you were talking about.

25:43 And you said the interview went pretty well.

25:46 But in the end, they decided to just hire their friend or something like this, right?

25:51 Ironic to me was that they were working on like automating human resources, like the hiring component.

25:56 And yet they decided, OK, well, we're just going to hire someone already now, which is like ironic because what is the purpose of the product that they're making?

26:05 The machine says my friend.

26:09 Oh, and again, like, you know, if you have a connection, a way in, that's great for you.

26:15 And we're lucky for them.

26:17 But a lot of times, like when I was doing a job search, like I didn't have a way in, like a direct connection or just me.

26:22 And everyone else is very much like, you know, they reached out to me via email or the standard application process.

26:29 Yeah, sure.

26:29 So how much do you think like moving out there from New York and not growing up there sort of limits your connections to like the number of people in these positions maybe?

26:42 So initially, it was harder for me because I didn't have like a network of people already in the Bay Area.

26:47 So I had to reach out to people, like connect with other people.

26:52 And that can get pretty frustrating sometimes, like especially for like the interviewing process, because sometimes people are hiring, sometimes they're not, especially for the meetups I would go to.

27:02 So it's really hit or miss for me.

27:03 And one of the questions I got from people after my talk was like, to what extent was I going to meetups and doing a networking thing?

27:10 And I didn't really do a whole lot.

27:12 I personally found that pretty draining, especially at the end of a long day of interviews.

27:16 Like I kind of didn't want to go to like a meetup.

27:18 And that was my personal.

27:20 Maybe some people are really into like all the networking and meeting all the possible people.

27:24 But as an introvert, I felt that it's a bit more draining to put myself out there.

27:29 Yeah, it can be pretty hard to do that as well.

27:32 Sure.

27:33 It's definitely challenging, especially if you're, it's kind of hard to walk in completely by yourself into a room and start just randomly talking to strangers.

27:42 I find it's a little easier in the tech space for me because I can just talk about tech, which is a pretty, is a pretty good common thing to talk about.

27:52 But general networking is still pretty challenging.

27:54 So what about Jelly?

27:56 Initially, I was pretty excited about Jelly.

27:59 And I was one of like, when I found out about Jelly, I was like one of the more avid users I was asking.

28:04 So Jelly to backup is a Q&A app.

28:06 You ask questions and then you can get answers that are-

28:10 Like Quora?

28:10 Yeah, it's pretty much like Quora.

28:12 Okay.

28:13 And their focus is about like providing quality answers.

28:17 So they're pretty selective about like who gets to like answer the questions or trying to find like the best people for that.

28:22 And it's all like crowdsourced.

28:24 So it's really up to like a team of volunteers who are in the community of experts who are answering a lot of these questions.

28:31 And they have like a Twitter integration where you get to put a hashtag, ask Jelly.

28:35 So sometimes I would like ask questions in 140 characters and I get a response back.

28:40 Okay.

28:42 And you had an interview with Biz Stone, co-founder of Twitter, who asked you just one question, right?

28:48 Yes.

28:49 What was the question?

28:50 So he asked me, what do you hope to accomplish in your life, Susan?

28:55 And I was a little bit from back from this question because I wasn't sure how to answer it.

28:59 Like this was not one of the questions I was prepared for.

29:02 So I was totally ready for like other questions.

29:05 Like, okay, like how does that jingle work?

29:08 Or like how does the internet work?

29:10 And I was ready for it.

29:11 It was kind of like web-depth related questions.

29:13 But this is like a really broad question to me.

29:15 So I was a bit in trouble.

29:16 What's the advantage of using a Q in such and such situation or something, right?

29:21 Like that's not the same as what are you going to accomplish in your life?

29:24 Yeah.

29:25 So I was like really like taken aback.

29:27 And so I basically had to come up with something really quickly on the spot.

29:30 And I talked about like my passion for Jelly.

29:33 Like it seems like it really has a lot of potential.

29:35 And I want to work on the features and get more users to use this product.

29:40 So it was like pretty like a standard response to something that's pretty generic, I think.

29:46 So I think he liked the answer.

29:49 Like, you know, he also gave me his answer, which seemed a little bit hippy-dippy.

29:54 He gave like this.

29:55 He gave me an answer about how he wants to connect the world and make everyone part of this like community of like-minded internet.

30:02 It's very hippy-dippy.

30:03 If I remember.

30:05 Yeah.

30:05 Sounds a little like Twitter Jelly.

30:07 Okay.

30:09 And you said you had this very awkward experience around like, hey, we know you don't really know Ruby that well, but why don't you implement a full stack solution in Ruby anyway?

30:20 Now.

30:21 Tell us about this one.

30:24 Yeah.

30:24 So I, so basically I walked into the office and the email that I got before the interview was like, hey, you should brush up on some Ruby and some Ruby on Rails.

30:33 And so initially like when I walked into the office, I thought I was going to be pair programming with the interviewer on a full stack Ruby application and we'll go through the problem together.

30:41 But it turned out that he wants me to implement a feature on an existing Ruby application from in like 15 minutes.

30:48 And I was like, wait, like, are you sure you want me to do this in 15 minutes?

30:51 And he was like, yeah, yeah, sure.

30:53 Go for it.

30:53 Since like he's in charge of this whole process.

30:56 I was like, and I was following instructions.

30:59 Like, okay, yeah, sure.

31:00 Why not?

31:00 And so I tried like going through the process.

31:02 Like I was looking up the documentation, like going through the online Ruby tutorial.

31:06 I was like, this is really awkward.

31:08 Like I'm trying to like learn Ruby at the same time, trying to create something that would be a profession.

31:12 Yeah.

31:13 And so 15, there was also like my shortest interview, 15 minutes.

31:17 And then like a few minutes later, he, he saw, I was like, not at all proficient with Ruby, which was, I told him that like a few minutes ago.

31:25 And he stopped me saying, okay, Susan, you don't seem to know Ruby very well.

31:29 So let's just hold off on this until you gain some experience in Ruby.

31:33 Then we can reconsider.

31:35 Yeah.

31:35 And you didn't follow up a few months later after you had done a bootcamp in Ruby.

31:39 I kind of understood where he was coming from.

31:42 Like, okay, this is like a, he wanted, maybe he did actually want people who are experienced in Ruby.

31:47 And not like he, maybe he wasn't willing to look at beginners or teach newbies.

31:52 Yeah.

31:52 And that's totally reasonable.

31:53 Like to say, look, I want somebody who already knows this technology.

31:55 You can just come in on the first day, start being productive, but that should be like clear.

32:00 Yeah.

32:01 Beforehand.

32:01 Right.

32:02 Like it should just like, that should be more obvious.

32:03 So that's kind of awkward.

32:05 I'm sure.

32:06 Right.

32:06 Yeah.

32:06 So there's a pattern of like a lot of interviewers may not know what they're looking for.

32:10 And so they ask a lot of these questions that may, may not be relevant or they give you code

32:14 challenges that may not have pertinence to the job description.

32:19 Sure.

32:19 So let's actually talk about code challenges since you brought that up a little bit.

32:23 Like that seemed to be like one of your really biggest pet peeves of the whole experience.

32:28 Yeah.

32:29 So code challenges to give an intro, sometimes you may get code challenges and that can take

32:33 anywhere from like 60, 30 minutes, 60 minutes, 90 minutes.

32:36 And sometimes it can be timed where you answer a number of questions and it's either like a

32:42 right answer or a wrong answer, depending on what they're looking for.

32:44 Or sometimes there are open-ended questions where you have to build an application from scratch

32:50 or you have to like create the models and the views and controllers, the whole thing.

32:54 If you're a web application developer, I particularly really harp on like the open-ended

32:58 open-ended code challenges in particular, because there's like no time constraints or sometimes

33:03 there's no time constraints or like no feature constraints.

33:05 So you don't have an idea if this will take like an hour or it's like a whole weekend project.

33:10 Yeah.

33:10 Give us an example.

33:11 So one example is build a full stack application that uses the Twitter API in some way.

33:19 And so it's just open-ended because you can use the Twitter API in any number of ways.

33:23 This particular is challenging because you're not sure like what exactly are you looking for?

33:28 Like, are you looking for design?

33:29 Are we looking for how well I can write the test for this feature or how?

33:33 So it's really hard to tell, especially if that code challenge doesn't come with really clear

33:37 and specific guidelines.

33:38 Like what is the input?

33:38 What is the output?

33:39 Yeah.

33:40 So certainly you mentioned design.

33:41 That's obviously one of them.

33:43 But even on just the programming side, like you could go to either end of a spectrum.

33:48 You could say, look, I want to see the most properly designed, layered, design pattern type

33:55 of testable architecture.

33:57 And that's what you could be graded on.

33:59 Or you could be graded on, I want to see the most complete, full implementation of a cool

34:05 app.

34:06 In which case you should throw that out the window and just write crap as fast as you can,

34:10 because it's not going to have to work really other than just to prove the concept.

34:13 Right?

34:14 Yeah.

34:14 And so what should you do, right?

34:16 You don't know.

34:16 Yeah.

34:16 And sometimes when I would go and spend time on the open-ended code challenges, one of the

34:21 things I fell into is that, okay, like one of the feedback I got was like, maybe I didn't

34:25 write unit tests or maybe I didn't use the right library that they expected me to.

34:29 So it's really hard to know what you're expecting because you're not given those instructions.

34:33 Yeah.

34:34 Yeah.

34:34 And you can spend days on it and maybe not even get anything out of it.

34:39 Right?

34:40 Right.

34:40 Yeah.

34:41 I suspect the most frustrating part is the ambiguity.

34:44 Like, I don't know what criteria I'm being evaluated on.

34:48 So I just got to like, what, go implement some brand new app from scratch.

34:52 And it's part of my exam.

34:54 Right?

34:54 So the last story you had was about this genetic biochemistry company that uses the CRISPR algorithm.

35:01 Right?

35:02 What's the story there?

35:03 Yeah.

35:03 So on paper, it sounds really great.

35:05 Like they're a very mission oriented company and the website has all these information,

35:09 like papers they've published and the team looks like really solid, like lots of experienced

35:14 people.

35:14 Lots of PhDs probably.

35:16 Yeah.

35:16 Yeah.

35:16 Yeah.

35:17 So this is like the biotech space.

35:19 And there's a lot of chemistry people, mechanical engineers, electrical engineers, and software

35:23 engineers all working in a lab environment.

35:25 Yeah.

35:26 Sounds really fun.

35:27 Yeah.

35:27 And so I got to explore and did a tour of the lab and that was pretty neat.

35:33 And in that interview process, I did a live coding challenge where I was making, I made

35:38 a Django app that went pretty well.

35:40 And I answered a lot of questions and asked a lot of questions to a lot of the engineers

35:44 there and including the two co-founders who also happened to be brothers.

35:49 So that was pretty interesting.

35:51 So at the end, I really enjoyed the process and everything seemed like really swell and good.

35:57 And I got the job offer with like the number and I was like, and I was pretty disappointed.

36:02 And I said, well, and I told the CEO and the co-founder that, well, this is like way

36:06 below the average salary for what a software engineer of my level experience should be making.

36:11 I said, no, I went on 50 interviews.

36:13 Yeah.

36:15 And his response was very like, he was very stubborn and he didn't want to negotiate.

36:20 Like I can tell that he was being very defensive on the other end of the phone.

36:24 So to me, like that didn't seem like everything on when I visited in person, it seems good.

36:29 But then like the company wasn't really willing to pay competitive salary to their engineers.

36:34 Well, and there's one thing is like, if this company is kind of just getting started and

36:39 they're, they're looking for VC money and they're thinking that this is going to blow up

36:43 and they say, look, we'll just take care of you when everything starts to take off and

36:47 it's going to be amazing for everyone.

36:48 We just all got to kind of come together to help launch this idea.

36:52 That's one thing, but they had like $40 million in VC funding already.

36:55 Right.

36:55 Yeah.

36:57 And they're ready and they're like fifth or fourth year.

37:00 So it's, they're not like a baby startup just getting started.

37:03 Yeah.

37:04 So they have a lot of money and that was like an automatic note to me.

37:07 Like I'm not willing to compromise.

37:09 You know, I think it's interesting is there are two, well, there are more than two types.

37:12 There are two categories of companies that come to mind that really, and I don't know if

37:18 this is the situation here.

37:19 Tell me your thoughts.

37:20 Like on one hand, there's companies, this could be in San Francisco and tech companies,

37:24 or it could be in Kansas city in, you know, like a cable company.

37:28 It doesn't really matter.

37:29 But that where the company sees their software team and their software people, their technology

37:34 people as like, like a sword that they can wield in business.

37:38 Right.

37:38 Like something that is super powerful and is like, should be respected.

37:42 And then there's other companies that just see it as like an expense, like that just drags

37:47 on the business.

37:48 And so maybe these guys, they had that mindset where it's like, well, these developers, they're

37:52 necessary, evil.

37:53 We have to pay them.

37:54 It's hard to tell.

37:56 Yeah.

37:56 Yeah.

37:57 I'm sure you didn't go into the philosophy too much with the guy.

38:00 Anyway, I definitely been in some companies where they, they don't seem to realize like,

38:05 Hey, we have this amazing software team.

38:06 Like, what could we do if we really inspired them?

38:08 And they just seem to like, you know, not, not put a lot of credit in what they say or

38:12 do or whatever.

38:13 And that's not amazing.

38:13 Yeah.

38:14 And this often comes from say, like if the founders aren't technical themselves, they

38:17 may not understand like, Oh, why do we have to have an ops team?

38:20 Why do we even have to have people working on like the front end?

38:23 I can even see if you were like a super high end scientist, theoretically, you might go,

38:28 well, the science is what's important, not the programming.

38:30 That's a dime a dozen, right?

38:32 I suspect that's less common, but it still could be the case.

38:36 All right.

38:37 So you gave us the talk.

38:41 You gave some numbers about how long it took you to find your first job, your second job

38:44 and this last job and maybe some takeaways.

38:48 Can you maybe run that down for us?

38:50 Overall, it was a pretty frustrating experience because I talked to a lot of different companies.

38:55 Sometimes I expected more positive responses and a lot of them turned out to be like, okay,

39:00 like more frustrating experiences than I expected.

39:02 Yeah, I'm sure.

39:04 So I've gone through, talked to a lot of different engineers and learned a lot about different

39:08 products.

39:09 So it's really, I feel like the whole process is like a crap shoot.

39:12 Like you, you have no idea.

39:13 It's so unpredictable.

39:13 Like you don't know how long the interview process may take and like what kind of questions

39:18 you might get.

39:19 And it can get pretty frustrating at times because getting a lot of no's can be like,

39:25 you can lose your self-confidence when you're going through this process.

39:28 But to me, like the way I got through it, like I tried to like take a step back and you know,

39:33 the next day after taking breaks in between the next days, there's always like a new opportunity

39:38 for me.

39:39 And there's always like a new door, lots of new people to talk to.

39:42 So like every day it was like a blank slate, like start fresh.

39:45 Yeah, that probably takes putting yourself in the right mindset somewhat.

39:50 So you're like, because you've got to show up with a good attitude.

39:54 You can't just show up like looking worn out and like dejected, right?

39:58 No one's going to hire you then.

39:59 So yeah, it's good to take some breaks.

40:01 And if you need to take like the afternoon off, just to like to clear ahead.

40:05 I did that.

40:06 Like there's lots of places where I would walk to just to take some walks.

40:10 It's very therapeutic.

40:11 And yeah, yeah.

40:13 And I also drink a lot of tea as well.

40:15 It's kind of like keeping calm.

40:16 That's really cool.

40:18 Nice.

40:19 Okay.

40:20 So did people ask about like, what did they ask about your prior work?

40:24 Like, did they check out your GitHub profile?

40:26 Did they talk about open source?

40:28 What you did at other companies?

40:29 What did they seem to focus on?

40:31 So the reason I'm asking is people who are out there looking for a job, like, you know,

40:35 where should they spend their energy?

40:37 I think having a good project you can focus on.

40:40 So a lot of questions that I've gotten are about previous favorite projects.

40:45 Like what's been your favorite project?

40:46 What's been the most challenging project?

40:48 So these are going to be questions that are going to be like pretty common if you go to

40:53 eventually to the on-site interview.

40:54 So it's good to be pretty prepared and be able to show off like your strengths and be able

40:59 to talk at length about different decisions that you've made or challenges that you faced

41:03 and how you overcome them.

41:04 Sure.

41:05 Did anybody ever ask you what your favorite open source project was?

41:08 Or was it always focused on like what you had done personally?

41:11 I don't think I've gotten that question.

41:13 It was primarily focused on like previous work.

41:15 So sometimes I would get questions where I need to like diagram or like whiteboard what the

41:20 architecture was for this past project.

41:23 So yeah.

41:24 So that's pretty typical.

41:25 Yeah, sure.

41:25 Okay.

41:27 Well, this is very, very interesting.

41:29 Let me ask you two more questions before I let you go and then we'll do a quick wrap up.

41:36 So if you're going to write some Python code, what editor do you open up?

41:40 It depends.

41:41 I switch between sublime text and Vim.

41:44 So the past two years I've been working on Vim, using Vim primarily because I had to SSH,

41:49 vagrant SSH into a good Linux environment.

41:53 Yeah.

41:54 So I learned how to use a lot of Vim packages like c tags, a lot of the common Vim packages installed.

42:01 But then what's frustrating about Vim personally is that sometimes when I destroy my environment

42:05 accidentally, I have to like reset up all of the packages again and like reinstall those packages.

42:10 And that gets a little bit annoying.

42:12 How do I get this thing working again?

42:13 Yeah.

42:14 I saw a picture.

42:15 It was some kind of meme.

42:16 It was a picture of a bus and it had VIM written like in huge letters on the side.

42:21 there were people in it and the meme was, how do I get off this bus?

42:25 How do I quit this bus?

42:26 Basically.

42:26 It was really funny.

42:28 All right.

42:29 So favorite PyPI package or most notable one that you've come across that maybe people haven't

42:33 heard of.

42:34 In Django, I really like Shell Plus.

42:36 You can use Shell Plus to load pretty much the database models into the shell.

42:42 So that's been really useful for debugging.

42:44 Oh yeah.

42:45 That's cool.

42:45 Because you have everything already preloaded for you when you open up the Django shell.

42:49 Yeah.

42:50 Nice.

42:50 Okay.

42:51 Very cool.

42:51 That's a good one.

42:52 All right.

42:53 So last thing, final call to action.

42:55 You've gone through this whole experience of all these interviews.

42:59 You even like were fairly retrospective or introspective about the process because you

43:05 did this PyCon talk, which I'll link to in the show notes.

43:07 So with all that, can you give people out there who may be looking for a job, like a couple

43:13 of pieces of advice?

43:14 What can you tell them to make it a little bit easier given what you've gone through?

43:17 Don't be afraid to say no when you think that.

43:20 Things may not be working out during any part of the interview process.

43:24 And I know I have a list of no criteria.

43:27 If you can be selective and feel free to do that.

43:31 And also you don't have to go for like, say, 20 interviews in a week.

43:35 Not a lot of people want to do that.

43:36 So take your time and take breaks in between.

43:40 Some people may get their first job at the first onsite or they may take a while.

43:46 So it really depends.

43:46 So it's really unpredictable.

43:47 So be mentally prepared for this process.

43:50 Yeah.

43:50 So one more question, I guess.

43:52 Like, how did you keep going?

43:53 Like, how do you just not get really frustrated and go, ah, I'm just going to go work at a

43:57 big company.

43:57 I'm going to go do something different or change my plan.

44:00 I really want to stay in San Francisco.

44:02 So it's just, it's a really good place to be in terms of like the environment.

44:07 And I really love the city.

44:08 So that's something I want to keep going.

44:10 And I didn't want to move back to New York City.

44:12 Yeah.

44:12 I guess it sounds like you were really clear about what your priorities were and that

44:17 kind of helped guide you.

44:18 Yeah.

44:18 So I have like a pretty clear list of like certain days I'm looking for.

44:21 And I was pretty excited when I found like a new company, a new product that I want to

44:26 contact the people behind that product and talk to them about it.

44:29 So that's something that kept me going because I like reading news articles and new product

44:33 releases.

44:34 So that's something, if there's like a new thing that gets me excited, yeah, that's, I want

44:38 to talk to them.

44:39 That's awesome.

44:39 So thank you so much, Susan, for sharing your journey and congratulations on finding

44:44 a place where you're happy after all this work.

44:46 That's, that's excellent.

44:47 Great.

44:47 Thanks for having me.

44:48 You're welcome.

44:48 Bye.

44:49 All right.

44:49 Bye.

44:49 This has been another episode of Talk Python to Me.

44:54 Our guest this week has been Susan Tan.

44:56 Are you or a colleague trying to learn Python?

44:59 Have you tried books and videos that just left you bored by covering topics point by point?

45:04 Well, check out my online course, Python Jumpstart by Building 10 Apps at

45:08 talkpython.fm/course to experience a more engaging way to learn Python.

45:13 And if you're looking for something a little more advanced, try my Write Pythonic Code course

45:17 at talkpython.fm/pythonic.

45:20 Be sure to subscribe to the show.

45:23 Open your favorite podcatcher and search for Python.

45:25 We should be right at the top.

45:26 You can also find the iTunes feed at /itunes, Google Play feed at /play and direct

45:32 RSS feed at /rss on talkpython.fm.

45:35 Our theme music is Developers, Developers, Developers by Corey Smith, who goes by Smix.

45:40 Corey just recently started selling his tracks on iTunes, so I recommend you check it out at

45:45 talkpython.fm/music.

45:47 You can browse his tracks he has for sale on iTunes and listen to the full length version

45:52 of the theme song.

45:53 This is your host, Michael Kennedy.

45:55 Thanks so much for listening.

45:56 I really appreciate it.

45:57 Smix, let's get out of here.

45:59 Smix, let's get out of here.

45:59 Outro Music.

46:21 you you

Back to show page
Talk Python's Mastodon Michael Kennedy's Mastodon