Important Points

  1. An information radiator displays information in a place where passersby can see it. With information radiators, the passersby don’t need to ask questions; the information simply hits them as they pass.
  2. A good information radiator
    • Is large and easily visible to the casual, interested observer
    • It takes very little energy to view the display.
    • Is understood at a glance
    • Changes periodically, so that it is worth visiting
    • Is easily kept up to date
    • Information radiators can be used on any project, large or small
  3. William Pietri took a stab at defining how you could identify a bad team space easily. He listed the following points
    • People wearing headphones
    • Stale artifacts on the walls
    • Workspace as information desert
    • Minimal interaction
    • Furniture as barrier
    • Sad or ugly spaces
    • Seating by job description
    • Space and furniture as status markers
    • No laughter, no fun
  4. Osmotic communication means information flows into the background hearing of members of the team, so that they pick up relevant information as in osmosis.
  5. Osmotic communication makes the cost of communications low and the feedback rate high, so that errors are corrected extremely fast, and knowledge is disseminated quickly.
  6. Although osmotic communication is valuable for larger projects, it is, of course, increasingly difficult to attain as the team’s size grows.
  7. Retrospective planning game: team members brainstorm the task necessary to accomplish a goal and signup for the tasks they will tackle in order to complete the project.
  8. Debate is not part of retrospective
  9. A more effective tool to use in gathering data for project retrospectives would be timeline.
  10. Signal card containing a small amount of work or story to develop: Kanban
  11. Issue of too much WIP addressed by Kanban
  12. In planning phase-setting a fixed time limit to overall development efforts is called as time-boxing
  13. Time-boxes are used as a form of risk management, especially for tasks that may easily extend past their deadlines.
  14. In Scrum, we have 6 formal time-boxed events.
    • Releasing Planning
    • Sprint Planning
    • Sprint
    • Sprint Review
    • Sprint Retrospective
    • Daily Scrum
  15. Time-boxing can greatly improve productivity and effectiveness.
  16. Time-boxes help manage complexity by determining what can be achieved in a short duration.
  17. In release burn-down chart, the region below the horizontal axis indicates the overall work added to release.
  18. The bars in release burn-down chart represent the amount of work in the release.
  19. If features are being removed the bottom of the bar is raised to reflect this change.
  20. When new stories are added to its work stack: burn-down chart report burn-up chart
  21. Release burn-down chart vertical axis indicates (story points remaining in the project)
  22. Process tailoring: When seeking to implement Agile methodology into the work flow of teams who already have established and entrenched process.
  23. User stories originated as a part of XP
  24. Triangulating is a process in Agile estimation which is estimating a story based upon its relationship with other stories.
  25. Questonieries don’t lend themself to follow-up questions and hence are not the primary technique for trawling for new user stories.
  26. User stories should be written by customers of a project.
  27. A well-written user story has three components, namely, card, conversation and confirmation.
  28. Story points represent cost and value points represent benefit.
  29. Zero point estimate: the story requires trivial effort
  30. Normal time estimate for research story: 1 day
  31. The emphasis in user stories should not be on written communication rather increase collaboration, encourage differing of detail and emphasize on verbal communication.
  32. Allow as many rounds as it takes to converge while playing pocker.
  33. Three assumptions that must be made when estimating ideal days are that the story being estimated is the only thing you will work on, that everything you need will be on hand when you start and there will be no interruptions.
  34. In Agile project, the output of negotiation contracts to procure vendors and contractors.
  35. With respect to Agile governance, executives are most interested in investments.
  36. Governance in Agile environment means making decision in an uncertain environment.
  37. Agile project governance team would be interested in both investment decisions and risks.
  38. Concepts prevent duplication of code—DRY (Dont repeat yourself)
  39. Which information radiator is MOST useful in aligning the team’s effort in the right direction?: project priority chart.
  40. Most essential for developing collective code ownership: collaboration.
  41. For actively cultivating innovation, it requires visualization and commonality.
  42. Exploration process are designed to deliver innovation reliably
  43. Five key business objectives of Agile project management are

    Continuous innovation, product adaptability, improved time to market, people and process capability, and reliable results.

  44. A buffer iteration is used to allocate contingency time for final finishing features.
  45. A hardening iteration is used for preparing items such as marketing materials.
  46. Release backlog features are measured in story point, while iteration backlog items are estimated in hours.
  47. Cumulative flow diagram shows visual of all the story points completed through every iteration.
  48. Benefit of short iterations: They allow the team to receive timely feedback.
  49. Three levels of planning in Agile: release planning, iteration planning and daily planning.
  50. Exploration process is designed to deliver innovation reliably
  51. Effective release plan is based on timeframe
  52. The primary objective of Agile risk planning is to enable the team to meet their long-term commitments.
  53. The primary tool used in Agile release planning is index cards.
  54. An example for index card-based planning is blitz planning.
  55. Release plan helps to develop a better understanding of the project viability.
  56. Learners at detaching stage look for limitations of the procedure.
  57. Daily stand-up is concise discussions of project status with the entire team.
  58. Daily stand-up meetings, daily interaction with product team and stakeholder coordination are ways of encouraging collaboration and coordination
  59. Standing helps the meeting to be short.
  60. To report the status to the customer all of the following are being used: formal documentation, informal documentation and daily stand-ups.
  61. Success of a project is determined by the maximum value that was delivered to the customer.
  62. The following demonstrates a measure of value delivered to the customer: extrinstic quality and releaseable product.
  63. Three performance parameters used for Agile projects are value, quality and constraints (value is the primary goal).
  64. Business goals, Agile values, organization, product pack and process are major components of an Agile scaling model (ASM).
  65. Agile teams generally achieve low bug rates
  66. ROI, customer satisfaction are the metrics that can be standardized across the team.
  67. On an Agile, ‘The Team’ determines how much of the product backlog can be delivered in the upcoming sprint.
  68. Tool utilized by distributed team to maintain high level of communication is Wikishare portal.
  69. In high performance team, leaders manage principles.
  70. The entire team is change controllers in an Agile project.
  71. Temperature reading is used to determine what the team wants.
  72. First step in building high performance team is to set the expectation.
  73. Agile team’s productivity metrics: cycle time, release burn-downs and customer support.
  74. Programmers should master the practice of spike solution.
  75. In high performance team, principles manage the team.
  76. The purpose of the risk mitigation is to reduce the impact.
  77. An output of catastrophes brainstorming session is a risk census (Risk register).
  78. Transition indictor is a signal when a risk is close to occurring.
  79. An Agile coach facilitates by creating mediums to collect team generated ideals and innovations. These collection medium are referred as ‘Containers’.
  80. Coaching style that can be applied where team members have trouble with compliance is teaching
  81. The code of professional conduct for Agile coaches holds that coaches exist for the coaches.
  82. Period time for release is 12 months.
  83. When the team delivered 23 story points, the top will move down 23 points in release burn-down bar.
  84. Conflict resolution allows teams to preserve trust amongst members
  85. Preferred level of conflict within team is LEVEL 1.
  86. When one person complains about another: Three step intervention approach of conflict is being used.
  87. The sum of knowledge all of the people in the team is called TACIT knowledge.
  88. Three ways to get initial value for velocity: use historical values, run initial iteration and use that velocity, and take a guess.
  89. Commit build process should have both unit test and integration test.
  90. The test which validates the functionality to be delivered and meets customer expectations: acceptance test.
  91. Exploratory testings help to catch bugs related to security and concurrency in the application.
  92. The purpose of ruthless automated testing: to ensure product quality remains high throughout the development process.
  93. XP team are advised to integrate their code a minimum of once per day
  94. In XP, customers are most qualified to prioritize product features.
  95. Most difficult hurdles that managers must overcome in cost accounting and reporting of project is capitalization vs. expense.
  96. Relative weighting priority of feature is determined by dividing the priority % by the cost %.
  97. Erg second is a measure of cost to get questions answered within a team.
  98. Lost opportunity cost: The cost of fixing errors introduced due to team members not communicating with one another.
  99. To improve time to market an Agile, the project manager should consider both the number of features and the depth of the features.
  100. Kano model’s most important product is threshold features/MUST have features(threshold, linear, excitor in order).
  101. Change report is generated at the end of each sprint.
  102. Change report is BEST described as differences between the product backlogs at the start of previous sprint and at the start of new sprint.
  103. Design principles that provides a guideline to design relationship between concepts in a design: Decoupling.
  104. The most effective and efficient way according to the Agile manifesto to convey the information throughout the team is to use face-to-face communication.
  105. Product owner represents the stakeholder and the business.
  106. Don’t wait when issues comes … discuss with the team immediately.
  107. The Agile management tool that allow teams to track pipeline delays and queue sizes: Cumulative flow diagram.
  108. Continuously practising the application of active listening frameworks helps to develop active listening skills within Agile groups.
  109. Version control system is accessible to both the development team and the customer.
  110. The period time for roadmap is 2 years.
  111. The period time for wave is 3 months.
  112. Specific roles ensure customer collaboration.
  113. Group thinking should be avoided while generating ideas.
  114. Project trade-off matrix is used to view the relative importance of the project constraints and determines whether they are fixed, flexible or acceptable.
  115. Complex adaptive system theory (CAS): the tacit and explicit information exchanges between stakeholders involved in the project.
  116. Best approach to estimation is always the combination of expert opinion, analogy and disaggregation.
  117. In Agile environment projects are divided into two areas: production and exploration.
  118. Exploration means: unknown problem and known solution, unknown problem and unknown solution, known problem and unknown solution.
  119. Strategy for creating trust in Agile team are customer programmer empathy, programmer tester empathy, eating together and team continuity.
  120. The preparation of business case can assist in obtaining project approval.
  121. A spike is best described as a brief learning period.
  122. Agile philosophy for failure of project: Fail fast.
  123. Collaboration involves working together to jointly produce a deliverable or make a decision, whereas communication involves sharing of information.
  124. The best place to store sandbox is on local develop machine.
  125. Version control with concurrent model allows multiple developers to edit the same file simultaneously; emphasis on user stories should not be on technical competencies.
  126. Time travelling to fix bugs: Checking previous versions to identify the root cause of a bug.
  127. Project data sheet is a one page summary of key project management information, business objectives and product capabilities.
  128. Think of vendors as part of the same team: ‘They are also us’.
  129. Keeping related concepts closer together is called cohesion.
  130. Six sigma technique adopted by Agile PMO: Pareto diagrams and RCA.
  131. Sitting together reduces time to market by one-third.
  132. Health check and questionnaires can be used to find problems in a process.
  133. Learners at level1 look for one procedure that works.
  134. Multi-stage integration builds for: running additional tests for performance, load or stability
  135. Five failure modes: People making mistakes, preference in conservative failures, inventing over researching, forming habits and inconsistencies.
  136. Agile enterprise framework has 4 layers: portfolio governance layer, project management layer, iteration management layer and technical practice layer.
  137. Speculate phase: develop a capability and/or feature based release plan to deliver on the vision.
  138. Reports generation should be considered as a separate story.
  139. Vertical market software are developed for many organisations.
  140. The correct order of APM delivery frame work: envision, speculate, explore, adapt and close.
  141. In high performance company, core values and distinguishing purpose remain constant while operating practices and business strategies change.
  142. The role of PMO: Provides insight to stakeholders of value delivered.
  143. Shotgun debugging: trying many solutions at once.
  144. Exciter feature: add price premium to the product.
  145. Cost of delivering an Agile project is best determined by delivery team during release planning phase.
  146. Report that is more detailed than vision statement: Roadmap.
  147. Team does not know whether the design will work out or not. It is recommended to do______(Spikes) to find out which will work out for them.
  148. Person best suited and most appropriate to monitor all risks in Agile projects: Project manager.
  149. Agility is the ability to manage flexibility and stability.
  150. To serve as an example of a skilled and capable Agile practitioner, one must be a model of Agile practices.
  151. Types of successes are personal success, organizational success and technical success.
  152. Organizational success is measured by ROI
  153. Apart from revenue and cost savings, sources of organisational value include:
    • Competitive differentiation
    • Brand projection
    • Enhanced customer loyalty
    • Satisfying regulatory requirements
    • Original research
    • Strategic information
  154. Agile projects release their most valuable features first and release new versions frequently, which dramatically increase value.
  155. Agile manifesto is a collection of 4 values and 12 principles.
  156. Agile manifesto values
    • Individuals and interactions over processes and tools
    • Working software over comprehensive documentation
    • Customer collaboration over contract negotiation
    • Responding to change over following a plan
  157. XP emphasizes face-to-face collaboration
  158. In XP, customers and testers create the customer tests for a story around the same time that programmers implement the story.
  159. This work is driven by test-driven development (TDD), an activity that inextricably weaves together testing, coding, design and architecture.
  160. TDD produces automated unit and integration tests.
  161. They use exploratory testing to look for surprises and gaps in the software.
  162. When the testers find a bug, the team conducts root-cause analysis and considers how to improve their process to prevent similar bugs from occurring in the future.
  163. A well-functioning XP teams produce only a handful of bugs per month in a completed work.
  164. Customers’ most important activity in XP is release planning.
  165. XP uses requirements documents only as memory aids for customers.
  166. Typically, product managers, domain experts, interaction designers and business analysts play the role of the on-site customer.
  167. As a rule of thumb, start with two on-site customers (including the product manager) for every three programmers. As a rule of thumb, start with one tester for every four programmers.
  168. The product manager has only one job on an XP project, - to maintain and promote the product vision.
  169. The best product managers have deep understandings of their markets.
  170. Interaction designers(UI) perform such tasks as interviewing users, creating user personas, reviewing paper prototypes with users, and observing usage of actual software.
  171. If the customers’ job is to maximize the value of the product, then the programmers’ job is to minimize its cost.
  172. XP leaders are called coaches.
  173. The coach differs from your mentor. Your mentor is someone outside the team who you can turn to for advice.
  174. At a minimum, however, XP prefer to see one person clearly designated as ‘product manager’ (who may do other customery things) and one person clearly defined as ‘programmer-coach’ (who also does programmery things).
  175. Refactoring is the process of changing the structure of code—rephrasing it—without changing its meaning or behaviour.
  176. Technical debt is the total amount of less-than-perfect design and implementation decisions in your project.
  177. Stories are customer-centric, describing the results in terms of business results.
  178. Velocity has no relation to productivity.
  179. TOC—Theory of Constraints. Programmers are the constraint.
  180. Agility—the ability to respond effectively to change—requires that everyone pays attention to the process and practices of development. This is mindfulness.
  181. XP’s applicability is based on organizations and people, not types of projects.
  182. For XP
    • Prerequisite #1: Management Support
    • Prerequisite #2: Team Agreement
    • Prerequisite #3: A Collocated Team
    • Prerequisite #4: On-site Customers
    • Prerequisite #5: The Right Team Size
    • Prerequisite #6: Use All the Practices
  183. For XP
    • Recommendation #1: A Brand-New Codebase
    • Recommendation #2: Strong Design Skills
    • Recommendation #3: A Language thats Easy to Refactor
    • Recommendation #4: An Experienced Programmer-Coach
  184. XP strongly recommends 40 hr week - 5 working days of 8 hr each. Regular overtime is the signal of a problem in the project.
  185. The first team is often very successful, inspiring the organization to use XP on more projects, but then this second wave of XP projects struggles, called second adaptor syndrome.
  186. Other than change itself, the biggest challenge in applying XP to an existing project is not writing tests, refactoring or cleaning up your bug database. The biggest challenge is setting aside enough time to pay down technical debt.
  187. Technical debt is a big challenge in applying XP to an existing project.
  188. The more slack you provide for paying down technical debt, the lower your velocity will be, but the less time it will take for your velocity to rise again.
  189. Think of velocity as cash flow: the more principal you pay on your debt, the less cash you have each week, but the more quickly you can stop paying interest.
  190. Fortunately, as your technical debt decreases, your velocity will rise again.
  191. XP assumes that you use iterations, not phases, which makes using XP in a phase-based environment difficult.
  192. Assess your agility: Thinking, planning, developing, releasing, collaborating.
  193. XP does not require experts. It does require a habit of mindfulness.
  194. Pair programming doubles the brainpower available during coding, and gives one person in each pair the opportunity to think about strategic, long-term issues.
  195. Energized work acknowledges that developers do their best, most productive work when they are energized and motivated.
  196. An informative workspace gives the whole team more opportunities to notice what’s working well and what isn’t.
  197. Root-cause analysis is a useful tool for identifying the underlying causes of your problems.
  198. Retrospectives provide a way to analyse and improve the entire development process.
  199. To practice communicating and switching roles while pairing, consider ping-pong pairing.
  200. An informative workspace broadcasts information into the room.
  201. Gaming occurs when people try to improve a number at the expense of overall progress.
  202. Iteration retrospectives, release retrospectives, project retrospectives and surprise retrospectives.
  203. Mute mapping is a variant of affinity mapping in which no one speaks. Its a great way to categorize a lot of ideas quickly.
  204. Trust is essential for the team to thrive (We work together effectively and without fear).
  205. Sitting together leads to fast, accurate communication.
  206. Real customer involvement helps the team understand what to build.
  207. A ubiquitous language helps team members understand each other.
  208. Stand-up meetings keep team members informed.
  209. Coding standards provide a template for seamlessly joining the team’s work together.
  210. Iteration demos keep the team’s efforts aligned with stakeholder goals.
  211. Reporting helps reassure the organization that the team is working well.
  212. Trust
    • Team Strategy #1: Customer–Programmer Empathy
    • Team Strategy #2: Programmer–Tester Empathy
    • Team Strategy #3: Eat Together
    • Team Strategy #4: Team Continuity
  213. Consider the team as a resource rather than people as a resource.
  214. The more successful XP is the more these worries grow. Alistair Cockburn calls them organizational antibodies.
  215. When a problem does occur, you should usually be able to solve it by using slack, not overtime.
  216. In the case of a software team, hustle is energized, productive work.
    • Organizational Strategy #1: Show Some Hustle
    • Organizational Strategy #2: Deliver on Commitments
    • Organizational Strategy #3: Manage Problems
    • Organizational Strategy #4: Respect Customer Goals
    • Organizational Strategy #5: Promote the Team
    • Organizational Strategy #6: Be Honest
  217. Tunnel vision—you can get so caught up in the daily details of the project that you lose track of your real customers’ interests.
  218. Unlike custom development, vertical-market software is developed for many organizations. Like custom development, however, it’s built for a particular industry and it’s often customized for each customer.
  219. Horizontal-market software: software that’s intended to be used across a wide range of industries. (Instead, find other ways to involve customers: focus groups, user experience testing, community previews, beta releases and so forth.)
  220. Stand-up Meetings—The primary virtue of the stand-up meeting is brevity.
  221. Progress Reports: Reports on the progress of the team, such as an iteration demo or a release plan.
    • Vision statement
    • Weekly demo
    • Release and iteration plans
    • Burn-up chart
    • Roadmap
    • Status e-mail
  222. Management Report: high level status of the project
    • Productivity
    • Throughput
    • Defects
    • Time usage
  223. Throughput is the number of features the team can develop in a particular amount of time.
  224. Reports to avoid
    • Number of stories
    • Velocity
    • Code quality
  225. A normal-sized team will typically work on 4 to 10 stories in every iteration.
  226. ‘Done done’ ensures that completed work is ready to release.
  227. Version control allows team members to work together without stepping on each other’s toes.
  228. A ten-minute build builds a tested release package in under 10 minutes.
  229. Continuous integration prevents a long, risky integration phase.
  230. Collective code ownership allows the team to solve problems no matter where they may lie.
  231. To achieve zero bugs result, XP uses a potent cocktail of techniques
    • Write fewer bugs by using a wide variety of technical and organizational practices.
    • Eliminate bug breeding grounds by refactoring poorly designed code.
    • Fix bugs quickly to reduce their impact, write tests to prevent them from reoccurring, then fix the associated design flaws that are likely to breed more bugs.
    • Test your process by using exploratory testing to expose systemic problems and hidden assumptions.
    • Fix your process by uncovering categories of mistakes and making those mistakes impossible.
  232. Collective code ownership spreads responsibility for maintaining the code to all the programmers.
  233. A typical alternative to collective code ownership is strong code ownership, in which each module has a specific owner and only that person may make changes. A variant is weak code ownership, in which one person owns a module but others can make changes as long as they coordinate with the owner.
  234. Vision reveals where the project is going and why it’s going there.
  235. Release planning provides a roadmap for reaching your destination.
  236. The planning game combines the expertise of the whole team to create achievable plans.
  237. Risk management allows the team to make and meet long-term commitments.
  238. Iteration planning provides structure to the team’s daily activities.
  239. Slack allows the team to reliably deliver results every iteration.
  240. Stories form the line items in the team’s plan.
  241. Estimating enables the team to predict how long its work will take.
  242. The vision statement documents three things: what the project should accomplish, why it is valuable and the project’s success criteria.
  243. Release early, Release often.
  244. A minimum marketable feature, or MMF, is the smallest set of functionality that provides value to your market, whether that market is internal users (as with custom software) or external customers (as with commercial software).
  245. MMFs provide value in many ways such as competitive differentiation, revenue generation and cost savings.
  246. Adapt Your Plans
    • Keep Your Options Open
    • Planning at the Last Responsible Moment
    • The Planning Game
  247. Suppose you are creating a system that gets data from a user, validates the data and writes it to a database.

    You might initially create a story for each step: ‘Get data’, ‘Validate data’, and ‘Write data to database’. These are sometimes called horizontal stripes.

  248. A better approach is to create stories that do all three tasks but provide narrower individual utility. For example, you might create the stories ‘Process customer data’, ‘Process shipping address’, and ‘Process billing information’. These are vertical stripes.
  249. There are two basic types of plans: scope-boxed plans and time-boxed plans.
  250. A scope-boxed plan defines the features the team will build in advance, but the release date is uncertain.
  251. A time-oxed plan defines the release date in advance, but the specific features that release will include are uncertain.
  252. XP assumes that customers have the most information about value: what best serves the organization.
  253. Programmers have the most information about costs: what it will take to implement and maintain those features.
  254. Create a risk census,that is, a list of the risks your project faces that focuses on your project’s unique risks.
  255. Risk exposure reflects how much time or money you should set aside to contain the risk.
  256. Risk_adjusted_points_remaining = (iterations_remaining - risk_exposure) × velocity / risk_multiplier
  257. For example, if you are using a rigorous approach, your release is 12 iterations away, your velocity is 14 points, and your risk exposure is one iteration, you would calculate the range of possibilities as:
    • Points remaining = (12 - 1) × 14 = 154 points
    • 10 % chance: 154/1 = 154 points
    • 50 % chance: 154/1.4 = 110 points
    • 90 % chance: 154/1.8 = 86 points
    • In other words, when it is time to release, you are 90% likely to have finished 86 more points of work, 50% likely to have finished 110 more points, and only 10% likely to have finished 154 more points.
  258. Some teams have a dedicated phone for emergency support requests; this is, of course, the bat-phone.
  259. The amount of slack you need does not depend on the number of problems you face. It depends on the randomness of problems.
  260. A good rule of thumb is to spend 10% of the iteration on technical debt.
  261. Dedicated research time is an excellent way to encourage learning and adding additional slack into your iterations (People improvement).
  262. Stories represent customer value and are written in the customers’ terminology. (The best stories are actually written by customers.)
  263. Stories describe an end-result that the customer values, not implementation details.
  264. Stories have clear completion criteria. Customers can describe an objective test that would allow programmers to tell when they have successfully implemented the story.
  265. Special type of stories
    • Documentation stories
    • ‘Non-functional’ stories
    • Bug stories
    • Spike stories (Research to do something)
    • Estimating
    • Meetings
  266. Velocity relies upon a strict iteration time-box. To make velocity work, never count stories that aren’t ‘done done’ at the end of the iteration. Never allow the iteration deadline to slip, not even by a few hours.
  267. You can have accurate estimates if you:
    • Estimate in terms of ideal engineering days (story points), not calendar time
    • Use velocity to determine how many story points the team can finish in an iteration
    • Use iteration slack to smooth over surprises and deliver on time, every iteration
    • Use risk management to adjust for risks to the overall release plan
  268. Improving Velocity
    • Pay down technical debt
    • Improve customer involvement
    • Support energized work
    • Provide needed resources
    • Offload programmer duties
    • Adding programmers
  269. Incremental requirements allows the team to get started while customers work out requirements details.
  270. Customer tests help communicate tricky domain rules.
  271. Test-driven Development allows programmers to be confident that their code does what they think it should.
  272. Refactoring enables programmers to improve code quality without changing its behaviour.
  273. Simple design allows the design to change to support any feature request, no matter how surprising.
  274. Incremental design and architecture allows programmers to work on features in parallel with technical infrastructure.
  275. Spike solutions use controlled experiments to provide information.
  276. Performance optimization uses hard data to drive optimization efforts.
  277. Exploratory testing enables testers to identify gaps in the team’s thought processes.
  278. Divergent change occurs when unrelated changes affect the same class. Its an indication that your class involves too many concepts. Split it, and give each concept its own home.
  279. Shotgun surgery is just the opposite: it occurs when you have to modify multiple classes to support changes to a single idea. This indicates that the concept is represented in many places throughout your code. Find or create a single home for the idea.
  280. Data clumps are similar to primitive obsession. They occur when several primitives represent a concept as a group.
  281. When you have a class that contains methods but no meaningful per-object state, you have a wannabe static class.
  282. When you a refactor, proceed in a series of small transformations. (Confusingly, each type of transformation is also called a refactoring.)
  283. You Aren’t Gonna Need It (YAGNI)
  284. ‘Don’t repeat yourself’, or the DRY principle.
  285. A spike solution, or spike, is a technical investigation. It’s a small experiment to research the answer to a problem.
  286. Exploratory testers use the following four tools to explore the software.
    • Tool #1: Charters (Charters are the testing equivalent of a story)
    • Tool #2: Observation
    • Tool #3: Note-taking
    • Tool #4: Heuristics
  287. CRUD: create, read, update, delete
  288. Experience helps you see how Agile methods work. Mindfulness helps you understand your experiences.
  289. Improve the Process

    Test-driven development, exploratory testing, real customer involvement, iteration demos and frequent releases all provide information about the project, from code to user response.

  290. Rely on People: (Continuous improvement)
  291. Build Effective Relationships
  292. Let the Right People Do the Right Things
  293. Eliminate Waste (improving)
  294. Deliver Value
    • Only Releasable Code has Value
    • Deliver Business Results
    • Deliver Frequently
  295. They say that it has the Quality without a Name (QWAN)—an ineffable sense of rightness in the design.
  296. Talk with end user involvement
  297. Building dam, building bridge there is no short cut.
  298. For software Agile is possible because of rapid change in business conditions, market conditions and needs to be integrated.
  299. We can’t call a requirement analysis phase complete in a Agile project. It keeps on going continuously.
  300. Delivery software quickly and incremental manner.
  301. In Agile projects, user feels software early in the life cycle and opportunity to get view quickly.
  302. Iterative process
    • Specify increment
    • Build increment
    • Validate increment
    • Integrate increment
    • Test system and continue
  303. Advantage Agile
    • Accelerated delivery
    • User engaged with system continuously
  304. Disadvantage Agile
    • Tracing the increment to meet the overall goal.
    • Hard to maintain if there are no documents.
    • There is no specification and so validation problem may exist.
    • Complexity keep on increasing.
  305. Prototyping
    • Does not focus on delivery to the customer.
    • Used to get feedback from the user.
    • Business logic may not be coded in prototyping.
    • Experimental systems are developed using this.
    • Initial version of the system.
    • It is used in UI, design, testing.
  306. Benefits of Prototyping
  307. Process of Prototype
    • Define objective of Prototype
    • Define functionality prototype
    • Develop prototype
    • Evaluate prototype
  308. Both (Agile, Prototypes) starts from requirements.
  309. E-commerce system developed incrementally.
  310. Examples for principles of Agile methods
    • Customer involvement
    • Incremental delivery
    • People not process
    • System is designed for change
  311. XP is a set of guiding principles.
  312. Core values of XP
    • Communication
    • Simplicity
    • Feedback
    • Courage
  313. The Scrum master is responsible for teaching others how to use the Scrum process to deal with every new complexity encountered during a project.
  314. Much of our society is based on processes that work only because their degree of imprecision is acceptable.
  315. Laying out a process that repeatedly will produce acceptable quality output is called defined process control.
  316. When defined process control cannot be achieved because of the complexity of the intermediate activities, something called empirical process control has to be employed.
  317. There are three legs that hold up every implementation of empirical process control: visibility, inspection and adaptation.
  318. Visibility means that those aspects of the process that affect the outcome must be visible to those controlling the process.
  319. Enumeration of complexity in software development to the three most significant dimensions: requirements, technology and people.
  320. Complexity assessment graph—the vertical axis traces requirements complexity, and the horizontal axis traces technology complexity.
  321. Scrum cycle repeats until the project is no longer funded.
  322. There are only three Scrum roles: the product owner, the team, and the Scrum master.
  323. The product owner is responsible for representing the interests of everyone with a stake in the project and its resulting system.
  324. The Scrum master is responsible for the Scrum process. Teach the product owner how to maximize ROI and meet his or her objectives through the Scrum.
  325. Team members are responsible for figuring out how to turn the product backlog into an increment of functionality within an iteration and managing their own work to do so.
  326. Pigs are those who are committed to a project: (PO, Team, Scrum master)
  327. Chickens are the spectators.
  328. Chickens have no direct authority over the project’s execution or progress.
  329. Each sprint is initiated with a sprint planning meeting, where the product owner and team get together to collaborate about what will be done for the next sprint.
  330. Sprint planning is an 8 hours meeting
  331. Sprint review is a 4 hours meeting
  332. Sprint retrospective is a 3 hours meeting
  333. Sprint review is an informal meeting
  334. In the product backlog items, the first four columns are the product backlog item name, the initial estimate, the complexity factor and the adjusted estimate.
  335. In the sprint backlog, each task takes roughly 4–hours to finish.
  336. This requires that the increment consist of thoroughly tested, well-structured, and well-written code that has been built into an executable and that the user operation of the functionality is documented, either in help files or in user documentation. This is the definition of a ‘done’ increment.
  337. While the traditional project manager is responsible for defining and managing the work, the Scrum master is responsible for managing the Scrum process. To put it simply, Scrum masters make Scrum work.
  338. One of the ingredients of Scrum is a practice known as sashimi. Sashimi is a Japanese delicacy consisting of thin slices of raw fish.
  339. The minimum plan necessary to start a Scrum project consists of a vision and a product backlog.
  340. The daily Scrum is open to everyone.
  341. Scrum addresses the various KPAs in level 2 and level 3. 6 level 2 KPAs 7 level 3 KPAs.
  342. The Scrum planning process sets stakeholders’ expectations.
  343. Specific structure of retrospective meeting
    • Set the stage—working agreement (ground rules)
    • Gather data—gathering data creates a shared picture of what happened.
    • Generate insights—time to ask ‘Why?’
    • Decide what to do—pick the topic items
    • Close the retrospective—decide
  344. Ensure each stage has minimum of 2 activities.
  345. Activities to set the stage
    • Check-in: Help people articulate what they want from the retrospective
    • Activity: Focus On/Focus Off
    • Activity: ESVP (Explorer, Shopper, Vacationer or Prisoner)
  346. Explorers are eager to discover new ideas and insights. They want to learn everything they can about the iteration/release/project.
  347. Shoppers will look over all the available information, and will be happy to go home with one useful new idea.
  348. Vacationers aren’t interested in the work of the retrospective, but are happy to be away from the daily grind. They may pay attention some of the time, but they are mostly glad to be out of the office.
  349. Prisoners feel that they’ve been forced to attend and would rather be doing something else.
  350. Activities to gather data
    • Activity: Timeline

    Coloor coding feelings to gather both facts and feelings, use colours to represent emotional states. For example:

    • Blue = sad, mad, bad
    • Red = challenged, stalled
    • Green = satisfied, successful, energetic
    • Yellow = cautious, confused
    • Purple = fun, surprise, humour
    • Salmon = fatigued, stressed
  351. Activity: Triple Nickels. (Generate ideas for actions or recommendations.)
  352. Activities to Generate Insights:
    • Activity: Brainstorming/Filtering
    • Activity: Force Field Analysis
    • Activity: Five Whys
    • Activity: Fishbone
    • Activity: Patterns and Shifts
    • Activity: Prioritize with Dots
    • Activity: Report Out with Synthesis
    • Activity: Identify Themes
    • Activity: Learning Ideas (what is significant in their ideas)
  353. Activities to decide what to do:
    • Activity: Retrospective Planning Game
    • Activity: SMART Goals (Specific, Measureable, Attainable, Relevant, Timely)
    • Activity: Circle of Questions
    • Activity: Short Subjects
  354. Activities to Close the retrospectives:
    • Activity: +/Delta
    • Activity: Appreciations
    • Activity: Temperature Reading
    • Activity: Helped, Hindered, Hypothesis (HHH)
    • Activity: Return on Time Invested (ROTI)
  355. Determine Goal for Retrospective, for example, Find ways to improve our practices. Determine duration: depends on length of the iteration, complexity of the work, size of the iteration.
  356. Encourage Equal Participation, Focus the Conversation Encourage New Perspectives
  357. J. M. Keller, an expert in motivation and learning, developed a criteria for evaluating instructional designs. The criteria are attention, relevance, confidence/competence, satisfaction—ARCS for short.
  358. Retrospectives can’t solve every problem.
  359. Iteration retrospectives focus solely on the team.
  360. For a release retrospective consider inviting folks who represent admin support, on-site ­customers, product owners, the deployment team, the testing group, marketing, technical support, help desk, operations, beta testers and the project manager.
  361. Four transitional phases in a change
    • Loss
    • Chaos
    • Transforming idea
    • Practice and integration
  362. A debrief helps your team examine their experience and extract insights. They’ll make conscious connections and form new ideas. Debriefing each activity builds towards the insights and decisions of the retrospective.
  363. Agility is the ability to both create and respond to change in order to profit in a turbulent business environment.
  364. Agility is the ability to balance flexibility and stability (Highsmith 2002).
  365. There are two primary sources for Agile values, the declaration of interdependence authored by the founding members of the Agile Project Leadership Network (www.apln.org) and the Manifesto for Agile Software Development authored by many of the founding members of the Agile Alliance (www.agilealliance.org).
  366. The Declaration of Interdependence was developed with project leaders in mind, whereas the Agile Manifesto (the oft-used short name) was developed with software development in mind.
  367. The Agile triangle. The measures here are value (to the customer), quality (required to deliver continuous value to the customer) and constraints (scope, schedule, and cost).
  368. The envision phase results in a well-articulated business or product vision—enough to keep the next phases bounded.
  369. In the speculate phase, the team hypothesizes about the specifications of the product and builds a release plan, knowing that as the project continues both technology and customer specifications will evolve as new knowledge is gained.
  370. The explore phase then becomes an iterative operation in which the features and stories are implemented.
  371. In the adapt phase, the results of these experiments are subjected to technical, customer and business case review, and adaptive actions are incorporated into the next iteration.
  372. Project leaders need to focus on value in several ways: value determination (with product owners), value prioritization (backlog management) and value creation (iterative development).
  373. Levels of Listening
    • Level 1- Internal Listening—Hearing the word and interrupt it in own language
    • Level 2- Focused Listening—Listening and responding without interrupting in own language
    • Level 3- Global Listening—While focused understand the team global environment
  374. Agile projects gives high IRR comparatively with other traditional projects.
  375. Payback Period: Payback period is the unit of time (amount of time) to receive (get back) the initial amount invested. It does not consider the future.
  376. Net Present Value (NPV): It is the accurate value of all the future inflow due to business in today’s value (Present Value). We need to convert the future value into the present value and then sum of all the present value gives NPV (Net Present Value).
  377. Discounted ROI = NPV of Benefits / NPV of Costs
  378. ROI = Velocity × Margin
  379. The most effective and efficient way according to the Agile manifesto to convey the information throughout the team is to use face-to-face communication.
  380. Collaboration involves working together to jointly produce a deliverable or make a decision, whereas communication involves the sharing of information.
  381. Time and Material Contract: This is the most suitable method of contracting for Agile projects. In this type of contract, the vendor is being paid for hours spent by the team members.
  382. Agile concentrates straightaway into execution (action) part.
  383. Iterative nature takes care of identifying risks earlier. Risk process repeats for every iteration.
  384. Risk analysis is used to help a team understand uncertainty that could affect the outcome of the project.
  385. Four Risk Planning mechanism:
    • Mitigate
    • Avoid
    • Evade
    • Contain
  386. Risk management should be an integral part of organizational processes—When you are doing Agile, you are doing risk management, and hence it is a part of the standard process.
  387. Risk management should take into account human factors—That’s why risk management is done with all stakeholders, and not single-handedly by a project manager.
  388. eXtreme projects are chaotic, messy and unpredictable; speed and innovation are critical, and planning is chaotic and just-in-time.
  389. Innovation is critical in eXtreme projects. In fact, it is more than critical; innovation is what eXtreme projects are all about.
  390. Traditional project management is past-oriented. eXtreme project management is future-oriented.
  391. The goal of traditional project management is to get it right the first time; the goal of Agile or adaptive project management is to get it right the last time.
  392. With a task-based WBS, tasks are relatively ­permanent. With a feature-based WBS, features can be added or deleted during each iteration.
  393. Coding standards focus on consistency and consensus over perfection.
  394. You can still cancel the project if you encounter risks and issues in planning phase of the project.
  395. Feature shell is also the term used to refer feature card.
  396. There is no formula to define the size of the story.
  397. The amount of time a user story will take to develop can be more easily estimated in ideal days than elapsed days.
  398. Ideal days are easier to explain to outside team than user stories.
  399. A project is usually critical if the company or customer can’t survive without it.
  400. When you create a trade-off matrix, only one item can be the number one priority.
  401. Prioritizing features lets you stop a project before it is complete and still delivers the critical features.
  402. When we create feature cards we record acceptance test too.