Showing posts with label Junit. Show all posts
Showing posts with label Junit. Show all posts

Junit tuorial | Junit concept | Junit tutorial step by step

Junit tutorial

  • The testing problems
  • The framework of JUnit
  • A case study
  • JUnit tool
  • Practices


 The testing problems
The framework of JUnit
A case study
JUnit tool
Practices

class Money {    

    private int fAmount;    
    private String fCurrency;
public Money(int amount, String currency) {
         fAmount= amount;        
         fCurrency= currency;      }
public int amount() {         return fAmount;     }
    
    public String currency() {         return fCurrency;     }


public Money add(Money m) {    
        return new Money(amount()+m.amount(), currency()); }
    }




public class MoneyTest extends TestCase {    
//…    
   public void testSimpleAdd() {        

         Money m12CHF= new Money(12, "CHF");  // (1)        

         Money m14CHF= new Money(14, "CHF");
                
         Money expected= new Money(26, "CHF");
        
         Money result=  m12CHF.add(m14CHF);    // (2)
        
         Assert.assertTrue(expected.equals(result));     // (3)    
    }
}
      (1) Creates the objects we will interact with during the test. This    testing context is commonly referred to as a test's fixture. All we need for the testSimpleAdd test are some Money objects.
     (2) Exercises the objects in the fixture.
     (3) Verifies the result



assertEquals(expected, actual)
assertEquals(message, expected, actual)
assertEquals(expected, actual, delta)
assertEquals(message, expected, actual, delta)
assertFalse(condition)
assertFalse(message, condition)
Assert(Not)Null(object)
Assert(Not)Null(message, object)
Assert(Not)Same(expected, actual)
Assert(Not)Same(message, expected, actual)
assertTrue(condition)
assertTrue(message, condition)

setUp()
       Storing the fixture's objects in instance variables of your TestCase subclass and initialize them by overriding the setUp method

tearDown()
       Releasing the fixture’s

run()
       Defining how to run an individual test case.
       Defining how to run a test suite.

testCase()

public class MoneyTest extends TestCase {    
     private Money f12CHF;    
     private Money f14CHF;
       
     protected void setUp() {        
           f12CHF= new Money(12, "CHF");        
           f14CHF= new Money(14, "CHF");     }
 
     public void testSimpleAdd() {    
           Money expected= new Money(26, "CHF");    
           Money result= f12CHF.add(f14CHF);    
           Assert.assertTrue(expected.equals(result)); }

    TestCase test= new MoneyTest("simple add") {    
           public void runTest() {         testSimpleAdd();     }
    }
}
The real world scenarios
The number boundaries
Smaller than 0 such as –1, -2, …, -100, …
0
Bigger than 0 such as 1, 2, …, 100…
class Money {    

    private int fAmount;    
    private String fCurrency;   

public Money(int amount, String currency) {
         fAmount= amount;        
         fCurrency= currency;      }
public int amount() {         return fAmount;     }
    
    public String currency() {         return fCurrency;     }

public Money add(Money m) {
        if (m.amount()<=0) throw exception;    
        return new Money(amount()+m.amount(), currency());
}
}
TestCase test= new MoneyTest("simple add")
{    
    public void runTest() {        
         testSimpleAdd();    
    }
}

public static Test suite() {    
    TestSuite suite= new TestSuite();    
    suite.addTest(new MoneyTest("testEquals"));    
    suite.addTest(new MoneyTest("testSimpleAdd"));    
    return suite;
}



JUnit supports two ways of running single tests:
static
dynamic

TestCase test= new MoneyTest("simple add")
{    
    public void runTest() {        
         testSimpleAdd();    
    }
}


TestCase test= new MoneyTest("testSimpleAdd");

Since JUnit 2.0 there is an even simpler dynamic way. You only pass the class with the tests to a TestSuite and it extracts the test methods automatically.

public static Test suite() {  return new TestSuite(MoneyTest.class); }
1. Download the latest version of JUnit from http://download.sourceforge.net/junit/
2. Installation
unzip the junit.zip file
add junit.jar to the CLASSPATH. For example: set classpath=%classpath%;INSTALL_DIR\junit3\junit.jar
3. Testing
           Test the installation by using either the batch or the graphical TestRunner tool to run the tests that come with this release. All the tests should pass OK.
for the batch TestRunner type:     java junit.textui.TestRunner junit.samples.AllTests
for the graphical TestRunner type:     java junit.awtui.TestRunner junit.samples.AllTests
for the Swing based graphical TestRunner type:     java junit.swingui.TestRunner junit.samples.AllTests

Notice: The tests are not contained in the junit.jar but in the installation directory directly. Therefore make sure that the installation directory is on the class path

Important: Don't install the junit.jar into the extension directory of your JDK installation.
If you do so the test class on the files system will not be found. JUnit plug-in for Eclipse