Friday, March 9, 2012

Unit Testing in Salesforce

Testing is a key and critical component to successful long term software development process. Salesforce.com strongly recommends using a test-driven development process which occurs at the same time as code development. Salesforce has very strong set of documentation. When I was learning salesforce unit testing, I realize that it is difficult to understand where to start read. Therefore, I summarized the unit testing for salesforce beginners to understand the basic aspects of unit testing.

There are few things to consider before you deploy or upload the code or package;
  • 75% of your Apex code must be covered by unit tests
  • All the tests must complete successfully
  • Every trigger has some test coverage (1%)
  • All classes and triggers must compile successfully
When you are writing a test class, you have to write test for Single Action, Bulk Action, Positive Behavior, Negative Behavior, and Restricted User.
  • Single Action :Test to verify that a single record produces the correct, expected result.
  • Bulk Action :  Test not only the single record case, but the bulk cases as well
  • Positive Behavior :  Verify that the expected behavior occurs through every expected permutation
  • Negative Behavior :  Verify that the error messages are correctly produced 
  • Restricted User :Test whether a user with restricted access to the sObjects used in     your code sees the expected behavior 
Test Class can be defined @isTest annotation. Before the Winter 12’ release we had only private test classes, but on Winter 12’ release salesforce has given the chance to write public test classes as well. Salesforce has released the public test classes for expose common methods for data creation. It can be used to setting up data that the tests need to run against. Public test methods can be called from a running test but not from a non-test request.

When you create a test method,
  • Use static
  • Use testMethod keyword 
  • Use void return type
  • No any arguments
  • No data changes performed in a test method
  • Don’t send emails
  • Cannot be used to test Web service callout because web services are asynchronous and tests are synchronous.
    • The API for asynchronous test runs is a Beta release (Winter ‘12)
    • For More : Force.com Apex code Developer’s Guide Page 153 
The key methods to use in your unit tests are the system.assert() methods. There are three types of system.assert() methods.
  • System.assert(condition)
  • System.assertEquals(x,y)
  • System.assertNotEquals(x,y)
For the security review, every test method must have at least one system.assert() method. We need use assert methods not only for the pass the security review but also as a best practice. It will be help us to keep track the failures of Apex classes or triggers.

Structure of the Test Class
@isTest

private classTest_class
{
    public static testMethodvoid test_name()
    {
       //code_block;
    }
}
Structure of public Test class for test data creation 
@isTest
public class TestUtil
{
    public static void createTestAccounts() 
    {
      // Create some test accounts
    }

    public static void createTestContacts()
    {
      // Create some test contacts
    }
}

3 comments:

  1. Hey Chamil,

    I am new apex and visualforce. I have simple question. Why we write "static" keyword for test methods.

    Thanks in advance.

    ReplyDelete
  2. because you do not chnage

    ReplyDelete
  3. Test methods are static so that they can be executed or called by using their class name. Static method can be access directly by using their class name.

    ReplyDelete