Extreme programming (XP) is an agile development method that uses on-site customer collaboration, paired programming, and automated testing processes. XP is a widely used agile method that focuses focusing on simplicity, internal communications, and customer feedback (Singh & Pandey, 2017). XP, which was presented by Beck in 1999, is one of the oldest of the agile methods (Anwer & Aftab, 2017). According to Munawar and Qureshi (2015), the . The advantages of XP are short iteration cycles, direct communication with an on-site customer, and continuous integration and testing. The disadvantages are that the practice is requires minimal documentation and the method is not suited unsuitable for projects that involve reengineering (Munawar & Qureshi, 2015). According to Anwer and Aftab (2017)reengineering projects. As a note, the XP method is challenging to use on large projects and projects of a critical nature. XP, although Although practiced before the concept of agile was defined, XP is an agile development process.
...
XP, much like scrum, uses iterative phases in the software development process. The first phase of XP is the initialization phase in which project team members gather requirements from customers that are directly involved with the team to determine project scope and cost (Anwer & Aftab, 2017). In the requirements gathering phase, the team uses story cards to document and describe the request and elicit dialogue with the customer (Baruah, 2015). In the second phase (analysis phase), the software team develops the architecture and iteration plan (Anwer & Aftab, 2017). Repeated cycles of code development and testing follow the requirements and analysis phase, and the code is integrated into a deliverable release once it achieves the functional request (Anwer & Aftab, 2017). Additionally, one of the critical distinctions in the XP development process is the concept of paired programming.
Paired programming is a development approach in which two programmers sit together, one assuming the role of the driver and the other, the navigator. Paired programming is a standard practice in XP in which two people collaborate in the coding process (Hohl et al., 2018; Kotaiah & Khalil, 2017; Meyer, 2018). The driver sits at the keyboard to type the code while the navigator oversees the code input, watching for syntax errors and ensuring the program meets the required deliverable (Chen & Rea, 2018). The programmer who is actively writing the code (driver) focuses on the completion of the current task (Chen & Rea, 2018). The navigator, who is overlooking the code writing, can judge the strategic direction of the work performed, offering ideas for improvement or potential future problems (Karthiekheyan, Ahmed, & Jayalakshmi, 2018). The approach uses two programmers to collaborate on a single code set, working together to complete a development request.
Extreme Programming (XP) is a software development methodology that is intended to improve software quality and responsiveness to changing customer requirements. XP, like Scrum, is a type of Agile methodology which emphasizes close collaboration between the development team and the customer, frequent delivery of software, and flexibility to adapt to changing requirements.
XP involves several key practices:
Pair Programming: In XP, developers work in pairs, with one developer writing code while the other observes and reviews. The two developers periodically switch roles. This approach is believed to increase code quality by facilitating immediate review and feedback.
Test-Driven Development (TDD): In XP, developers write automated tests for a new feature before they write the code itself. They then write the minimum amount of code needed to pass the test. This practice helps ensure that all code is tested and promotes simplicity and confidence in the codebase.
Continuous Integration: Developers integrate their work frequently, often multiple times a day, to detect integration issues as soon as possible. Each integration is verified by an automated build and automated tests.
Refactoring: This is the practice of improving the design of existing code without changing its behavior. Refactoring is done regularly to improve the understandability of the code and reduce complexity.
Simple Design: The focus here is on keeping the design of the system as simple as possible at all times. Unnecessary complexity is avoided. The design is allowed to evolve as the system grows.
Collective Code Ownership: In XP, any developer can change any part of the codebase at any time. This is contrary to the practice of individual code ownership, where only the original developer can make changes. This practice promotes team-wide responsibility for the codebase.
Customer Collaboration: An on-site customer or user representative is involved throughout the development process to provide feedback and steer the project based on business or market requirements.
Sustainable Pace: Work hours should be kept at a level that is sustainable in the long run. Overly long hours of work can lead to burnout and mistakes.
Planning Game: The planning game is an iterative approach to long-term and short-term planning conducted by the whole team and the customer representative. It includes determining the scope of the next release, breaking down features into small, estimable tasks, and planning the work for the next iteration.
These practices are intended to be used together. Removing any one practice can affect the efficacy of the others. The objective is to reduce the cost of changes in requirements by having multiple short development cycles, rather than one long one.
Paired programming can have an advantage over developers working independently. In paired programming, the driver and the navigator often change roles throughout the project (Chen & Rea, 2018; Haines et al., 2017). The benefits of paired programming are constant code review and the brainstorming of approaches during the code’s development (Karthiekheyan et al., 2018). According to Chen and Rea (2018), programmers . Programmers can quickly catch and resolve errors, thus producing better code using a collaborative approach. Additionally, pairing an expert programmer with an average or novice programmer provides mentorship to the novice (Chen & Rea, 2018). However, teaming individuals who have the same expertise can cause counterproductive work (Haines et al., 2017). Therefore, the benefits of paired programming can be more significant when developers have different skill levels or experience.