2

3 小时后我又回到了这里,没有对任何代码进行任何更改,测试执行工作正常。无视这个问题

我编写了一个触发器,该触发器非常适合根据外部 ID 在联系人记录上设置 accountID。

我有一个效果很好的测试,但我在触发器中添加了一些逻辑,因此它只更新使用“默认帐户”作为帐户的联系人。现在我的测试失败了,说它没有更新帐户,即使它在保存记录时仍然按设计工作。

我错过了什么?

我添加了第 4 行

ID DefaultAccID = [select ID from Account where Name = 'Default Account'].ID;

以及第 9 行附近的 if

if (contactNew.AccountID == DefaultAccID) {
}

触发:

trigger TRG_Contact_SetHouseholdID on Contact (before update, before insert) {
Set<String> AccIDlist = new Set<String>();
ID DefaultAccID = [select ID from Account where Name = 'Default Account'].ID;

// loop through records finding thoes that need to be linked
for(Contact contactNew:Trigger.New){
    if (contactNew.AccountID == DefaultAccID) {
        AccIDlist.add(contactNew.RPHouseholdID__c);
    }
}

Map<String, ID> AccountMap = new Map<String, ID>();

//loop needing linked and get account ID if it exist     
for(Account oneAccount:[SELECT RPHouseholdID__c, ID from Account where RPHouseholdID__c IN :AccIDlist]){
    AccountMap.put(oneAccount.RPHouseholdID__c, oneAccount.ID);
}

// loop through records updating the ones that need link
for(Contact contactNew:Trigger.New){
    if (AccountMap.get(contactNew.RPHouseholdID__c) <> null){
        contactNew.AccountID = AccountMap.get(contactNew.RPHouseholdID__c);
    }
}
}

测试类:

@isTest
Private class TRG_Contact_SetHouseholdID_Test {
static TestMethod void Test0_TestInsertWithValue(){
    insertTestAccounts();
    Account defaultAccount = [select ID from Account where name = 'Default Account' limit 1];
    Account newAccount = [select ID from Account where name = 'Camper Family' limit 1];
    test.startTest();
        insertTestContact(defaultAccount.ID);
    test.stopTest();
    Contact newContact = [select ID,AccountID from Contact where firstname = 'Happy' and lastname = 'Camper' limit 1];
    System.assertEquals(newContact.AccountID, newAccount.ID, 'accountID did not get changed from default (' + defaultAccount.ID + ')');
}

private static void insertTestAccounts()
{
    Account obj = new Account();
    obj.Name = 'Default Account';
    insert obj;
    obj = new Account() ;
    obj.Name = 'Camper Family';
    obj.RPHouseholdID__c = '111';
    insert obj;

}
private static void insertTestContact(ID defaultID)
{
    Contact obj = new Contact();
    obj.AccountID = defaultID;
    obj.firstName = 'Happy';
    obj.lastname = 'Camper';
    obj.RPHouseholdID__c = '111';
    insert obj;
}
}
4

2 回答 2

4

扩展一点@zachelrath 的回答,从 API 版本 24.0 开始,测试方法与组织中的数据隔离(除了一些例外用户、记录类型等,请参阅此处以获取完整列表)。与其更改文件的 API 版本,最简单的做法是将查看所有数据指令添加到 isTest 注释,如下所示:

@isTest(SeeAllData=true)
Private class TRG_Contact_SetHouseholdID_Test {
// etc
于 2012-06-04T22:00:30.487 回答
2

将您的测试类的 API 版本设置为 24.0 --- 我敢打赌,您对默认帐户的初始查询是在提取名称为“默认帐户”的预先存在的记录,而不是您在测试数据中创建的默认帐户. 有两种方法可以解决这个问题:

  1. (最简单)将您的测试类更改为 API 版本 24.0
  2. 如果您希望使用 API 23.0 或更低版本,那么在您的测试方法开始时,删除所有名为“默认帐户”的帐户,然后插入您的测试帐户。
于 2012-06-04T20:42:38.367 回答