📜 ⬆️ ⬇️

What are the responsibilities of the lead developer

This big John Olspau article is called "Being a Lead Engineer . " The first time I read it about four years ago, when I just started working for the current job, and it really influenced my ideas about this direction of my career.

Rereading it now, the really interesting thing there seems to be one thing, that empathy and helping the team is an important part of the work of the lady. Which, of course, is true!

But now I see that most or all of the leading engineers I know take on considerable help from other employees in addition to their personal programming work. Now it seems to me that my colleagues and I face not so much the problem “What ?? Need to TALK WITH PEOPLE ?? INCREDIBLE ", but with another problem:" How to balance all this leadership work with your individual contribution / programming? How much and what work should I do? ” Therefore, instead of talking about the signs of the seigneur from the Olspau article (with which I fully agree), I want to talk about the work we are doing.

What is this article about


“What does the lead engineer do?” Is a huge topic, and here is just a small article, so you should keep in mind:
')

What are the responsibilities


These are things that I see more as the work of the lead engineer and less as the work of a manager (although managers definitely do some of the above, especially creating new projects and linking projects with business priorities).

Almost all of this work is essentially technical : helping someone to cope with a complex project is clearly human interaction, but the problems we will work on together will usually be technical! (“Maybe if we simplify the design, then we can cope faster!”).


In the first place I put "write code", because in reality this task easily slides down in the list of priorities. :)

The list is missing the item "to make estimates / forecasts." Here I am not very good yet, but I think that someday it is worth spending more time on it.

The list seems big. It seems that if you do all these things, they will absorb all your intellectual resources. I think that in general it makes sense to pick out some part and decide: “Right now I'm going to focus on X, Y and Z, I think my brain will explode if I try to make B and C”.

What is not the responsibility


It's a little more complicated here. I do not say that such things are categorically impossible to do. Most of the leading engineers I know spend a tremendous amount of time thinking about these issues, and work a little in that direction.

But it seems to me that it is useful to draw a certain border, because some people have a high sense of responsibility for the team and the company - and they are ready to take on everything, and as a result they will be overloaded with work and will not be able to make a technical contribution, which in fact is their main business. Therefore, the establishment of some boundaries helps to determine what issues it makes sense to ask for help when the situation becomes restless. Your real boundaries depend on you / your team. :)

Most of the following are the work of a manager. Disclaimer: managers do much more than what is listed here (for example, “create new projects”), and in some companies some of the above may actually be the work of a lead engineer (for example, sprint management).


It is useful to set boundaries explicitly.


Recently, I was faced with an interesting situation when I discussed my responsibilities with the manager - and we realized that we look at them very differently! We clarified the situation, and now everything is in order, but it made me realize that it is very important to agree on expectations. :)

When I started as an engineer, the work was pretty simple — I wrote code, tried to invent projects that made sense, and everything was fine. My manager always had a clear view of my work, nothing too complicated. Now the situation has changed! Therefore, now I believe that I must determine the work that:


The exact wording will be different for different people (not everyone has the same interests and strengths, for example, I am not too good at code review!). I think for this reason it is even more important to discuss this topic and coordinate expectations.

Don't settle for work you can't / don't want to do.


I think it is very important to abandon work that I cannot do or which in the long run will not bring joy! It seems tempting to take on a lot of work, even if you don’t really like it (“Oh, that's good for the team!”, “Well, someone has to do it!”). Of course, sometimes I take on tasks only because they have to be completed, but I think that for the health of the team it’s actually very important that employees do what they like in general and what they can do in the long run.

Therefore, I will take small tasks that just need to be done, but it is important not to say: “Oh, of course, I will spend most of my time on what I’m doing poorly and what I don’t like, no problem” :). And if “someone” has to do this, perhaps it simply means that we need to hire / train someone new to fill the gap. :)

I still have a lot to learn!


Although I feel that I am beginning to understand what “lead engineer” is (already 7 years in my career), but I still feel that there is still much to be learned about it, and I would be interested to hear how other people define the boundaries your work!

Source: https://habr.com/ru/post/427223/


All Articles