NJIT 1 Test Driven Development and Refactoring Larman, Chapter 21.

Slides:



Advertisements
Similar presentations
12-Dec-14 Refactoring IV. Previously discussed bad smells Duplicated code — and other forms of redundancy Long method — use short methods that delegate.
Advertisements

Module 7. Simplifying Conditional Expressions Course: Refactoring.
Test-Driven Development and Refactoring CPSC 315 – Programming Studio.
© 2010 Shawn A. Bohner Software Construction and Evolution - CSSE 375 Even more Bad Smells in Code Shawn & Steve Q1 Shawn & Steve Hint 
You want me to do what??? Refactoring legacy applications aka : fixing someone else’s “bad” code Niel Zeeman Team Foundation Consulting
Refactoring Overview  What is refactoring?  What are four good reasons to refactor?  When should you refactor?  What is a bad smell (relative to refactoring.
Software Construction and Evolution - CSSE 375 Bad Smells in Code Shawn Bohner & Steve Chenoweth.
1 Software Maintenance and Evolution CSSE 575: Session 1, Part 4 Even more Bad Smells in Code Steve Chenoweth Office Phone: (812) Cell: (937)
Introduction to Refactoring Excerpted from ‘What is Refactoring?’ by William C. Wake and Refactoring: Improving the Design of Existing Code by Martin Fowler.
George Blank University Lecturer. REFACTORING Improving the Design of Existing Code Supplement to Ian Sommerville, Software Engineering, Chapter 20 Prepared.
25-Jun-15 Refactoring III. General philosophy A refactoring is just a way of rearranging code Refactorings are used to solve problems If there’s no problem,
REFACTORING Improving the Design of Existing Code Atakan Şimşek e
Leiden University. The university to discover. Leiden University. The university to discover. Leiden University. The university to discover. Software Engineering.
Maintenance Refactoring and Code Smells. Where are we? Over the semester we have talked about Software Engineering. The overall goal of software engineering.
Advanced Programing practices
Software Refactoring Part I: Introduction Bartosz Walter Advanced Object-Oriented Design Lecture 5.
Refactoring. Mathematics: Factor ● fac·tor – One of two or more quantities that divides a given quantity without a remainder, e.g., 2 and 3 are factors.
Refactoring - A disciplined approach to rework for better design.
Software Engineering 1 Object-oriented Analysis and Design Chap 21 Test-Driven Development and Refactoring.
Refactoring Improving the structure of existing code Refactoring1.
Small changes to code to improve it. Refactoring Defined A change made to the internal structure of software to make it easier to understand and cheaper.
Refactoring (continued) Source: "Refactoring: Improving the Design of Existing Code", Martin Fowler.
Refactoring1 Refactoring DEPARTMENT OF COMPUTER SCIENCE AND SOFTWARE ENGINEERING CONCORDIA UNIVERSITY February 6, 2009.
Refactoring An Automated Tool for the Tiger Language Leslie A Hensley
1 Software Maintenance and Evolution CSSE 575: Session 3, Part 1 Simplifying Conditionals Steve Chenoweth Office Phone: (812) Cell: (937)
Refactoring1 Improving the structure of existing code.
Informatics 122 Software Design II
Software Engineering CS3003 Lecture 4 Code bad smells and refactoring.
Refactoring: Code Smells. Admin Notes REGISTER FOR BLACKBOARD Watch blackboard site for updates on class as hurricane season approaches.
Refactoring. Refactoring Overview  What is refactoring?  What are four good reasons to refactor?  When should you refactor?  What is a bad smell (relative.
Chapter 21 Test-Driven Development 1CS6359 Fall 2011 John Cole.
Refactoring 2. Admin Blackboard Quiz Acknowledgements Material in this presentation was drawn from Martin Fowler, Refactoring: Improving the Design of.
REFACTORINGREFACTORING. Realities Code evolves substantially during development Requirements changes 1%-4% per month on a project Current methodologies.
Refactoring II Dealing with Polymorphism. Switch in Rental Switches on Movie! class Rental … public double getCharge() { double result = 0; switch (getMovie().getPriceCode()){
Module 3. Smells Between Classes Course: Refactoring.
Com S 362: Object-Oriented Analysis and Design Refactoring.
1 Software Maintenance and Evolution CSSE 575: Session 2, Part 1 Refactoring Principles Steve Chenoweth Office Phone: (812) Cell: (937)
Software Construction and Evolution - CSSE 375 Making Method Calls Simpler Shawn and Steve Below – “Be the character!” The late acting teacher Lee Strasberg.
Refactoring Advanced Software Engineering Dr Nuha El-Khalili.
Refactoring. Mathematics: Factor ● fac·tor – One of two or more quantities that divides a given quantity without a remainder, e.g., 2 and 3 are factors.
Refactoring1 Improving the structure of existing code.
Pertemuan 12 Refactoring Mata kuliah: T0144 – Advanced Topics in Software Engineering Tahun: 2010.
Refactoring. 2 Process of changing a software system in such a way that it does not alter the external behavior of the code, yet improves its internal.
Software Construction and Evolution - CSSE 375 Simplifying Conditionals Shawn & Steve.
CSSE 375 Organizing Data – Part 1 Shawn and Steve Q1.
Refactoring. DCS – SWC 2 Refactoring ”A change made to the internal structure of software to make it easier to understand and cheaper to modify without.
Catalog of Refactoring (5) Simplifying Conditional Expressions.
Code Refactoring Milan Vukoje Soprex SkfOffice2 SkfOffice3 Big5 Quality oriented We are hiring…
Catalog of Refactoring (1) Composing Methods. Code Smells Long methods Dubious temporary variables Dubious methods.
Software Engineering 1 Object-oriented Analysis and Design Applying UML and Patterns An Introduction to Object-oriented Analysis and Design and Iterative.
A (Very) Simple Example Consolidate duplicate conditional fragments if (isSpecialDeal()) { total = price * 0.95; send (); } else { total = price * 0.98;
Principles and examples
Steve Chenoweth Office Phone: (812) Cell: (937)
Refactoring and Code Smells
Test-first development
Software Construction and Evolution - CSSE 375 Composing Methods
Refactoring III 27-Nov-18.
Code Smells 1.
Improving the structure of existing code
Refactoring and Code Smells
Refactoring III 25-Dec-18.
Test-Driven Development
Refactoring Strategies
Refactoring.
Refactoring and Code Smells
Advanced Programing practices
Test-Driven Development
Refactoring.
Refactoring and Code Smells
Presentation transcript:

NJIT 1 Test Driven Development and Refactoring Larman, Chapter 21

2 Test-First Programming eXtreme Programming and dX suggest that unit test code be written before coding is done. This promotes reliability, and constrains the code to the design. Often, tests are automated and rerun after every integration.

3 Test-First Benefits Unit tests actually get written Programmer satisfaction Interfaces and behavior are clear Provable verification Confidence to change code (refactoring)

4 Resources for Test Driven Development Larman recommends the xUnit family, including JUnit, as a good introductory unit test product. JUnit is integrated into some popular IDEs, including Eclipse, and is part of the SourceForge project. Get Eclipse at CruiseControl is a free open souce tool to rebuild applications and run the unit tests.

5 JUnit Example The next four slides are extracted from Using JUnit With Eclipse IDE, by A. Prohorenko and O. Prohorenko, at /04/juie.html 02/04/juie.html

6 Creating a JUnit test in Eclipse You open a project, navigate to the folder with the junit.jar file and open the jar.

7 JUnit test for Hello World import junit.framework.TestCase; public class TestThatWeGetHelloWorldPrompt extends TestCase { public TestThatWeGetHelloWorldPrompt( String name) { super(name); }

8 JUnit test for Hello World (2) public void testSay() { HelloWorld hi = new HelloWorld(); assertEquals("Hello World!", hi.say()); } public static void main(String[] args) { junit.textui.TestRunner.run( TestThatWeGetHelloWorldPrompt.class); }

9 Failed and Successful Tests

10 Refactoring Refactoring is changing a software system by improving its internal structure without changing its external behavior, i.e. it is a technique to restructure the code in a disciplined way. It makes the software easier to understand and cheaper to modify.

11 Continued… For a long time it was a piece of programmer lore, done with varying degrees of discipline by experienced developers, but not passed on in a coherent way. Refactoring is an overhead activity.

12 Where did Refactoring come from ? Two of the first people to recognize the importance of refactoring were Kent Beck and Ward Cunningham They worked with Smalltalk from the 80's onward. Refactoring has always been an important element in the Smalltalk community. Ralph Johnson's work with refactoring and frameworks has also been an important contribution.

13 Why Refactor ? Improves the design of software Without refactoring the design of the program will decay. Poorly designed code usually takes more to do the same things, often because the does the same thing in different places Easier to understand In most software development environments, somebody else will eventually have to read your code so it becomes easy for others to comprehend.

14 Continued… To find the bugs It helps in finding the Bugs present in the program. To program faster It helps us to do the coding/programming faster as we have better understanding of the situation.

15 When to Refractor ? When you add a function Helps you to understand the code you are modifying. Sometimes the existing design does not allow you to easily add the feature. When you need to fix a bug If you get a bug report its a sign the code needs refactoring because the code was not clear enough for you to see the bug in the first place.

16 Continued… When you do a Code Review - Code reviews help spread knowledge through the development team. - Works best with small review groups

17 Properties of Refactoring Preserve Correctness One step at a time Frequent Testing

18 Design Attributes Abstraction (information hiding) Flexibility Clarity Irredundancy

19 Steps to Refactoring Pareto analysis helps to identify heavily used or time consuming code. Refactoring begins by designing a solid set of tests for the section of code under analysis. Identify problems in code by review using bad smells of code. Introduce a refactoring and test.

20 Continued… The steps taken when applying the refactoring should be: - Small enough to oversee the consequences they have. - Reproduceable to allow others to understand them. - Generalized in a way, that they are more a rule that can be applied to any structure. - Written down to allow sharing these steps and to keep a reference, with step by step instructions how to apply them.

21 A few Refactorings Add Parameter Change Association Reference to value Value to reference Collapse hierarchy Consolidate conditionals Procedures to objects Decompose conditional Encapsulate collection Encapsulate downcast Encapsulate field Extract class Extract Interface Extract method Extract subclass Extract superclass Form template method Hide delegate Hide method Inline class Inline temp Introduce assertion Introduce explain variable Introduce foreign method

22 Refactoring examples Add a Parameter : When a method needs more information from its caller.

23 Continued.. Bi-directional Association to Unidirectional : We have a two-way association but one class no longer needs features from the other.

24 Continued… Change Reference to Value : When we have a reference object that is small, immutable, and awkward to manage.

25 Continued… Change Value to Reference : When we have a class with many equal instances that we want to replace with a single object.

26 Continued.. Collapse Hierarchy : As superclass and subclass are not very different.

27 Continued… Consolidate conditionals : double disabilityAmount() { if (_seniority < 2) return 0; if (_monthsDisabled > 12) return 0; if (_isPartTime) return // compute the disability amount double disabilityAmount() { if (isNotEligableForDisability()) return 0; // compute the disability amount

28 Continued… Decompose Conditionals : When we have a complicated conditional (if- then-else) statement. if (date.before (SUMMER_START) || date.after(SUMMER_END)) charge = quantity * _winterRate + _winterServiceCharge; else charge = quantity * _summerRate; if (notSummer(date)) charge = quantity * _winterRate + _winterServiceCharge; else charge = summerCharge (quantity);

29 Continued.. Encapsulate Collection : When a method returns a collection

30 Continued.. Encapsulate Downcast : When a method returns an object that needs to be downcasted by its callers. Object lastReading() { return readings.lastElement(); } Reading lastReading() { return (Reading) readings.lastElement(); }

31 Continued… Extract Class : When we have one class doing the work that should be done by two.

32 Continued… Extract Method : When we have a code fragment that can be grouped together. void printOwing() { printBanner(); //print details System.out.println ("name: " + _name); System.out.println ("amount " + getOutstanding()); } void printOwing() { printBanner(); printDetails(getOutstanding()); } void printDetails (double outstanding) { System.out.println ("name:" + _name); System.out.println ("amount:" + outstanding); }

33 Continued… Hide Delegate : When a client is calling a delegate class of an object.

34 Continued… Inline Class : When a class isn't doing very much.

35 Bad Smells in Code Duplicated Code Long Method Large Class Long Parameter List Divergent Change Shotgun Surgery Feature Envy Data Clumps Primitive Obsession Switch Statements Parallel Interface Hierarchies Lazy Class Speculative Generality Temporary Field Message Chains Middle Man Inappropriate Intimacy Incomplete Library Class Data Class Refused Bequest

36 Few solutions to Bad Smells Duplicated Code If you see the same code structure in more than one place, you can be sure that your program will be better if you find a way to unify them. solution: perform EXTRACT METHOD and invoke the code from both places. Long Method The longer a procedure is the more difficult it is to understand. solution: perform EXTRACT METHOD or Decompose Conditional or Replace Temp with Query.

37 Large class When a class is trying to do too much, it often shows up as too many instance variables. solution: perform EXTRACT CLASS or SUBCLASS Long Parameter List With objects you don't need to pass in everything the method needs, instead you pass in enough so the method can get to everything it needs solution: Use REPLACE PARAMETER with METHOD when you can get the data in one parameter by making a request of an object you already know about.

38 Shotgun Surgery This situation occurs when every time you make a kind of change, you have to make a lot of little changes to a lot of different classes. solution: perform MOVE METHOD/FIELD or INLINE Class bring a whole bunch of behavior together. Feature Envy It is a method that seems more interested in a class other in the one that it is in. solution: perform MOVE METHOD or EXTRACT METHOD on the jealous bit and get it home.

39 Switch Statements They are generally scattered throughout a program. If you add or remove a clause in one switch, you often have to find and repair the others too. solution: Use EXTRACT METHOD to extract the switch statement and then MOVE METHOD to get it into the class where the polymorphism is needed.

40 Benefits of Refactoring Refactoring is useful to any program that has at least one of the following shortcomings: Programs that are hard to read are hard to modify. Programs that have duplicate logic are hard to modify

41 Continued… Programs that require additional behavior that requires you to change running code are hard to modify. Programs with complex conditional logic are hard to modify.

42 Refactoring Risks Introducing a failure with refactoring can have serious consequences. When done on a system that is already in production, the consequences of introducing bugs without catching them are very severe.

43 Costs of Refactoring Language / Environment : Depends on how well the operations on the source code are supported. But in general the cost of applying the basic text modifications should be bearable. Testing : Relies heavily on testing after each small step and having a solid test suite of unit tests for the whole system substantially reduces the costs which would be implied by testing manually

44 Continued… Documentation : Costs of updating documentation of the project should not be underestimated as applying refactorings involves changes in interfaces, names, parameter lists and so on. All the documentation concerning these issues must be updated to the current state of development.

45 Continued… System : The tests covering the system need an update as well as the interfaces and responsibilities change. These necessary changes can contribute to higher costs as tests are mostly very dependent on the implementation.

46 When to put Off Refactoring ? Concerned code is neither able to compile or to run in a stable manner, it might be better to throw it away and rewrite the software from scratch. When a deadline is very close. Then it would take more time to do the refactoring than the deadline allows.