“an engineer would switch teams about every 9 to 12 months.”

· Location 934-934

when a single team owns the system or subsystem, and the team has the autonomy to plan their own work, then that team can make sensible decisions about short-term fixes with the knowledge that they will be removing any dirty fixes in the next few weeks.

· Location 954-956

Every part of the software system needs to be owned by exactly one team. This means there should be no shared ownership of components, libraries, or code.

· Location 957-958

Outside teams may submit pull requests or suggestions for change to the owning team, but they cannot make changes themselves. The

· Location 959-960

Outside teams may submit pull requests or suggestions for change to the owning team, but they cannot make changes themselves.

· Location 959-960

Note that team ownership of code should not be a territorial thing. The team takes responsibility for the code and cares for it, but individual team members should not feel like the code is theirs to the exclusion of others. Instead, teams should view themselves as stewards or caretakers as opposed to private owners. Think of code as gardening, not policing.

· Location 961-963

For teams to work, team members should put the needs of the team above their own. They should:

· Location 967-968

For teams to work, team members should put the needs of the team above their own. They should: Arrive for stand-ups and meetings on time. Keep discussions and investigations on track. Encourage a focus on team goals. Help unblock other team members before starting on new work. Mentor new or less experienced team members. Avoid “winning” arguments and, instead, agree to explore options.

· Location 967-972

However, even with coaching, some people are unsuitable to work on teams or are unwilling to put team needs above their own. Such people can destroy teamwork and, in extreme cases, destroy teams. These people are “team toxic” and need to be removed before damage is done.

· Location 973-975

Looking to reward individual performance in modern organizations tends to drive poor results and damages staff behavior.

· Location 990-991

With a team-first approach, the whole team is rewarded for their combined effort.

· Location 994-995

the team needs the space to continuously try to reduce the amount of intrinsic and extraneous load they currently have to deal with (via training, practice, automation, and any other useful techniques).

· Location 1042-1043

“Do you feel like you’re effective and able to respond in a timely fashion to the work you are asked to do?”

· Location 1045-1046

organization needs to take the necessary steps to reduce cognitive load, thus ensuring that the team is able to be effective and proactive again. Incidentally, this will increase motivational levels within the team as members see more value and purpose in their work.

· Location 1048-1049

The team was constantly faced with too much work and context switching prevailed, with tasks coming in from different product areas simultaneously.

· Location 1061-1062

there is a risk here of diminishing team members’ motivation due to the more routine nature of their work.

· Location 1088-1089

“Minimize cognitive load for others” is one of the most useful heuristics for good software development.

· Location 1144-1144

For effective team-first ownership of software, teams need to continuously define, advertise, test, and evolve their team API to ensure that it is fit for purpose for the consumers of that API: other teams.

· Location 1163-1164

People who work all day with headphones on are seen as anti-social, and their behavior does not promote interaction and collaboration; but it could well be that the office environment is generally noisy and these people require a quiet environment to be effective.

· Location 1192-1194

Office design for effective software delivery should accommodate all of the following modes of work: focused individual work, collaborative intra-team work, and collaborative inter-team work.

· Location 1201-1202