If you have read my recent blog posts, you have undoubtedly noticed a pattern; i.e. I talk a lot about how software development is a highly collaborative activity; and we all (should) know by now that poor communication is the major contributing factor to project failure. So... stop doing things that detract from effective communication and collaboration. Permanent or frequent telecommuting is one of those things.
I'm mostly refering to the following scenario: You are allowed to regularly telecommute but could otherwise work with your peers in a local office. I'm not referring to scenarios where occasional or permanent telecommuting is ok, such as for reasons of illness or scarcity of talent.
A few years back, I telecommuted full-time for a whole year. I was a software tester at the time, embedded in a software development team. The company was local and was a 20-minute commute for me. There were many facets that were personally beneficial to me: an ability to set a flexible schedule, to not have to drive to work, and to attend to my daughter on demand; but the reality was that the business was not benefiting. I remain convinced that it is a bad idea.
Thursday, October 23, 2008
Tuesday, October 14, 2008
Why to Work for a Large Company
A while back I posted Why to Work for a Small Company. It is only fair that I offer the other perspective. See if you can tell which one is my preference.
Generally speaking, based on my experience, work in software development for a large company if you value...
Hand-in-hand with mobility is the idea of career title advancement. Large companies have formal hierarchies, and you can climb the corporate ladder.
Pay & Benefits
Large companies almost always offer better pay and benefits than small companies. Oftentimes the attraction of a small company is rooted in non-financial benefits, and small companies are more likely to pay less and/or offer less in the form of financial benefits. For example, a small company may not provide health insurance, or may require that you pay a large percentage of the premium. A small company may not have disability insurance or life insurance, or a 401k, or an FSA.
Training
Large companies tend to offer formal training opportunities. You may be able to go to conferences, or attend classroom training or online training. Large companies may have tuition assistance programs, to pay for college degrees.
And large companies are more likely to employ experts in your field, who can teach or mentor you.
Generally speaking, based on my experience, work in software development for a large company if you value...
Reputation
There is a certain prestige that comes with working for a company whose name is recognized and respected. This could open doors to future employment, or to speaking engagements, etc.
Stability
Large companies tend to be more financially stable than small companies. If you look at statistics on business failure rates, if you work for a small company, you have about 50/50 chance of losing your job to business failure within 5 years of start-up.
Specialization
Large companies tend to silo their employees, which means you will likely work within a very narrow domain and set of responsibilities. This is a good thing if what you are after is depth of knowledge. This will allow you to focus and gain experience to a degree that you might not be able to get at a small company.
Combine depth with mobility (see next), and you have a potential recipe for deep knowledge in many domains, without having to switch companies.
Mobility
At a large company, you often have the ability to move around to different jobs, or to get assigned to projects of personal interest, without having to leave the company. At a small company, on the other hand, if you want to do something different, you might have to leave to find another job.
Large companies tend to be more financially stable than small companies. If you look at statistics on business failure rates, if you work for a small company, you have about 50/50 chance of losing your job to business failure within 5 years of start-up.
Specialization
Large companies tend to silo their employees, which means you will likely work within a very narrow domain and set of responsibilities. This is a good thing if what you are after is depth of knowledge. This will allow you to focus and gain experience to a degree that you might not be able to get at a small company.
Combine depth with mobility (see next), and you have a potential recipe for deep knowledge in many domains, without having to switch companies.
Mobility
At a large company, you often have the ability to move around to different jobs, or to get assigned to projects of personal interest, without having to leave the company. At a small company, on the other hand, if you want to do something different, you might have to leave to find another job.
Formal Advancement
Hand-in-hand with mobility is the idea of career title advancement. Large companies have formal hierarchies, and you can climb the corporate ladder.
Pay & Benefits
Large companies almost always offer better pay and benefits than small companies. Oftentimes the attraction of a small company is rooted in non-financial benefits, and small companies are more likely to pay less and/or offer less in the form of financial benefits. For example, a small company may not provide health insurance, or may require that you pay a large percentage of the premium. A small company may not have disability insurance or life insurance, or a 401k, or an FSA.
Training
Large companies tend to offer formal training opportunities. You may be able to go to conferences, or attend classroom training or online training. Large companies may have tuition assistance programs, to pay for college degrees.
And large companies are more likely to employ experts in your field, who can teach or mentor you.
Testers need to be with developers
I once believed that Testing needs to be organizationally separated from development. I once created a testing group, from the ground up. In the group's charter, I specifically called out the need for the testing group to be a separate organizational entity from development. This was important, I believed, because, among other things, it avoided conflict of interest and it better supported the testing ecosystem. I now think the separation of developers from testers is a bad idea. Testers need to be with developers.
There are three primary and fundamental reasons that software projects fail: requirements instability, lack of communication, lack of domain expertise. Ken Schwaber, who is the inventor of Scrum, puts this in terms of the significant “dimensions of complexity” to software development: requirements, people, and technology. “Anything can be complex. When complex things interact, the level of complexity goes through the roof.”
When you physically or politically separate testers from developers, you create communication and collaboration complexity whose resultant problems, in my opinion, utterly and completely dwarf any concern you might have about keeping/putting them together.
I realize that testers and developers are different, in terms of skills required to be good, tools used, etc. So I'm not saying you simply fold testing into development and be done with it. I don't in any way mean to imply that it would necessarily be easy to undo a culture that is used to the separation of developers from testers, or that combining developers with testers doesn't come with its own set of challenges.
There are three primary and fundamental reasons that software projects fail: requirements instability, lack of communication, lack of domain expertise. Ken Schwaber, who is the inventor of Scrum, puts this in terms of the significant “dimensions of complexity” to software development: requirements, people, and technology. “Anything can be complex. When complex things interact, the level of complexity goes through the roof.”
When you physically or politically separate testers from developers, you create communication and collaboration complexity whose resultant problems, in my opinion, utterly and completely dwarf any concern you might have about keeping/putting them together.
I realize that testers and developers are different, in terms of skills required to be good, tools used, etc. So I'm not saying you simply fold testing into development and be done with it. I don't in any way mean to imply that it would necessarily be easy to undo a culture that is used to the separation of developers from testers, or that combining developers with testers doesn't come with its own set of challenges.
Friday, October 10, 2008
Proposal for an Open Work Space
Software development is a collaborative undertaking. Physical work environment is an important factor. In an effort to produce a higher level of collaboration, I believe an open office environment is the best option, providing more value to the business and a higher level of employee satisfaction.
My claims are as follows: Work space design is important. Collaboration is important. Employee satisfaction is important. An appropriately designed open work space will improve collaboration and employee satisfaction. Cubicles and closed office spaces are an inhibitor to collaboration. Improved collaboration leads to improved results.
Definition of an "open work space"
An open work space is a physical work area with a defined outer boundary. The space should be dedicated to a single team. The whole team sits together in a single common room without cubicle borders and works on a closely related set of tasks. The work space design must facilitate ad hoc collaboration by providing things such as visual line of site among the team members and open meeting areas with plenty of whiteboards, etc.
Within the defined boundary, there must be spaces for privacy, such as 1 or 2 offices or meeting rooms; and it should (ideally) provide physical and visual elements that make it a desirable place to be. It should be re-configurable -- people should be able to move desks around.
Here is an example of what an open work space could look like (click the image to view larger):
As much as possible, the team should have control over the look and feel, and have the ability to reorganize their space if they so choose.
Each person in an open office environment *must* have a sense of personal space. It is not appropriate to sling a set of conference tables together and put people two feet from each other and label it an "open office" space. This is important, because so often people are turned off by open office spaces because they aren't set up correctly. We'll get into that more as this article unwinds.
Communication and collaboration problems are an inherent challenge
If you look at studies that discuss project failure -- e.g. the Standish Group's annual Chaos Report -- you can categorize failure into three main buckets: poor requirements management, poor communication and collaboration, and lack of domain expertise. We can often think of the work processes of our individual organizational teams as microcosms of the processes of a larger software project. In other words, anything an organizational team does involves elements of planning, analysis, design, execution, and validation. The same things that cause failure of the larger efforts are problematic for the day-to-day work of individual teams. Poor communication and collaboration are core problems to getting work done on any team.
Improved collaboration leads to improved results
There are essential communication aspects of successful work. Collaboration is a key factor to a highly productive and happy team. The work produced by a collaborative team is better than the sum of any work produced only by its individualistic parts.
Some popular business books have been written about the benefits of collaboration and teamwork:
Software development is (or should be) a highly collaborative activity. We see much recent evidence of the understanding of the critical importance of collaboration when we look at trends in software development process; e.g. the Agile approaches to software development. From Agile Software Development EcoSystems:
The momentum of the movement towards Agile processes signifies evidence of the importance of collaboration in software development. From the Manifesto for Agile Software Development:
The items that Agile values have an enormous amount to do with communication and collaboration. We want to eliminate those things that are barriers to collaboration. And one of those things is cubicles and closed offices.
An open work space is a better choice
A properly established open work space will improve a team's level of collaboration, which will result in more value to the business and improved employee satisfaction. From Open Plan and Enclosed Private Offices: Research Review and Recommendations:
To reinforce the idea that work space design is important:
Physical work space design is part of the overall design of a team, and evidence shows that team design is a critical factor in team performance and employee satisfaction. From How Leaders Foster Self-Managing Team Effectiveness: Design Choices Versus Hands-on Coaching:
Also, from What Makes Teams Work: Group Effectiveness Research from the Shop Floor to the Executive Suite: “Team effectiveness [is] a function of task, group, and organization design factors, environmental factors, internal processes, external processes, and group psychosocial traits.”
Keith Sawyer is an author and university professor and is considered one of the country’s leading scientific experts on creativity. He is the author of Group Genius: The Creative Power of Collaboration, which was the 2007 winner of Best Business Book on Innovation. He is a professor of education and psychology at Washington University in St. Louis. He says:
A framework for an open work space
The open work space and the team's work processes need to exist in such a way as to minimize undesirable effects, such as unwanted or irrelevant interruption. There needs to be a balance between the need for collaboration and the need for concentration. Taking a page from Agile development processes such as Scrum, to minimize unwanted interruption we need to set up a framework for the open work space that includes the following:
An open work space may arguably be more monetarily costly -- in its entirety -- than a typical cubicle environment, depending on how much space you give to each person and how much collaboration space you give to the team. In an open work space, an individual's personal work space is actually less costly than it would be in a cubicle space, because open work spaces do not require walls. A person just requires a desk, chair, computer, and some storage (desk shelf, filing cabinet).
People will also have a need for some personal privacy. Any team member can use the shared private offices when they need privacy.
It is inevitable that some people will not like an open office environment or are not going to be willing to try it. If possible, we do not want to push people into something they do not want to try; and we want to give those people the ability to opt out. People who have not worked in an effective open work space are typically going to be initially hesitant. We need to be cognizant of these facts and work to convince people to try it.
Employee satisfaction is impacted by how an open work space is designed. The work space needs to be set up in such a way that people do not perceive the space as crowded. See Research and Design Recommendations on Crowding in Open-Plan Offices.
Metrics
I claimed at the beginning of this article that an open work space would result in the team providing more "value" to the business. I purposely didn’t frame the goal in terms of productivity -- e.g. "the team will become more productive". Attempting to measure productivity is problematic, especially in the context of software development -- see how do you measure the productivity of a tester. I believe it is better to frame the goal in the more abstract and qualitative concept of "value".
It is important to note that saying "increase the value" is the same as saying "improve the quality". We could restate the claim of benefit of an open work space as "improving the quality of the team's work", and it would be saying the same thing as "increasing the value of the team". Quality and value become synonymous according to Jerry Weinberg’s definition: “Quality is value to some person.”
Side note: The phrase “quality of the team's work” refers to the quality of the product that is produced or quality of the service provided by the team – i.e. in the case of testing, it is the quality of testing, not the quality of the product being tested. This sometimes can be an important distinction.
We could think of increasing value or quality in many ways:
E.g.:
An open work space is just one part of what should be a bigger effort to maximize collaboration and create highly effective teams. For teams that are stuck in the traditional command-and-control management environment, moving to an open work environment can be a great catalyst to positive change, because it is so visible and different.
The following comment, which comes from Creative Class, is typical:
An open work space is the best choice.
My claims are as follows: Work space design is important. Collaboration is important. Employee satisfaction is important. An appropriately designed open work space will improve collaboration and employee satisfaction. Cubicles and closed office spaces are an inhibitor to collaboration. Improved collaboration leads to improved results.
Definition of an "open work space"
An open work space is a physical work area with a defined outer boundary. The space should be dedicated to a single team. The whole team sits together in a single common room without cubicle borders and works on a closely related set of tasks. The work space design must facilitate ad hoc collaboration by providing things such as visual line of site among the team members and open meeting areas with plenty of whiteboards, etc.
Within the defined boundary, there must be spaces for privacy, such as 1 or 2 offices or meeting rooms; and it should (ideally) provide physical and visual elements that make it a desirable place to be. It should be re-configurable -- people should be able to move desks around.
Here is an example of what an open work space could look like (click the image to view larger):
As much as possible, the team should have control over the look and feel, and have the ability to reorganize their space if they so choose.
Each person in an open office environment *must* have a sense of personal space. It is not appropriate to sling a set of conference tables together and put people two feet from each other and label it an "open office" space. This is important, because so often people are turned off by open office spaces because they aren't set up correctly. We'll get into that more as this article unwinds.
Communication and collaboration problems are an inherent challenge
If you look at studies that discuss project failure -- e.g. the Standish Group's annual Chaos Report -- you can categorize failure into three main buckets: poor requirements management, poor communication and collaboration, and lack of domain expertise. We can often think of the work processes of our individual organizational teams as microcosms of the processes of a larger software project. In other words, anything an organizational team does involves elements of planning, analysis, design, execution, and validation. The same things that cause failure of the larger efforts are problematic for the day-to-day work of individual teams. Poor communication and collaboration are core problems to getting work done on any team.
Improved collaboration leads to improved results
There are essential communication aspects of successful work. Collaboration is a key factor to a highly productive and happy team. The work produced by a collaborative team is better than the sum of any work produced only by its individualistic parts.
Some popular business books have been written about the benefits of collaboration and teamwork:
- The Wisdom of Crowds
- The Wisdom of Teams: Creating the High-Performance Organization
- Group Genius: The Creative Power of Collaboration
Students learn best when they are actively involved in the process. Researchers report that, regardless of the subject matter, students working in small groups tend to learn more of what is taught and retain it longer than when the same content is presented in other instructional formats. Students who work in collaborative groups also appear more satisfied with their classes.
Software development is (or should be) a highly collaborative activity. We see much recent evidence of the understanding of the critical importance of collaboration when we look at trends in software development process; e.g. the Agile approaches to software development. From Agile Software Development EcoSystems:
ASDEs focus on people -- both in terms of individual skills and in terms of collaboration, conversations, and communications that enhance flexibility and innovation. As Alistair says, “Software development is a cooperative game.” Most traditional “methodologies” place 80 percent of their emphasis on processes, activities, tools, roles, and documents. Agile approaches place 80 percent of their emphasis on ecosystems -- people, personalities, collaboration, conversations, and relationships.
The momentum of the movement towards Agile processes signifies evidence of the importance of collaboration in software development. From the Manifesto for Agile Software Development:
...we have come to value:
Individuals and interactions over processes and tools
Working software over comprehensive documentation
Customer collaboration over contract negotiation
Responding to change over following a plan
That is, while there is value in the items on the right, we value the items on the left more.
The items that Agile values have an enormous amount to do with communication and collaboration. We want to eliminate those things that are barriers to collaboration. And one of those things is cubicles and closed offices.
An open work space is a better choice
A properly established open work space will improve a team's level of collaboration, which will result in more value to the business and improved employee satisfaction. From Open Plan and Enclosed Private Offices: Research Review and Recommendations:
A seminal three-year research project conducted by UCLA revealed that companies who had modified their business processes to encourage collaboration and supported new work processes by moving from private spaces to open, collaborative environments realized performance increases (speed and accuracy of work) averaging 440 percent (Majchrzak and Qianwei, 1996). Research examining human resources, procurement, finance and other functional areas (O’Neill, 2007; Majchrzak et al., 2004) confirms the notion that workspace designed to foster group work has a positive impact on business process time and cost. O’Neill (2007) found a 5.5% reduction in business process time and cost for employees who moved from traditional enclosed office space into a mix of non-assigned and assigned open plan furnishingsAnd
Vietch, et. al. (2007) studied 779 open-plan office occupants from nine government and private sector office buildings in five large Canadian and US cities. They found that open-plan office occupants who were more satisfied with their environments were also more satisfied with their jobs, suggesting a role for the physical environment in organizational well-being and effectiveness.
To reinforce the idea that work space design is important:
- Good work environment improves satisfaction, productivity
- Workplace design can improve productivity
- Work environment effects on labor productivity: An intervention study in a storage building
Physical work space design is part of the overall design of a team, and evidence shows that team design is a critical factor in team performance and employee satisfaction. From How Leaders Foster Self-Managing Team Effectiveness: Design Choices Versus Hands-on Coaching:
Findings show that how leaders design their teams and the quality of their hands-on coaching both influence team self-management, the quality of member relationships, and member satisfaction, but only leaders' design activities affect team task performance.... The difficulties of fostering self-management teams -- particularly in organizations with histories of individualistic, manager-directed work -- have been...attributed to deficits in the...ability of managers to create the conditions that foster self-management....
Also, from What Makes Teams Work: Group Effectiveness Research from the Shop Floor to the Executive Suite: “Team effectiveness [is] a function of task, group, and organization design factors, environmental factors, internal processes, external processes, and group psychosocial traits.”
Keith Sawyer is an author and university professor and is considered one of the country’s leading scientific experts on creativity. He is the author of Group Genius: The Creative Power of Collaboration, which was the 2007 winner of Best Business Book on Innovation. He is a professor of education and psychology at Washington University in St. Louis. He says:
What kinds of offices foster creativity and collaboration? They are offices that support flexible work arrangements and frequent spontaneous reconfigurations, of people, furniture, walls, and cubicles. In innovative organizations, you find a blend of solo work, work in pairs, and collaborative teams. But most of today’s offices are designed to support only one kind of work: solitary work, alone in an office (or a cubicle). In innovative organizations, people are always moving around, bumping unexpectedly into others, and stopping for a few minutes to chat.And...
...for a group’s genius to be fully realized, several things have to happen. First, the members of the group have to share a common body of knowledge -- and on top of that, they each have to know some uniquely different information. Second, they have to trust in each other. But trust doesn’t mean everyone always agrees; it allows them to challenge other’s ideas, and to propose crazy ideas of their own. Third, they need to interact with each other, in a special kind of open, improvisational conversation [my emphasis] -- where something unexpected can emerge. The best genius groups are like improvisational jazz ensembles. The outcome is unpredictable, and it depends on a complex sequence of small actions and interactions.
A framework for an open work space
The open work space and the team's work processes need to exist in such a way as to minimize undesirable effects, such as unwanted or irrelevant interruption. There needs to be a balance between the need for collaboration and the need for concentration. Taking a page from Agile development processes such as Scrum, to minimize unwanted interruption we need to set up a framework for the open work space that includes the following:
- The team's physical work space should have a physical boundary, such as walls or an entire room, to shield the team from external distraction.
- The team needs to be working on a shared set of tasks -- i.e. it should not be treated as a resource pool for a larger organization.
- The team's work should be time-boxed (2-4 weeks), allowing the team to focus for a period of time on a set of tasks without change of course from external forces.
- The team should hold daily stand-up meetings to discuss work status, which establishes daily focus and reduces unwanted ad hoc coordination.
- The team's work space should include one or two shared private offices, which can be used by team members when needed, for individualized focused work.
An open work space may arguably be more monetarily costly -- in its entirety -- than a typical cubicle environment, depending on how much space you give to each person and how much collaboration space you give to the team. In an open work space, an individual's personal work space is actually less costly than it would be in a cubicle space, because open work spaces do not require walls. A person just requires a desk, chair, computer, and some storage (desk shelf, filing cabinet).
People will also have a need for some personal privacy. Any team member can use the shared private offices when they need privacy.
It is inevitable that some people will not like an open office environment or are not going to be willing to try it. If possible, we do not want to push people into something they do not want to try; and we want to give those people the ability to opt out. People who have not worked in an effective open work space are typically going to be initially hesitant. We need to be cognizant of these facts and work to convince people to try it.
Employee satisfaction is impacted by how an open work space is designed. The work space needs to be set up in such a way that people do not perceive the space as crowded. See Research and Design Recommendations on Crowding in Open-Plan Offices.
Metrics
I claimed at the beginning of this article that an open work space would result in the team providing more "value" to the business. I purposely didn’t frame the goal in terms of productivity -- e.g. "the team will become more productive". Attempting to measure productivity is problematic, especially in the context of software development -- see how do you measure the productivity of a tester. I believe it is better to frame the goal in the more abstract and qualitative concept of "value".
It is important to note that saying "increase the value" is the same as saying "improve the quality". We could restate the claim of benefit of an open work space as "improving the quality of the team's work", and it would be saying the same thing as "increasing the value of the team". Quality and value become synonymous according to Jerry Weinberg’s definition: “Quality is value to some person.”
Side note: The phrase “quality of the team's work” refers to the quality of the product that is produced or quality of the service provided by the team – i.e. in the case of testing, it is the quality of testing, not the quality of the product being tested. This sometimes can be an important distinction.
We could think of increasing value or quality in many ways:
- Increase the volume of work with the same number of people
- Get the same amount done with less people
- Get work done quicker
- Become more effective (better tests, more coverage, reduced test errors)
- Increase the variety of work that the team can handle
- Find more bugs
- Let less bugs escape to the customer
- Get the team more knowledgeable, and thus more valuable
- Etc
E.g.:
- How would you rate the value of the team? 1 2 3 4 5 6 7 8 9 10
- Please comment on your rating.
- How would you rate your level of satisfaction with your work space? 1 2 3 4 5 6 7 8 9 10
- Please comment on your rating.
An open work space is just one part of what should be a bigger effort to maximize collaboration and create highly effective teams. For teams that are stuck in the traditional command-and-control management environment, moving to an open work environment can be a great catalyst to positive change, because it is so visible and different.
The following comment, which comes from Creative Class, is typical:
[Our] space is almost completely open plan. We designed it with a library/ lounge filled with books and sofas and tables; a big room for seminars that seats 15-60; a conference room that seats 12-16; a bullpen for group work; and a cafe for socializing. We included 3 private offices; and were told that was too few. Let me tell you. Our big room has turned into an incredible project space. The offices are doubled up in. Our library/lounge has become a seminar room, we had a class of 20 or so there today. If we had to do it again, we’d probably give up all 3 offices. I spend precious little time in mine. We’d take as much reconfigureable group space as we could get out hands on. Yet we are by far the exception in an academic environment, which is built around private offices for professors, classrooms, and cube farms for research assistants. I may well be the first professor in my unit to give up a private office.
An open work space is the best choice.
Thursday, August 28, 2008
Why to Work for a Small Company
I've worked for very small companies (less than 50, privately held) and for very large companies (50k+ Fortune 500), for significant periods of time and in a variety of software development roles.
Small organizations tend to take on the personality of their leaders, so if you find a small company whose leaders share your personal values (E.g. honesty, integrity, sense of humor, etc), the vast majority of the employee population is likely to also share those values; and this makes for a very nice fit and a familial atmosphere. It's hard to find this type of atmosphere at a large company.
Variety
At a small company, it is likely that you will become a generalizing specialist. In other words, according to Scott Ambler: "Multi-disciplinary developers, cross-functional developers, deep generalists, polymaths, versatilists." This will be true with respect to the technology and tools, the people you interact with, the domains you work in, and the roles you play.
At a large company, as a software developer, you are more likely to have a singular purpose (e.g. DBA, Performance Tester, Project Manager, etc.), where you can acquire a depth of knowledge within your narrow domain. If depth is what you are after, a small company might not be the best option.
At a small company, you will have a responsibility to influence what the company does as a whole. You will have direct access to the owners and other decision makers. You may have direct access to the customers as well, and an ability to make decisions on your own based on what customers are asking of you.
Below I've laid out several reasons in favor of working in software development for a small company. I'm not saying that these things are guaranteed, but I am saying they are out there and you can find them; and you are more likely to find them at a small company. Caveat emptor.
I also have a post on Why To Work for a Large Company.
Generally speaking, based on my experience, work for a small company if you value...
Risk Taking
If you are going to work for a small company, you should be somewhere on the spectrum between risk tolerant and risk-loving. Here are some risks: the company could fail for reasons beyond your control, the owners and/or co-workers could be difficult to work with, decisions that you make could negatively affect the company, everyone knows when you fail.
If you are going to work for a small company, you should be somewhere on the spectrum between risk tolerant and risk-loving. Here are some risks: the company could fail for reasons beyond your control, the owners and/or co-workers could be difficult to work with, decisions that you make could negatively affect the company, everyone knows when you fail.
But for every risk, there is a potential reward. That's part of the thrill and payoff of working at a small company -- the entrepreneurial spirit -- taking risk and reaping the reward. Yes, everyone knows when you fail; but everyone also knows when you succeed. And your personal successes can have a highly visible and significant positive impact on the success of the company, the success of the people your company serves, and your own sense of self-fulfillment.
Connectedness
You should work for a small company if you enjoy the feeling you get when you can easily relate what you work on to the success of the company or the impact it has on the success of the company's clients or end users. I.e. You have a strong desire to feel like you are making a difference and helping others to succeed. When you are at a large company, that connectedness is often missing.
Like-Minded People
People who work for small companies are more likely to have values that align with yours and that are on this list. I.e. Risk-takers, entrepreneurs, optimists, do-ers, etc.
Less Incompetence
At a small company, you cannot hide. Everyone knows when you fail and everyone knows when you succeed; and the company cannot afford incompetence. Because of this, incompetence gets weeded out.
Familial Culture
Small organizations tend to take on the personality of their leaders, so if you find a small company whose leaders share your personal values (E.g. honesty, integrity, sense of humor, etc), the vast majority of the employee population is likely to also share those values; and this makes for a very nice fit and a familial atmosphere. It's hard to find this type of atmosphere at a large company.
Variety
At a small company, it is likely that you will become a generalizing specialist. In other words, according to Scott Ambler: "Multi-disciplinary developers, cross-functional developers, deep generalists, polymaths, versatilists." This will be true with respect to the technology and tools, the people you interact with, the domains you work in, and the roles you play.
At a large company, as a software developer, you are more likely to have a singular purpose (e.g. DBA, Performance Tester, Project Manager, etc.), where you can acquire a depth of knowledge within your narrow domain. If depth is what you are after, a small company might not be the best option.
Personal Marketability
My experience has been that breadth makes you more marketable -- it gives you more career options. Exposure to a variety of things also helps you to discover areas of personal career interest that you might otherwise have never discovered. Small companies help people to attain a more well-rounded skill-set.
My experience has been that breadth makes you more marketable -- it gives you more career options. Exposure to a variety of things also helps you to discover areas of personal career interest that you might otherwise have never discovered. Small companies help people to attain a more well-rounded skill-set.
Of course, breadth has a dark side: "jack of all trades, master of none". If you have to make a transition to a specialty, you will be behind others who already have that depth; but it has been my experience that, for career advancement and security, breadth is better than depth. There are exceptions, of course.
No Nonsense
Small companies tend to be very lean. Process and bureaucracy are overhead, and small companies don't want it and/or can't afford it.
Small companies do not suffer from the complexities of communication like large organizations do; and thus they do not tend to put in place restrictive, bureaucratic, and frustrating processes. Small companies tend to be agile by default.
Small companies tend to be very lean. Process and bureaucracy are overhead, and small companies don't want it and/or can't afford it.
Small companies do not suffer from the complexities of communication like large organizations do; and thus they do not tend to put in place restrictive, bureaucratic, and frustrating processes. Small companies tend to be agile by default.
For more on this, read up on Diseconomy of Scale.
Fast Pace
No nonsense translates into a fast pace. You don't rest on your laurels. You may work a lot of overtime. The cadence is just plain fast most of the time. You probably won't be bored. If you like to be busy, you will like working at a small company.
Flexibility
At a small company, there tends to be more flexibility in your terms of employment. Many aspects of your terms of employment may be negotiable, such as vacation, work schedule, etc.
Small companies tend to be more laid back about certain things, such as dress code and your personal work space. Jeans and t-shirt may be every-day attire. Perhaps shorts and sandals in the summer. Arrange your desk the way you want it. Put software on your computer without having to get permission. Listen to music. Take a mental break and play a game. Bring your dog to work.
Responsibility
Empowerment at a small company can vary greatly according to the policies and whims of the owner. It has been my experience that there is more empowerment at a small company. If you think about it, based on what I've previously said, this makes sense. There is less incompetence, which leads to more trust, which leads to empowerment. There is less overhead, which translates into less micro-managing, which leads to empowerment.
Small companies tend to be more laid back about certain things, such as dress code and your personal work space. Jeans and t-shirt may be every-day attire. Perhaps shorts and sandals in the summer. Arrange your desk the way you want it. Put software on your computer without having to get permission. Listen to music. Take a mental break and play a game. Bring your dog to work.
Responsibility
Empowerment at a small company can vary greatly according to the policies and whims of the owner. It has been my experience that there is more empowerment at a small company. If you think about it, based on what I've previously said, this makes sense. There is less incompetence, which leads to more trust, which leads to empowerment. There is less overhead, which translates into less micro-managing, which leads to empowerment.
At a small company, you will have a responsibility to influence what the company does as a whole. You will have direct access to the owners and other decision makers. You may have direct access to the customers as well, and an ability to make decisions on your own based on what customers are asking of you.
Tuesday, August 19, 2008
Applying Agile Techniques to an Individual Workgroup
Generally speaking, I believe Agile frameworks define the best practices for managing complex software projects; and I believe you can say that these same practices can be applied to any set of work items that are to be executed by any organizational team. I want to take some of the foundation and theory that Agile is built upon and apply those principles to general team management.
A "project" can be abstractly defined as "A planned endeavor, usually with a specific goal and accomplished in several steps or stages" (from wiktionary). An individual organizational team that is supposed to be collaborative, then, to execute its set of work items, can think of its work items according to that definition; and the practices from Agile that are applied to the larger concept of "software project" can be applied to an individual team's work items.
It will be easier for me to express what I want to do using the terminology of a specific framework, and for that I choose Scrum.
Let's start by looking at the top reasons for project failure:
- Poor requirements management
- Insufficient communication and collaboration
- Lack of domain expertise
Now let's restate these items in a way that makes more sense in the context of any cohesive managed work (i.e. stuff done by a team):
- Poor definition and management of the expected work
- Low level of team collaboration, customer involvement, and management involvement
- Lack of knowledge by staff, of product and tools
These are the problems we want to try to solve. Knowing what problems we want to try to solve, let's take a look at some of the specific concepts within Scrum and see how we can apply them to any individual workgroup/team:
1. Open work environment
Improve collaboration by removing physical barriers to communication, such as cubicles.
2. Product backlog
More generally, let's call this a "prioritized work queue". A team should have an explicit list of things it is expected to work on.
3. Sprints
A "Sprint" is a time-box for executing a set of work. Get the team to focus on a set of items from their work queue by time-boxing their work. Provide up-front planning for each Sprint to define what is to be done in more detail, and provide post-Sprint retrospectives as feedback into the process.
4. Daily stand-ups
Keep the work transparent. Hold a 15-minute meeting each morning, where each team member answers three questions: 1) What did I accomplish yesterday; 2) What am I going to accomplish today; and 3) What obstacles are in my way?
5. Scrummaster
A Scrummaster is a person who shephards the team through the execution of a Sprint. They run the Sprint planning and restrospective meetings, they run the daily stand-up meetings, they remove obstacles, etc.
It's not that hard to see that you can take concepts from Agile and apply them to any team in an effort to increase the value of the team's work.
A "project" can be abstractly defined as "A planned endeavor, usually with a specific goal and accomplished in several steps or stages" (from wiktionary). An individual organizational team that is supposed to be collaborative, then, to execute its set of work items, can think of its work items according to that definition; and the practices from Agile that are applied to the larger concept of "software project" can be applied to an individual team's work items.
It will be easier for me to express what I want to do using the terminology of a specific framework, and for that I choose Scrum.
Let's start by looking at the top reasons for project failure:
- Poor requirements management
- Insufficient communication and collaboration
- Lack of domain expertise
Now let's restate these items in a way that makes more sense in the context of any cohesive managed work (i.e. stuff done by a team):
- Poor definition and management of the expected work
- Low level of team collaboration, customer involvement, and management involvement
- Lack of knowledge by staff, of product and tools
These are the problems we want to try to solve. Knowing what problems we want to try to solve, let's take a look at some of the specific concepts within Scrum and see how we can apply them to any individual workgroup/team:
1. Open work environment
Improve collaboration by removing physical barriers to communication, such as cubicles.
2. Product backlog
More generally, let's call this a "prioritized work queue". A team should have an explicit list of things it is expected to work on.
3. Sprints
A "Sprint" is a time-box for executing a set of work. Get the team to focus on a set of items from their work queue by time-boxing their work. Provide up-front planning for each Sprint to define what is to be done in more detail, and provide post-Sprint retrospectives as feedback into the process.
4. Daily stand-ups
Keep the work transparent. Hold a 15-minute meeting each morning, where each team member answers three questions: 1) What did I accomplish yesterday; 2) What am I going to accomplish today; and 3) What obstacles are in my way?
5. Scrummaster
A Scrummaster is a person who shephards the team through the execution of a Sprint. They run the Sprint planning and restrospective meetings, they run the daily stand-up meetings, they remove obstacles, etc.
It's not that hard to see that you can take concepts from Agile and apply them to any team in an effort to increase the value of the team's work.
Monday, August 18, 2008
Elizabeth Hendrickson on Agile Testing
Elizabeth Hendrickson gives an interesting talk on Agile Testing:
Ken Schwaber on Scrum
Ken Schwaber gives a nice talk at Google about Scrum:
Tuesday, June 17, 2008
The Value of Human Capital
Michael Bolton has a great quote about the value of human capital, from an interview he gave at whatistesting:
...I frankly don't think businesses are very good at measuring or even considering cost and value if there's not a direct cash figure that can be calculated easily. Outsourcing is a great example: outsourcing is usually less expensive if you look only at the cost of labour. However, many companies today have no assets to speak of, other than intellectual ones--the real assets are in the minds and experience of their staff. Economics suggests that we can't put an accurate value on intellectual capital; there aren't good ways to measure its worth. That's not the same thing as intellectual capital having no value, but without a yardstick, nobody bothers measuring, and the value implicitly gets set to zero. And yet it seems pretty clear to me that software companies that don't place value on knowledge, or that don't treat their people well are vulnerable to losing their most valuable assets. Companies that work hard to retain their employees, to keep their minds engaged, to keep their skills sharp, and to keep knowledge in-house will do correspondingly better.Attempt to understand value before you make a decision based on cost.
Subscribe to:
Posts (Atom)