An Engineering Lead is a formal role that is added to an engineer’s normal responsibilities. Becoming an EL does not result in a change in title, and people can switch in and out of this role on different teams based on what is the best fit for the team and individual at that time.
Engineering Lead is a leadership role. The technical success & output of their squad is more important than the code they themselves write.
- If the technical solution the team chooses doesn’t solve the problem, it’s on the EL
- If the team is doing big upfront architecture rather than working out how to break features into vertical slices that add value, it’s on the EL
- If the quality of the code the team is putting out isn’t good (lots of defects, low test coverage) or UX performance is slow, it’s on the EL
- If the team doesn’t have good engineering practices (like CI & unit tests), it’s on the EL
- If the team isn’t addressing tech debt & it’s impacting their ability to deliver it’s on the EL
- Work with PM/ED/EM/Designer to create key results for squads
- Work with PM/Designer to suggest hypotheses & ways to validate them
- Work with PM/Designer to discuss approach & t shirt size of larger releases/features - look for ways to break into smaller pieces that add value & discuss risks & mitigations
- Ensure the squad understands how the sprint & the stories in it ladder up into OKRs & the company priorities
- Lead necessary tradeoff decisions with the PM, Designer, and team
- Work with PM to ensure epics & stories have a clear goal, are user focussed & have clear acceptance criteria
- Work with PM to ensure Stories are groomed & ready before IPM
- Manage technical WIP & help with/raise blockers
- Ensure engineers have clear focus
- Ensure engineers pause to ask questions as necessary
- Advise on which tech debt the team needs to address
- Guide team in balance of addressing tech debt vs new features - prioritize chores in the backlog
- Ensure high quality architecture & technical approach of features
- Guide team towards the simplest solution
- Act as tie breaker if necessary
- Ensure squad is breaking features into vertical slices that add value rather than doing big upfront architecture
- Ensure code quality, stability & UX speed as appropriate (experiments & prototypes may have different standards)
- Coach & mentor engineers in technical development & good engineering practices
- Works with EM, PM & designer to evolve Agile approach to fit team and project needs.