Close
Register
Close Window

CS3 Coursenotes

Chapter 5 Week 6

Show Source |    | About   «  5.2. Tries   ::   Contents   ::   6.1. Sorting Part 1  »

5.3. Over-Constrained Code

5.3.1. Over-Constrained Code

5.3.1.1. Over-constrained Code (1)

  • Consider the situation where we have two points. We want to know which quadrant the second point (b) is in w.r.t. the first point (a):

    if ((b.x < a.x) && (b.y < a.y))
      doNW();
    else if ((b.x < a.x) && (b.y >= a.y))
      doSW();
    else if ((b.x >= a.x) && (b.y < a.y))
      doNE();
    else if ((b.x >= a.x) && (b.y >= a.y))
      doSE();
    
  • This has the virtue of being quite logical and clear. However, it has some problems.

5.3.1.2. Over-constrained Code (2)

  • It is horribly inefficient, compared to alternatives.

  • But our real concern has to do with testing and code coverage.

  • Fact: No series of tests will cover all branches in this code.

  • Q: Why?

  • A: Consider every possible branch and see what can get triggered. Consider that there have to be at least 8+ branches, and only 4 possible inputs!!

  • Try to hit every branch by brute force, one at a time…

5.3.1.3. Over-constrained Code (3)

  • Q: If we want complete code coverage when there are only four logically distinct inputs, then we had better do what?

  • A: Come up with code that has only four branches!

5.3.1.4. Over-constrained Code (4)

  • Refactored code:

    if (b.x < a.x)
      if (b.y < a.y)
        doNW();
      else
        doSW();
    else
      if (b.y < a.y)
        doNE();
      else
        doSE();
    
  • Not only can you test every branch, but this is a lot more efficient! Every branch requires 2 tests!

   «  5.2. Tries   ::   Contents   ::   6.1. Sorting Part 1  »

Close Window