function readOnly(count){ }
Starting November 20, the site will be set to read-only. On December 4, 2023,
forum discussions will move to the Trailblazer Community.
+ Start a Discussion
nallurisivashankarnallurisivashankar 

Test class for batch apex

Hi,

 

I have created batch class, but i am facing problem during code coverage.

can any one tell me how to write test class?

 

here is my class:

 

global class expireNotify implements Database.Batchable<sObject>
{
    global Database.QueryLocator start(Database.BatchableContext bc)
    {
        Date d = Date.today();
        String soql = 'SELECT Expiry_Date__c, Name, Email_Address__c FROM Member__c WHERE Expiry_Date__c =: d';
        return Database.getQueryLocator(soql);
    }
   
    global void execute(Database.BatchableContext bc, List<Member__c> recs)
    {
        List<Messaging.SingleEmailMessage> mailList = new List<Messaging.SingleEmailMessage>();
        for(Member__c m : recs)
        {
            List<String> toAddresses = new List<String>();           
            Messaging.SingleEmailMessage mail = new Messaging.SingleEmailMessage();
            toAddresses.add(m.Email_Address__c);
            mail.setToAddresses(toAddresses);
            mail.setSubject('Welcome to Sweet 16 Siebel Batch');
            String messageBody = '<html><body>Hi ' + m.Name + ',<br>Your account Expires today. <br>Kindly contact your administrator.<br><br><b>Regards,</b><br>Magulan D</body></html>';
            mail.setHtmlBody(messageBody); 
            mailList.add(mail);          
        } 
        Messaging.sendEmail(mailList);
    }
   
    global void finish(Database.BatchableContext bc)
    {
    }
}

empucempuc

Hi,

 

Try smth like this.

 

 

@isTest
public class TestExpireNotify {
static testMethod void testBatch(){

String soql = 'SELECT Expiry_Date__c, Name, Email_Address__c FROM Member__c WHERE Expiry_Date__c =: d';
Member__c nMember = new Member__c();
nMember.Expiry_Date__c = Date.today();
nMember.Name = 'testest';
//fill also other mandatory fields
insert nMember;

Test.startTest();
expireNotify batch = new expireNotify ();
ID batchprocessid = Database.executeBatch(batch, 1);
Test.stopTest();

System.assert(Limits.getEmailInvocations() == 1,'One email should be send');
}
}