climbing up the technical stool

That's a function of the size of the company and industry you are in. In

general, the technical ladder (or stool) becomes steep very quickly. And as you

climb it up, you start to see that you do more management than actual hands-on

thingie-building. But do not delude yourself into thinking that this type of

management is of a non-technical nature.

Software Architect. Enterprise Architect. Technical Lead. Principal Engineer.

Technical Director. Chief Scientist. Let's call these upper-stool technical

positions.

These types of positions require you to do less hands-on stuff, but the

management you will have to do must be technical-oriented. How you assign

technical tasks to people and teams will depend on whether tasks are technical

feasible, on identifying the technical capabilities of your team, on

understanding the resources required to complete technical tasks.

Granted that a lot of people who get into these positions let go of themselves,

gradually detaching themselves from the technical realities on the ground,

where the pedal hits the metal. And as a result, their decisions are no longer

technical, with technical consequences that is beyond their grasp. But those

are examples of doing a bad job in their positions. And that exists at all

levels, from the uber-chief of technical reality down to the lowest code

monkey.

These are the fabled paper tigers.

That is, being detached of technical realities is not an inevitability of

working so high up the ladder/stool. Good technical people remain strategically

and tactically technical always, regardless of their pecking order. A good

above-the-clouds architect can drop back to code with only a few days to clear

the mental cobwebs. A good technical foot soldier can extrapolate the reasons

behind good high-level technical decisions, even if he/she does not have the

management experience (which naturally they don't at their entry level of their

careers.)

My suggestion to people who find themselves staring at the technical stool: put

another stool over it, secure it with nails, crazy glue or some other good

shit, and then climb it. That is, like a good engineer, you need to engineer

and build your technical ladder.

This can only be done without realizing first that to climb it, you will have

to gradually move away from hands-on work without losing your technical wits.

You cannot allow yourself to become a paper-tiger.

This will also means that when you find yourself at a company where there is

nowhere else to go but down (because the stool cannot go any higher for

whatever reasons), then it is time to go somewhere else where there is a chance

to nail/glue another stool over the one you have built so far.

These are my personal interview red flags for a software developer job,

starting with the most likely to result in me throwing the interview/leaving

early/declining any offer:

Hiring is based on brain teasers, $-based certifications, or other similarly

irrelevant criteria.

Wants to know my current salary. (Bonus point: Doesn't give any indication at

the same time of the likely compensation if I'm offered the job. Extra bonus

point: Makes clear that the salary range given in the job ad was wildly

optimistic.)

Won't show me an example of their production code, real documentation, etc.

when given a reasonable opportunity to do so.

In each case, someone is skirting what matters, instead of finding out as fast

as possible whether we are really a good fit and a mutually satisfactory hire

might result.

current salary?

try this: companies are now asking (expecting!) your WHOLE CAREER SALARY TRACK!

I laugh and refuse. I don't even give current salary, I give a range of what I

expect for THIS job.

one guy even asked if the # I gave for my salary was verifyable. I asked him

'this is a trick question or test question isn't it? there's no legal way you

can 'verify' my salary, so who are you trying to kid, here??'

of course, some actually want COPIES of your pay stub to prove it.

I walk away from such places. those are big red flags that there will be mgmt

trouble later on, at that kind of place.

look, if you want to hire me, stop playing games. but if you want to start

things off poorly, start DEMANDING I tell you private things, like how much I

made last year. that's none of your fucking business, mr corporate asshole

hiring mgr. talk about rude questions - and the fact that so many people just

give in and answer them! astonishing.

then again, its a horrible time for job seekers right now. they have us by the

shorties, as there is NO bargaining and NO unions to help us keep the big co's

in check and in their place.

This is the best advice out there. If you enter any job interview from a

position of needing the job rather than wanting it, you risk not being happy in

your role. And don't be afraid to turn the question back around - if someone is

asking you where you see yourself in five years, why are they asking that? Is

it because they want someone who will grow with the company, do they have a

specific path mapped out that they'd want you to follow, are they hoping for

someone who will stick in the one position forever, etc - ask them, if you got

the job, where they'd see your role in five years, because it depends more on

them than you at the end of the day (it doesn't matter if you see yourself as

CEO if they only see you in a junior role).

Ask them to program something specific

I guess we combine the two approaches: we send our candidates small coding

problems to solve. So we see real code they create and have a standardized way

of comparing it to what other candidates have provided.

It works really well at filtering out people we don't want to waste time

talking to, and gives us a starting point for the technical interview. It isn't

useful for deciding whether or not a candidate should be hired, since there are

many other factors that come into play.

I ask candidates puzzles

But the idea isn't to get an answer - and I am very up front that I don't care

about the answer, and I already know it anyway. What I do want to see is how

someone approaches a problem that they don't know how to solve. I had one

candidate ask me the answer, I already know it after all - immediately top of

my hiring list, and she was an awesome hire. Another asked if they could use

google on their phone - again a pretty much perfect answer. The puzzle is

completely irrelevant, the ability to question, put forward ideas and not just

say 'I don't know' or, even worse, go completely silent and get embarrassed

that you don't know, is pretty fucking critical. IMHO.

I also look at samples of previous work, and we make all candidates carry out

real world tasks along side us.

> If the candidate is embarrassed, you should find the reason why, what

emotion is interfering?

http://developers.slashdot.org/story/12/01/06/1334246/

are-brain-teasers-good-hiring-criteria