@IsTest public with sharing class RepairAndQISSendToETQBatchTest { @testSetup static void makeTestRepairAndQIS() { List rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '病院']; if (rectCo.size() == 0) { throw new ControllerUtil.myException('not found 病院 recodetype'); } List rectSct = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '戦略科室分類 消化科']; if (rectSct.size() == 0) { throw new ControllerUtil.myException('not found 戦略科室分類 呼吸科 recodetype'); } List rectDpt = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '診療科 消化科']; if (rectDpt.size() == 0) { throw new ControllerUtil.myException('not found 診療科 消化科 recodetype'); } // テストデータ Account company = new Account(); company.RecordTypeId = rectCo[0].Id; company.Name = 'NFM105TestCompany'; upsert company; Account section = [Select Management_Code__c, Management_Code_Auto__c, Name, Id from Account where ParentId = :company.Id and RecordTypeId = :rectSct[0].Id]; Account depart = new Account(); depart.RecordTypeId = rectDpt[0].Id; depart.Name = '*'; depart.Department_Name__c = 'NFM105TestDepart'; depart.ParentId = section.Id; depart.Department_Class__c = section.Id; depart.Hospital__c = company.Id; upsert depart; // 再取得 // List accList = new List(); // company = [select Management_Code__c, Management_Code_Auto__c, Name, Id from Account where Id = :company.Id]; // accList.add(company); // accList.add(section); // depart = [select Management_Code__c, Management_Code_Auto__c, Name, Id from Account where Id = :depart.Id]; // accList.add(depart); List prdList = new List(); Product2 prd1 = new Product2(); prd1.ProductCode_Ext__c = 'NFM105Prd1'; prd1.ProductCode = 'NFM105Prd1'; prd1.Repair_Product_Code__c = 'NFM105Prd1_RP'; prd1.Name = 'NFM105Prd1'; prd1.Manual_Entry__c = false; prdList.add(prd1); Product2 prd2 = new Product2(); prd2.ProductCode_Ext__c = 'NFM105Prd2'; prd2.ProductCode = 'NFM105Prd2'; prd2.Repair_Product_Code__c = 'NFM105Prd2_RP'; prd2.Name = 'NFM105Prd2'; prd2.Manual_Entry__c = false; prdList.add(prd2); insert prdList; Asset ast = new Asset(); ast.Name = 'NFM105Ast1'; ast.AccountId = depart.Id; ast.Department_Class__c = section.Id; ast.Hospital__c = company.Id; ast.Product2Id = prd1.Id; ast.SerialNumber = 'NFM105SerialNumber'; ast.Guarantee_period_for_products__c = Date.today(); ast.InstallDate = Date.today(); insert ast; ast = [select Id, Name, Product_Serial_No__c, AccountId, Department_Class__c, Department_Class__r.Management_Code_Auto__c, Hospital__c, Product2Id, Product2.ProductCode, Product2.Repair_Product_Code__c, SerialNumber from Asset where Id = :ast.Id]; // User testUser = new User(); // testUser.Job_Category__c = '销售服务'; Repair__c rpr = new Repair__c(); rpr.SAPRepairNo__c = 'NFM105Rpr1'; rpr.Account__c = depart.Id; rpr.Department_Class__c = section.Id; rpr.Hospital__c = company.Id; rpr.Delivered_Product__c = ast.Id; rpr.Status__c = '1.受理完毕'; rpr.Incharge_Staff__c = Userinfo.getUserId(); rpr.Repair_Detail__c = 'test'; rpr.GeneratedPDFField__c = null; // rpr.SAP_Transfer_time__c = Datetime.now(); rpr.SAP_Transfer_time__c = Date.newInstance(2021, 10, 10); rpr.AsyncData__c = false; rpr.Repair_Shipped_Date__c = Date.today(); rpr.ifDeadHurt__c = '无'; rpr.PAE_Determine__c = 'nonPAE'; rpr.PAE_DetermineAC__c = 'nonPAE'; rpr.Complaint_Number__c = null; rpr.PAE_reappear_confirm__c = '21'; rpr.ASReportedCodeAC__c = '1233'; insert rpr; QIS_Report__c qr = new QIS_Report__c( RC__c = UserInfo.getUserId(), // Photo_1__c = '用户添加的图片', Damage_For_Doc_Or_Pat__c = '有', Relation_With_The_Problem__c = '有可能', Report_For_Goz__c = '不知道', Name = 'QIS012345', GeneratedPDFField__c = null, QIS_Submit_day__c = Date.Today() ); insert qr; } @IsTest static void myTest(){ Repair__c res = [select id,name from Repair__c]; QIS_Report__c qis = [select id,name from QIS_Report__c]; System.debug('res++'+res); System.debug('qis++'+qis); Test.startTest(); Database.executeBatch(new RepairSendToETQBatch(null,null,null,'')); //update by rentx 2020-10-22 // Database.executeBatch(new QISSendToETQBatch()); Test.stopTest(); } @IsTest static void myTest2(){ Repair__c res = [select id,Name,ASReportedCodeAC__c,AE_DetermineResult__c,PAE_Determine__c,PAE_DetermineAC__c from Repair__c]; System.debug('res++'+res); System.debug('111111111111111111111111111111111111111111111111111::'+res); Test.startTest(); Database.executeBatch(new RepairSendToETQBatch(null,null,null,'',10)); //update by rentx 2020-10-22 // Database.executeBatch(new QISSendToETQBatch()); Test.stopTest(); } }