Salesforce APEX - 测试上下文为相关对象返回null

时间:2012-05-25 18:30:04

标签: unit-testing salesforce apex-code soql

编写testMethod时,我无法检索相关的联系人字段。在下面的示例中,我希望最终的断言返回true。我正在测试的代码运行正常,select只在测试环境中失败。

为什么不从SOQL查询返回联系信息?

static testMethod void FailTest()
{
        Contact client = new Contact(FirstName='TestFirst1', LastName='TestFirst', BirthDate = Date.parse('01/01/1986'), Gender__c = 'Male');
        insert client;
        Opportunity opp = new Opportunity(Name = 'Test Opp' + Math.random(), CloseDate=Date.Today(), StageName='ASR - Case Design', Product_Types__c='UL', Face_Amount_Applied_For__c=500, Estimated_Target_Premium__c=1000, X1st_Client__r = client);
        insert opp;

        Opportunity selectOpp = [Select o.X1st_Client__r.LastName From Opportunity o WHERE o.Id = :opp.Id LIMIT 1];

        system.assertNotEquals(opp.X1st_Client__r.LastName, null); //true
        system.assertNotEquals(opp.Name, null); //true
        system.assertNotEquals(selectOpp.Name, null); //true
        system.assertNotEquals(selectOpp.X1st_Client__r.LastName, null); //false, should be true
}

1 个答案:

答案 0 :(得分:2)

我认为问题可能是您将机会与客户记录相关联的方式。你有X1st_Client__r =客户端,我认为你真正想要做的是X1st_Client__c = client.Id。我不认为插入DML会考虑X1st_Client__r中表示的对象。我认为在插入过程中只会注意X1st_Client__c值。