Your Project Manager comes to you asking if something could be done and you say YES. And then you have a unbelievable deadline looming over you for the next few days.
Your peers ask you for some help on a task that they had been struggling with - for days. You say YES and then you end up having to feel the burn for their complete workload.
Your subordinates ask you for help every five minutes and you always say YES and end up helping them and sometimes end up doing all the task yourself - veiled under 'mentoring'.
How do you say NO? How did you learn to say NO?
One weird situation I often encounter is people wanting something on a deadline, but there isn't actually enough time or circumstances have changed. It's highly unproductive when people just keep repeating that a deadline must be meet, regardless of circumstances. What I have resorted to in these cases are not saying no, but asking what they'd have me do. That often removes the expectation of magic or whatever management believes is going to intervene if you just keeps pushing.
- Other projects will be pushed out of the way
- Your deadline is not feasible, I can do it by this date.
- The cost/time of me doing something would be high, due to my inexperience in doing that task.
- I personally think it is a bad idea and a waste of everyone's time, but it's your call.
Things may work differently for others, but turning a "no" to a "yes, on my terms" is what has worked well in any situation I've been in.
Try saying no to smaller things first.
Also, to get over the natural (for many people) social anxiety involved in saying no, try saying it a different way. Example: "Okay, I'd love to do this. Help me prioritize here, though. I've presently got to do X,Y, and Z. I can't do a good job with all 4 and stay on time. Should I cut X? Wait to tackle this? What do you think is best?"
Eventually you'll work up to speaking up and creating preventative measures. Eg "if we're going to frequently face interrupt-driven task priorities, we need to move to some Kanban-like and also give up on concrete milestones."
But yeah.. just start trying. Practice makes perfect. As long as your not a jerk about it and take care to explain yourself and not make a requester feel dismissed, nobody will hold saying no against you. (Unless you're just not as productive as others, or unless it's a crappy environment/culture, in which case you should bail if you can.)
For the PM and boss: "to attend to this new task, I'll have to postpone these other tasks which you asked me to do. Which one is more important?" + paper trail + "this week we focused on Y and are pushing X one week" in status reports.
For the peers and subordinates: if the request is legitimate, discuss, brainstorm, "Here's how I'd approach finding a solution, try it and check in when you find a few possibilities. Google and SO are your friends."
And, for subordinates: teach them to think for themselves and to lead
https://m.youtube.com/watch?v=psAXMqxwol8
Of course sometimes you'll have to put out a fire. But if it's a small fire then you should be training your firemen on it.
When people ask you to do something, tell them where it will fall in your priority list and ask them if they would still like you to come back to them at that point.
I general this works for me, I have product managers come and ask me if I can work out a feature, I say, 'Yeah, I can do that, but i'll have to put off x in order to get to it... is this task more important than x?'
Also, in a similar but different note, at one point as a team lead, I did say no to a project which I felt didn't make sense for our company. It immediately went back up the ladder and turned into career growth for me. So there can be incentive for saying no also!
"Nope, it has to be Ruby on Rails. Oh, and some firm in San Jose will do it $10K cheaper than your quote."
Fired the client, told them to go to San Jose.
Not if they know nothing about programming and they are just throwing out buzzwords they happened to pick up.
Anyone else that asks you to do something should go through the PM. Its up to your PM to decide if that work should be done before your sprint work is done.
So tell people to talk to your PM. If that person has no idea how to be a PM then its time to talk to your boss to find a real one
When you do that, you remove the immediate pressure to please the person with a YES answer.
You also give the (honest) impression that your answer has thought and weight behind it, and is the measured response of a professional.
Tom Limoncelli/Christine Hogan has you covered on this one I guess: The Practice of System and Network Administration mention that you should ask politely if the other party can fire a mail to the ticket system since "that way you can be sure I won't forget".
Tada: off your mind in to a queue that can be sorted and prioritized.
Then the PM would go to your manager and say engineer Y REFUSED to help me with my project. All the PMs did this at that company, so I assume it was a technique taught on whatever training courses they were sent on. Well we all soon got wise to it, and after we started saying no to them in ever more "creative" ways, they soon learned a new technique...
It's not hard, and if you cultivate a track record of delivering on your word, he'll appreciate it.
If you say yes to things you cannot deliver, when you don't, he won't respect your judgment.
Or her.
But hey, for the big cases, you can always go back to the person and say, "sorry, but it's not really going to work. I didn't take into account _____." If they're mad, they're mad. It's like a breakup--it's not ideal, but people change their minds about things, and everyone has to make the best of it.
Sometimes, it's like a marriage proposal to in a public venue. It's hard to say no, but later on, you get to examine your feelings, and you have to eventually make a decision that's true to yourself.
The small cases have to be practice for the big cases.
Eventually, with experience, you'll start to see the patterns, but for now, just do what's best for yourself (which may include following through with the yes).
Not a confrontational question, just a logical one.
In that vein, the BBC used to vet new hires (in an assessment) around how they would react to a colleague who kept asking for help on similar things but refused to learn how to do it themselves.
No idea if they still do this but worth thinking if you are enabling your colleagues to just dump it on you.
Ask yourself, do you completely take over? Have you tried getting them to do it by talking them through but not hands on solving it for them?
Often quicker a couple of times to just take over but long term they'll be reliant on you and you'll be stuck helping them solve that problem time after time.
Harder to do that with tasks from a manager or similar, but I've found it helps to talk through what you'd have to do, what you'd have to drop and problems you see coming. You'll probably still have to do it but you can make explicit what will move down your pecking order.
The approach I take is that I don't care what the order of the list should be (save for dependencies), so I give collective control over that to other stakeholders.
If someone then comes to me a few days later with an "urgent" request that will take a non-trivial amount of time, I simply put the pressure back on them to seek agreement on the change of priorities. They can make their case to the other stakeholders about why their project or task is more urgent or important than others on the list, and come back to me if/when they have that.
The extra benefit to this is that when other tasks are not finished when they were originally expected to be and you are called on this by a stakeholder, you can point out that they agreed to add new higher priority tasks into the queue, so the original time estimates were no longer applicable.
It got easier the day after that, and easier still the day after that.
If any person in your reporting chain does the very human thing of "trying to please", and undercuts your promises, you have a problem. Telling your boss "well I told you so, and I am not going to alter my activities to try and fix it" is a short cut to P45 land.
No matter how much lip service is paid to Agile, the sprint concept is not protected
Agile : it will be done when it's done, there are no schedules, only estimates.
very very few organisations accept this. Everyone has milestones on the board report and if you slip, others slip and lots of pain happens.
It is good to have your own schedule and to feed that out professionally, but it only seems to work in areas where your personal influence (your professionalism) reflects to the top of the decision chain.
Other than that m, saying yes or no is just squeaking of the wheels.
This is also absolutely true for the "Yes" you get back from your requests for help as well.
So I usually say "Yes", but I would qualify it with when I can do it, or what resources I need to complete it etc.
It also comes down to managing the expectations of your requester. Is it OK for them if you complete their request by next week or you only have resource to do half of the tasks.
Then you hit a snag in a project and what you thought was going to take a few days ends up taking weeks. Then more weeks because of more unforseen issues.
Sure you could've researched things to death from the start but there were hidden gremlins you couldn't have seen until you were knee-deep in either research or development.
What then? You're going to blow your deadline and that'll cascade to other work scheduled after your current workload.
The other thing? CUT. Can't have feature completed by next week? What are the parameters? Could you do a mock-up or a skeleton of it and have it serve the immediate, urgent purpose, while potentially still moving you towards final feature nirvana? Better phrased: you've hit a snag, you can't deliver what you said, on the deadline that you said- especially if you fear that manager you'll be reporting to, tell him/her what you CAN still deliver on that timetable. "What CAN you deliver, then?" is almost certainly on someone in your chain of command's mind, desperately begging for an answer! :)
Ask this question, in the way you describe here, to the person you are reporting to, who is responsible reviewing your annual performance. Depending on your target, you may say yes to all and ok be late for deadlines and no to everything else and just focus on one task, and deliver before the deadline.
However, answering colleague's 5-15 minute long questions is different then the above. You should do it even in the expense of doing overtime. If it takes longer then that, you should return to your work.
Really, if everyone on Earth read those two books and his "Getting Past No", the world would be a much happier place.
I don't know how well all of his concepts translate to an IT environment, but it was, for me, a good read with a lot of insights.
Contracting means I just tell them how much it would cost them. It's a remarkably effective filter.
In my younger days I did find myself up at 3am regularly, not having eaten an evening meal with a boss literally sat behind me trying to make me code more. I'd come in the next day and have to undo loads of stuff, it just wasn't effective. One day he proudly announced that he saw his job as keeping salaried programmers in the office as long as possible.
Somehow it got a lot easier after that.
Obviously if you don't have a reason for your no, then you have to go with the yes. As a manager, I'd rather get a no instead of a 'yes' that ends up fucking up everything later because I wasn't aware of something.
All in all: asking for help is a good thing!
There you go, 9 times out of 10 they will shelve the idea.
No is still not natural to me but I now master it when necessary I think.
If anything, myself and the rest of our dev team have a problem with saying NO too often - an opportunity for us is to say either NO in a more productive way (as in, propose a compromise) or learn to be more ambitious and say YES.
You say Yes I can but first need to be finished this and that.
Then say: If you feel your task has priority let me talk to my supervisor 1st.
You will be yes man, expert and your boss will know u r busy.
Noone will feel bad about your attitude. Try it.
Martin