β
I'm not a great programmer; I'm just a good programmer with great habits.
β
β
Kent Beck
β
Do The Simplest Thing That Could Possibly Work
β
β
Kent Beck
β
Responsibility cannot be assigned; it can only be accepted. If someone tries to give you responsibility, only you can decide if you are responsible or if you aren't.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Write tests until fear is transformed into boredom
β
β
Kent Beck (Test-Driven Development: By Example)
β
Brilliance in a scientist does not consist in being right more often but in being wrong about more interesting topics.
β
β
Kent Beck
β
Saying that programmers should just accomplish twice as much doesn't work. They can gain skills and effectiveness, but they cannot get more done on demand. More time at the desk does not equal increased productivity for creative work.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
the XP strategy is "design always.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
The XP philosophy is to start where you are now and move towards the ideal. From where you are now, could you improve a little bit?
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
A statement Kent Beck often makes about himself, "I'm not a great programmer; I'm just a good programmer with great habits.
β
β
Martin Fowler (Refactoring: Improving the Design of Existing Code)
β
Given the choice between an extremely skilled loner and a competent-but-social programmer, XP teams consistently choose the more social candidate. The best interviewing technique is to have the candidate work with the team for a day. Pair programming provides an excellent test of technical and social skills.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
It reminds me of a statement Kent Beck often makes about himself: βIβm not a great programmer; Iβm just a good programmer with great habits.β Refactoring helps me be much more effective at writing robust code.
β
β
Martin Fowler (Refactoring: Improving the Design of Existing Code (Addison-Wesley Signature Series (Fowler)))
β
I've sat through far too many "crying in the beer" sessions where all the energy for change was dissipated in the intensity of the complaining. Once you see an idea for improvement that makes sense to you, do it.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
In software development, βperfectβ is a verb, not an adjective. There is no perfect process. There is no perfect design. There are no perfect stories. You can, however, perfect your process, your design, and your stories.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
If you're happy slamming some code together that more or less works and you're happy never looking at the result again, TDD is not for you. TDD rests on a charmingly naΓ―ve geekoid assumption that if you write better code, you'll be more successful. TDD helps you to pay attention to the right issues at the right time so you can make your designs cleaner, you can refine your designs as you learn.
β
β
Kent Beck (Test-Driven Development: By Example)
β
McConnell writes, "In ten years the pendulum has swung from 'design everything' to 'design nothing.' But the alternative to BDUF [Big Design Up Front] isn't no design up front, it's a Little Design Up Front (LDUF) or Enough Design Up Front (ENUF)." This is a strawman argument. The alternative to designing before implementing is designing after implementing.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Beta testing is a symptom of weak testing practices and poor communication with customers.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Without planning, we are individuals with haphazard connections and effectiveness. We are a team when we plan and work in harmony.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Rather than apply minutes of suspect reasoning, we can just ask the computer by making the change and running the tests.
β
β
Kent Beck (Test-Driven Development: By Example)
β
No matter the circumstance you can always improve. You can always start improving with yourself. You can always start improving today.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
Software development is a game of insight, and insight comes to the prepared, rested, relaxed mind.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
If there are forms of testing, like stress and load testing, that find defects after development is "complete," bring them into the development cycle. Run load and stress tests continuously and automatically.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Pair programmers: Keep each other on task. Brainstorm refinements to the system. Clarify ideas. Take initiative when their partner is stuck, thus lowering frustration. Hold each other accountable to the team's practices. Pairing
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Sit Together Develop in an open space big enough for the whole team. Meet the need for privacy and "owned" space by having small private spaces nearby or by limiting work hours so team members can get their privacy needs met elsewhere.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Code should be obvious: When someone needs to make a change, they should be able to find the code to be changed easily and to make the change quickly without introducing any errors. A healthy code base maximizes our productivity, allowing us to build more features for our users both faster and more cheaply. To keep code healthy, pay attention to what is getting between the programming team and that ideal, then refactor to get closer to the ideal. But the most important thing to learn from this example is the rhythm of refactoring. Whenever Iβve shown people how I refactor, they are surprised by how small my steps are, each step leaving the code in a working state that compiles and passes its tests. I was just as surprised myself when Kent Beck showed me how to do this in a hotel room in Detroit two decades ago. The key to effective refactoring is recognizing that you go faster when you take tiny steps, the code is never broken, and you can compose those small steps into substantial changes. Remember thatβand the rest is silence.
β
β
Martin Fowler (Refactoring: Improving the Design of Existing Code (Addison-Wesley Signature Series (Fowler)))
β
If you have a month to plan a project in detail, spend it on four one-week iterations developing while you improve your estimates. If you have a week to plan a project, hold five one-day iterations. Feedback cycles give you information and the experience to make accurate estimates.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
I didnβt know then that Carol DaRonch, Jean Graham, and Debby Kentβs girlfriend, Jolynne Beck, who had seen the man in the auditorium on November 8, had all picked Ted out of the Utah lineup on October 2. Ted had been one suspect, standing in a seven-man lineup, surrounded by detectives, all of them a little older, a little heavier than he was.
β
β
Ann Rule (The Stranger Beside Me)
β
Change always starts at home. The only person you can actually change is yourself. No matter how functional or dysfunctional your organization, you can begin applying XP for yourself. Anyone on the team can begin changing his own behavior. Programmers can start writing tests first. Testers can automate their tests. Customers can write stories and set clear priorities. Executives can expect transparency. Dictating practices to a team destroys trust and creates resentment. Executives can encourage team responsibility and accountability. Whether the team produces these with XP, a better waterfall, or utter chaos is up to them. Using XP, teams can produce dramatic improvements in the areas of defects, estimation, and productivity.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
However, those whose souls are healed by the balm of elegance can find in TDD a way to do well by doing good. TDD is also good for geeks who form emotional attachments to code. One of the great frustrations of my young engineer's life was starting a project with great excitement, then watching the code base decay over time. A year later I wanted nothing more than to dump the now-smelly code and get on to the next project. TDD enables you to gain confidence in the code over time. As tests accumulate (and your testing improves), you gain confidence in the behavior of the system. As you refine the design, more and more changes become possible. My goal is to feel better about a project after a year than I did in the starry-eyed beginning, and TDD helps me achieve this.
β
β
Kent Beck (Test-Driven Development: By Example)
β
Without the adjustment, you are working under a lie. Everyone knows it and has to hide to protect themselves. This is no way to get good software done and deployed;
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Some of the teams who read and applied the first edition of this book didn't get the part of the message about the last responsible moment. They piled story on story as quickly as possible with the least possible investment in design. Without daily attention to design, the cost of changes does skyrocket. The result is poorly designed, brittle, hard-to-change systems.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
If I have the same logic in two places, I work with the design to understand how I can have only one copy. Designs without duplication tend to be easy to change.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Trust energizes participants. We feel good when things work smoothly. We need to be safe to experiment and make mistakes. We need testing to bring accountability to our experimentation so that we can be sure we are doing no harm.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
The constraint has shifted out of software development. Here's a sad but repeated story: a development team begins applying XP, dramatically improves quality and productivity, but then is disbanded, its leaders fired and the rest of the team scattered.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
The majority of the cost of software is incurred after the software has been first deployed. Thinking about my experience of modifying
code, I see that I spend much more time reading the existing code than I do writing new code. If I want to make my code cheap, therefore, I should make it easy to read.
β
β
Kent Beck (Implementation Patterns)
β
Exceptions occur at different levels of abstraction. Catching and reporting a low-level exception can be confusing to someone who is not expecting it. When a web server shows me an error page with stack trace headed by a NullPointerException, Iβm not sure what Iβm supposed to do with the information. Iβd rather see a message that said, βThe programmer did not consider the scenario you have just presented.β I wouldnβt mind if the page also provided a pointer to further information that I could send to a programmer so he could diagnose the problem, but presenting me with untranslated details isnβt helpful.
β
β
Kent Beck (Implementation Patterns)
β
If you want people to take your advice, you need to solve more problems than you create.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Listening , Testing , Coding , Designing. That's all there is to software. Anyone who tells you different is selling something .
β
β
Kent Beck
β
First you learn the value of abstraction, then you learn the cost of abstraction, then you're ready to engineer
β
β
Kent Beck
β
I donβt write to make money; I make money with writing so I can afford to write.
β
β
Kent Beck (Tidy First?: A Personal Exercise in Empirical Software Design)
β
Optimism is an occupational hazard of programming; feedback is the treatment." - Kent Beck
β
β
Anonymous
β
Cards on a wall is a way of practicing transparency, valuing and respecting the input of each team member. The project manager has the task of translating the cards into whatever format is expected by the rest of the organization.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
However, most defects end up costing more than it would have cost to prevent them. Defects are expensive when they occur, both the direct costs of fixing the defects and the indirect costs because of damaged relationships, lost business, and lost development time.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Folk wisdom in software development teaches that interfaces shouldn't be unduly influenced by implementations. Writing a test first is a concrete way to achieve this separation.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
A team using the information provided by pay-per-use should be able to do a more effective job than a team relying for feedback only on license revenues.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Customers may have a good idea of the general behavior they want to see, but testers are good at looking at "happy paths" and asking what should happen if something goes wrong. "Okay, but what if login fails three times? What should happen then?" In this role testers amplify communication.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
To achieve this his team had a sophisticated stress testing environment. When they wanted to improve the architecture they would first improve the stress tests until the system broke. Then they would improve the architecture just enough to run the tests. I suggested this strategy to an architect at another company. He complained of spending all of his time writing specifications and then explaining them to developers.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
First a small team writes a small system. Then they find the natural fracture lines and divide the system into relatively independent parts for expansion. The architects help choose the most appropriate fracture lines and then follow the system as a whole, keeping the big picture in mind as the groups focus on their smaller section.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Change is not necessarily slow. A team eager or desperate for improvement can progress quickly. It doesn't need to wait long to assimilate one change before moving on to the next practice. If you change too fast, though, you risk slipping back into old practices and values. When this happens, take time to regroup. Remind yourself of the values you want to hold. Review your practices and remind yourself why you chose them. New habits take time to solidify.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Don't make more versions of your source code. Rather than add more code bases, fix the underlying design problem that is preventing you from running from a single code base.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Write contracts for software development that fix time, costs, and quality but call for an ongoing negotiation of the precise scope of the system. Reduce risk by signing a sequence of short contracts instead of one long one.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Inaccurate estimates are a failure of information, not of values or principles. If the numbers are wrong, fix the numbers and communicate the consequences.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Simon Baron-Cohen, The Science of Evil; Judith Beck, Cognitive Behavior Therapy; Louis Cozolino, The Making of a Therapist; Kevin Dutton, The Wisdom of Psychopaths; James Fallon, The Psychopath Inside; Peter and Ginger Ross Breggin, Talking Back to Prozac; Robert D. Hare, Without Conscience; Kent Kiehl, The Psychopath Whisperer; Jane McGregor and Tim McGregor, The Sociopath at the Breakfast Table; J. Reid Meloy, The Psychopathic Mind; Dinah Miller, Annette Hanson, and Steven Roy Daviss, Shrink Rap; Daniel Smith, Monkey Mind; Scott Stossel, My Age of Anxiety; Martha Stout, The Sociopath Next Door; M. E. Thomas, Confessions of a Sociopath; and Robert Whitaker, Mad in America.
β
β
Lisa Scottoline (Every Fifteen Minutes)
β
There is only one code stream. You can develop in a temporary branch, but never let it live longer than a few hours. Multiple code streams are an enormous source of waste in software development. I fix a defect in the currently deployed software. Then I have to retrofit the fix to all the other deployed versions and the active development branch. Then you find that my fix broke something you were working on and you interrupt me to fix my fix. And on and on. There are legitimate reasons for having multiple versions of the source code active at one time. Sometimes, though, all that is at work is simple expedience, a micro-optimization taken without a view to the macro-consequences. If you have multiple code bases, put a plan in place for reducing them gradually. You can improve the build system to create several products from a single code base. You can move the variation into configuration files. Whatever you have to do, improve your process until you no longer need multiple versions of the code.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Used Pluggable Adaptor, which we promise not to use again for four months, minimum, because it makes code hard to statically analyze.
β
β
Kent Beck (Test-Driven Development: By Example)
β
By far the dominant reason for not releasing sooner was a reluctance to trade the dream of success for the reality of feedback.
β
β
Kent Beck
β
... no matter what the client says the problem is, it is always a people problem.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
Simplicity only makes sense in context. If Iβm writing a parser with a team that understands parser generators, then using a parser generator is simple. If the team doesnβt know anything about parsing and the language is simple, a recursive descent parser is simpler.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (The XP Series))
β
The future value of a system reveals itself in todayβs realities, not yesterdayβs speculation.
β
β
Kent Beck (Tidy First?: A Personal Exercise in Empirical Software Design)
β
One example is the concept that vulnerability is safety. The old habit of holding something back in order to be safe doesnβt really work. Holding back that last 20% of effort doesnβt protect me. When my project fails, the fact that I didnβt give my all doesnβt actually make me feel better. It doesnβt protect me from a sense of failure that I couldnβt make the project work. If I do my very best writing a program and people donβt like it, I can still feel justly good about myself. This attitude allows me to feel safe no matter the circumstance. If how I feel is based on an accurate read on whether I did my best, I can feel good about myself by doing my best.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
Are the teeny-tiny steps feeling restrictive? Take bigger steps. Are you feeling a little unsure? Take smaller steps. TDD is a steering process -- a little this way, a little that way.
β
β
Kent Beck (Test-Driven Development: By Example)
β
Incremental designβWe invest in the design every day, but we have the additional constraint that we need to keep our APIs stable.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
XP always keeps the system in deployable condition. Problems are not allowed to accumulate.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
Itβs not my job to βmanageβ someone elseβs expectations. Itβs their job to manage their own expectations. Itβs my job to do my best and to communicate clearly.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
The difference between what I think is valuable and what is really valuable creates waste.
β
β
Kent Beck (Extreme Programming Explained: Embrace Change (XP Series))
β
A framework with all protected fields would be more immediately usable but harder to evolve later.
β
β
Kent Beck (Implementation Patterns)
β
Packages can provide a way to offer clients incremental access to upgrades. By introducing new classes in a new package, you can give them the same name as the old classes. For example, if I can upgrade org.junit.Assert in org.junit.newandimproved.Assert, then clients need only change the import statements to be using the new class. Changing imports is less risky and intrusive than changing code.
β
β
Kent Beck (Implementation Patterns)
β
Versioned interfaces are a reasonable compromise when you absolutely must introduce new operations to an existing interface-based abstraction without affecting client code. They are not a long-term solution for frequently changing abstraction, because of the complexity they create both for client and framework developers.
β
β
Kent Beck (Implementation Patterns)
β
Actually this book is built on a rather fragile premise: that good code matters. I have seen too much ugly code make too much money to believe that quality of code is either necessary or sufficient for commercial success or widespread use.
β
β
Kent Beck (Implementation Patterns)
β
Another way to look at implementation patterns is as a way of thinking βWhat do I want to tell a reader about this code?
β
β
Kent Beck (Implementation Patterns)
β
Even if there was no long-term economic impact from careful coding I would still choose to write the best code I could.
β
β
Kent Beck (Implementation Patterns)
β
Readers need to understand programs in detail and in concept. Sometimes they move from detail to concept, sometimes from concept to detail.
β
β
Kent Beck (Implementation Patterns)
β
Flexibility can come at the cost of increased complexity.
β
β
Kent Beck (Implementation Patterns)
β
Unlike the names at the roots of hierarchies, subclass names arenβt used nearly as often in conversation, so they can be expressive at the cost of being concise.
β
β
Kent Beck (Implementation Patterns)
β
When objects first became popular, subclassing seemed like a magic pill. First, subclasses were used for classificationβa Train was a subclass of Vehicle regardless of whether they shared any implementation. In time, some people saw that since what inheritance did was share implementation, it could most effectively be used to factor out common bits of implementation. Quickly, though, the limitations of subclassing became apparent.
β
β
Kent Beck (Implementation Patterns)
β
In the olden days (half a century ago), programs were big, undifferentiated masses of code and data. Control could flow from anywhere to anywhere. Data could be accessed from anywhere. Calculations, the original purpose of computers, occurred with (relatively speaking) lightning speed and perfect accuracy. Then people discovered an awkward fact: programs are written as much to be changed as to be run. All this control jumping around and self-modifying code and data accessed from everywhere was great for execution, but it was terrible if you wanted to change the program later. And so began the long and halting road to find models of computation so a change here doesnβt cause an unanticipated problem there.
β
β
Kent Beck (Implementation Patterns)
β
At some point, the cost of maintaining perfect compatibility outweighs the value to clients.
β
β
Kent Beck (Implementation Patterns)
β
The purposes of two constructors with different sets of parameters are not always obvious, but the name of the factory methods can suggest the reason clients might want to create an object each way.
β
β
Kent Beck (Implementation Patterns)
β
It is the framework developerβs job to ensure that clients can extend the framework to solve the remainder of their problems. Itβs tempting to try to solve a broad range of problems with a framework. The conflict is that the added functionality makes the framework that much more difficult to learn and use for all clients.
β
β
Kent Beck (Implementation Patterns)
β
Sometimes I feel silly introducing methods βjustβ to satisfy an βaestheticβ urge like symmetry. Aesthetics go deeper than that. Aesthetics engage more of your brain than strictly linear logical thought. Once you have cultivated your sense of the aesthetics of code, the aesthetic impressions you receive of your code is valuable feedback about the quality of the code.
β
β
Kent Beck (Implementation Patterns)
β
Call-by-reference went out of fashion in language design a couple of decades ago because of the possibility for unintended consequences.
β
β
Kent Beck (Implementation Patterns)
β
When we released JUnit 4 recently we spent nearly half of our engineering budget on reducing the cost of deployment for our clients. We tried to make sure that new-style tests would work with old tools and old-style tests would work with new tools. We also worked to make sure we had the freedom to make future changes to JUnit without breaking client code.
β
β
Kent Beck (Implementation Patterns)