You need to sign in to do that
Don't have an account?
Josh Harsh
Apex Class For Full Coverage of Trigger
Hello,
Below are a trigger and its test class. Understanding that the coverage needs to be 75% in order to send it to production, I seem to be stuck with my code, and I am hoping that someone may be able to push me in the right direction.
trigger updatezipcode on Account (before update, before insert) {
List<String> BillingPostalCodes = new List<String>();
for (Account a:Trigger.new){
BillingPostalCodes.add(a.BillingPostalCode.substring(0,5));
}
List <Zip_Code__c> ZipCodeList = [Select ID, Name from Zip_Code__c where Name in :BillingPostalCodes];
for (Integer i = 0; i <Trigger.new.size(); i++){
if (ZipCodeList.size() > 0 && Trigger.new[i].BillingPostalCode.substring(0,5) !=null){
for (Zip_Code__c z:ZipCodeList){
if (Trigger.new[i].BillingPostalCode.substring(0,5) == z.name){
Trigger.new[i].Zip_Code_Territory__c = z.ID;
}
}
}
else{
Trigger.new[i].Zip_Code_Territory__c = null;
}
}
}
@isTest
private class TestZip {
static testMethod void testZipChange() {
Account[] Accounttest = new Account[]{
new Account(Name ='Tester1', BillingPostalCode = '44281'),
new Account(Name ='Tester2', BillingPostalCode = '44282'),
new Account(Name ='Tester3', BillingPostalCode = '44283'),
new Account(Name ='Tester4', BillingPostalCode = '44284'),
new Account(Name ='Tester5', BillingPostalCode = '44285'),
new Account(Name ='Tester6', BillingPostalCode = '44286',OwnerId = '005C0000006nFc6')
};
insert Accounttest;
Test.startTest();
Accounttest[0].BillingPostalCode = '44281';
update Accounttest;
Test.stopTest();
Accounttest = [SELECT id, BillingPostalCode, Zip_Code_Territory__c FROM Account WHERE id IN:Accounttest];
}
}
The bolded area in the trigger is what is not covered in the class.
Thank you for any help!
Below are a trigger and its test class. Understanding that the coverage needs to be 75% in order to send it to production, I seem to be stuck with my code, and I am hoping that someone may be able to push me in the right direction.
trigger updatezipcode on Account (before update, before insert) {
List<String> BillingPostalCodes = new List<String>();
for (Account a:Trigger.new){
BillingPostalCodes.add(a.BillingPostalCode.substring(0,5));
}
List <Zip_Code__c> ZipCodeList = [Select ID, Name from Zip_Code__c where Name in :BillingPostalCodes];
for (Integer i = 0; i <Trigger.new.size(); i++){
if (ZipCodeList.size() > 0 && Trigger.new[i].BillingPostalCode.substring(0,5) !=null){
for (Zip_Code__c z:ZipCodeList){
if (Trigger.new[i].BillingPostalCode.substring(0,5) == z.name){
Trigger.new[i].Zip_Code_Territory__c = z.ID;
}
}
}
else{
Trigger.new[i].Zip_Code_Territory__c = null;
}
}
}
@isTest
private class TestZip {
static testMethod void testZipChange() {
Account[] Accounttest = new Account[]{
new Account(Name ='Tester1', BillingPostalCode = '44281'),
new Account(Name ='Tester2', BillingPostalCode = '44282'),
new Account(Name ='Tester3', BillingPostalCode = '44283'),
new Account(Name ='Tester4', BillingPostalCode = '44284'),
new Account(Name ='Tester5', BillingPostalCode = '44285'),
new Account(Name ='Tester6', BillingPostalCode = '44286',OwnerId = '005C0000006nFc6')
};
insert Accounttest;
Test.startTest();
Accounttest[0].BillingPostalCode = '44281';
update Accounttest;
Test.stopTest();
Accounttest = [SELECT id, BillingPostalCode, Zip_Code_Territory__c FROM Account WHERE id IN:Accounttest];
}
}
The bolded area in the trigger is what is not covered in the class.
Thank you for any help!
Due to this ZipCodeList may be null & the for loop for it might not be covered.
I did create a class that creates Zip Codes too, off the Zip_Code__c object. See below.
@isTest
private class TestAddZip {
static testMethod void testAddZipChange() {
Zip_Code__c[] Ziptest = new Zip_Code__c[]{
new Zip_Code__c(Name = '44281'),
new Zip_Code__c(Name = '44282'),
new Zip_Code__c(Name = '44283'),
new Zip_Code__c(Name = '44284'),
new Zip_Code__c(Name = '44285'),
new Zip_Code__c(Name = '44286',OwnerId = '005C0000006nFc6')
};
insert Ziptest;
Test.startTest();
Ziptest[0].Name = '44281';
update Ziptest;
Test.stopTest();
}
}
Its basically the same as the previous class only related to the Zip_Code__c object.
For every test method data needs to be created, creating it in one will not make it available in other test method.
Thanks.
Adding lines would help but that is not a good thing to do !