@isTest private class LoanerReminderSubmitLostBatchForTrTest { @isTest static void testDetail1() { bp3_Setting__c conf = bp3_Setting__c.getOrgDefaults(); conf.BJ_Start_Inventory_User__c = UserInfo.getUserId(); conf.Reminder_Submit_Lost__c = null; insert conf; ControllerUtil.EscapeNFM001Trigger = true; SS_Batch_Column_Mapping__c InventoryHeaderName = new SS_Batch_Column_Mapping__c(Name = 'Inventory_Header_Name', SS_TableName__c='Inventory_Header_Name'); InventoryHeaderName.From_Column_001__c = '北京 备品中心'; InventoryHeaderName.SS_Column_001__c = 'BJ'; InventoryHeaderName.From_Column_002__c = '上海 备品中心'; InventoryHeaderName.SS_Column_002__c = 'SH'; InventoryHeaderName.From_Column_003__c = '广州 备品中心'; InventoryHeaderName.SS_Column_003__c = 'GZ'; insert new SS_Batch_Column_Mapping__c[] {InventoryHeaderName}; // User thisUser = [Select Id from User where Id =: UserInfo.getUserId()]; System.runAs(new User(Id = UserInfo.getUserId())) { // 省 Address_Level__c al = new Address_Level__c(); al.Name = '東京'; al.Level1_Code__c = 'CN-99'; al.Level1_Sys_No__c = '999999'; insert al; // 市 Address_Level2__c al2 = new Address_Level2__c(); al2.Level1_Code__c = 'CN-99'; al2.Level1_Sys_No__c = '999999'; al2.Level1_Name__c = '東京'; al2.Name = '渋谷区'; al2.Level2_Code__c = 'CN-9999'; al2.Level2_Sys_No__c = '9999999'; al2.Address_Level__c = al.id; insert al2; // 病院を作る Account hospital = new Account(); hospital.recordtypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Account' and DeveloperName = 'HP'].id; hospital.Name = 'test hospital'; hospital.Is_Active__c = '有効'; hospital.Attribute_Type__c = '卫生部'; hospital.Speciality_Type__c = '综合医院'; hospital.Grade__c = '一级'; hospital.OCM_Category__c = 'SLTV'; hospital.Is_Medical__c = '医疗机构'; hospital.State_Master__c = al.id; hospital.City_Master__c = al2.id; hospital.Town__c = '东京'; insert hospital; StaticParameter.EscapeAccountTrigger = true; // 戦略科室を得る Account[] strategicDep = [SELECT ID, Name FROM Account WHERE parentId = :hospital.Id AND recordType.DeveloperName = 'Department_Class_OTH']; // 診療科を作る Account dep = new Account(); dep.recordtypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Account' and DeveloperName = 'Department_OTH'].id; dep.Name = 'test dep1'; dep.AgentCode_Ext__c = System.Label.Account_Asset_FJZ; dep.ParentId = strategicDep[0].Id; dep.Department_Class__c = strategicDep[0].Id; dep.Hospital__c = hospital.Id; Account dep1 = new Account(); dep1.recordtypeId = dep.recordtypeId; dep1.Name = 'test dep1'; dep1.AgentCode_Ext__c = System.Label.Account_Asset; dep1.ParentId = strategicDep[0].Id; dep1.Department_Class__c = strategicDep[0].Id; dep1.Hospital__c = hospital.Id; insert new Account[]{dep, dep1}; // 产品 Product2 pro1 = new Product2(Name='CLH-250:内窥镜冷光源',IsActive=true,Family='GI', Fixture_Model_No__c='CLH-250',Serial_Lot_No__c='S/N tracing', Fixture_Model_No_T__c = 'CLH-250', Asset_Model_No__c = 'Pro1', ProductCode_Ext__c='4604362',Manual_Entry__c=false); Product2 pro2 = new Product2(Name='电源线',IsActive=true,Family='GI', Fixture_Model_No__c='电源线',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = '电源线', Asset_Model_No__c = 'Pro2', ProductCode_Ext__c='BP900003',Manual_Entry__c=false); Product2 pro3 = new Product2(Name='MAJ-1933:数字调光电缆',IsActive=true,Family='GI', Fixture_Model_No__c='MAJ-1933',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'MAJ-1933', Asset_Model_No__c = 'Pro3', ProductCode_Ext__c='N3647100',Manual_Entry__c=false); insert new Product2[] {pro1, pro2, pro3}; // 保有设备 主机 Asset asset1 = new Asset(Asset_Owner__c = 'Olympus'); asset1.RecordTypeId = System.Label.Asset_RecordType; asset1.SerialNumber = 'asset1'; asset1.Name = 'asset1'; asset1.AccountId = dep.Id; asset1.Department_Class__c = strategicDep[0].Id; asset1.Hospital__c = hospital.Id; asset1.Product2Id = pro1.Id; asset1.Quantity = 10; asset1.Status = '不明'; asset1.Manage_type__c = '个体管理'; asset1.Loaner_accsessary__c = false; asset1.Out_of_wh__c = 0; asset1.Salesdepartment__c = '1.华北营业本部'; asset1.Internal_asset_location__c = '北京 备品中心'; asset1.Product_category__c = 'GI'; asset1.Equipment_Type__c = '产品试用'; asset1.SalesProvince__c = '北京'; asset1.CompanyOfEquipment__c = '北京'; asset1.Internal_Asset_number__c = '0001'; asset1.Rental_Count__c = 0; asset1.AssetManageConfirm__c = true; Asset asset2 = new Asset(Asset_Owner__c = 'Olympus'); asset2.RecordTypeId = System.Label.Asset_RecordType; asset2.SerialNumber = 'asset2'; asset2.Name = 'asset2'; asset2.AccountId = dep.Id; asset2.Department_Class__c = strategicDep[0].Id; asset2.Hospital__c = hospital.Id; asset2.Product2Id = pro2.Id; asset2.Quantity = 10; asset2.Status = '不明'; asset2.Manage_type__c = '数量管理'; asset2.Loaner_accsessary__c = true; //附属品 asset2.Out_of_wh__c = 0; asset2.Salesdepartment__c = '1.华北营业本部'; asset2.Internal_asset_location__c = '北京 备品中心'; asset2.Product_category__c = 'GI'; asset2.Equipment_Type__c = '产品试用'; asset2.SalesProvince__c = '北京'; asset2.CompanyOfEquipment__c = '北京'; asset2.Internal_Asset_number__c = '0002'; asset2.Rental_Count__c = 0; asset2.AssetManageConfirm__c = true; insert new Asset[] {asset1, asset2}; List assetList = [select Name from Asset]; System.assertEquals(2, assetList.size()); //调拨申请 TransferApply__c raObj = new TransferApply__c(); raObj.Name = 'testra'; raObj.From_Location__c = '北京'; raObj.Destination_Location__c = '北京 备品中心'; raObj.RecordTypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'TransferApply__c' and DeveloperName = 'AgencyToCenter'].id; insert raObj; // 调拨一览 TransferApplySummary__c raesObj = new TransferApplySummary__c(); raesObj.TransferApply__c = raObj.Id; raesObj.Cancel_Select__c = false; raesObj.IndexFromUniqueKey__c = 1; insert raesObj; //调拨申请一览明细 //状态 待移至报废区 主机 TransferApplyDetail__c raesdObj1 = new TransferApplyDetail__c(); raesdObj1.TransferApply__c = raObj.Id; raesdObj1.TransferApplySummary__c = raesObj.Id; raesdObj1.IndexFromUniqueKey__c = 1; raesdObj1.FSD_OneToOneAccessory_Cnt__c = 1; raesdObj1.ApplyPersonAppended__c = false; raesdObj1.TransferCount__c = 1; raesdObj1.FSD_SortInt__c = 01; raesdObj1.Asset__c = asset1.Id; raesdObj1.Main_OneToOne__c = true; //主机 raesdObj1.Salesdepartment_After__c = '1.华北营业本部'; raesdObj1.OneToOneAccessory__c = false; raesdObj1.StockDown__c = true; raesdObj1.StockDown_staff__c = UserInfo.getUserId(); raesdObj1.StockDown_time__c = Datetime.now(); raesdObj1.Pre_inspection_time__c = Datetime.now(); raesdObj1.Inspection_staff__c = UserInfo.getUserId(); raesdObj1.Inspection_result__c = 'OK'; raesdObj1.Inspection_result_after__c = 'NG'; raesdObj1.Inspection_result_after_ng__c = '废弃'; raesdObj1.Lost_item_giveup__c = false; raesdObj1.Check_lost_Item_Final__c = '欠品'; raesdObj1.Loaner_Giveup_Time__c = System.now(); raesdObj1.ArrivalResult__c = 'OK'; //附属品 欠品 TransferApplyDetail__c raesdObj2 = new TransferApplyDetail__c(); raesdObj2.TransferApply__c = raObj.Id; raesdObj2.TransferApplySummary__c = raesObj.Id; raesdObj2.IndexFromUniqueKey__c = 2; raesdObj2.FSD_OneToOneAccessory_Cnt__c = 1; raesdObj2.ApplyPersonAppended__c = false; raesdObj2.TransferCount__c = 1; raesdObj2.FSD_SortInt__c = 02; raesdObj2.Asset__c = asset2.Id; raesdObj2.OneToOneAccessory__c = true; raesdObj2.StockDown__c = true; raesdObj2.StockDown_staff__c = UserInfo.getUserId(); raesdObj2.StockDown_time__c = Datetime.now(); raesdObj2.Pre_inspection_time__c = Datetime.now(); raesdObj2.Inspection_staff__c = UserInfo.getUserId(); raesdObj2.Inspection_result__c = 'OK'; raesdObj2.Lost_item_giveup__c = false; raesdObj2.Loaner_Giveup_Time__c = System.now(); raesdObj2.OnStock_By_Cancel__c = false; raesdObj2.Check_lost_Item_Final__c ='欠品'; raesdObj2.Loaner_accsessary__c = true; raesdObj2.Confirm_Lost_Date__c = null; raesdObj2.ArrivalResult__c = 'OK'; insert new TransferApplyDetail__c[] {raesdObj1,raesdObj2}; //调拨申请 TransferApply__c raObj1 = new TransferApply__c(); raObj1.Name = 'test0001'; raObj1.From_Location__c = '北京 备品中心'; raObj1.Destination_Location__c = '北京'; raObj1.RecordTypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'TransferApply__c' and DeveloperName = 'CenterToAgency'].id; raObj1.Status_Text__c = '草案中'; insert raObj1; // 调拨一览 TransferApplySummary__c raesObj1 = new TransferApplySummary__c(); raesObj1.TransferApply__c = raObj1.Id; raesObj1.Cancel_Select__c = false; raesObj1.IndexFromUniqueKey__c = 1; insert raesObj1; //调拨申请一览明细 //状态 待移至报废区 主机 TransferApplyDetail__c raesdObj5 = new TransferApplyDetail__c(); raesdObj5.TransferApply__c = raObj1.Id; raesdObj5.TransferApplySummary__c = raesObj1.Id; raesdObj5.Return_DeliverySlip__c = null; raesdObj5.Check_lost_Item_Final__c = '欠品'; raesdObj5.OneToOneAccessory__c = true; raesdObj5.ArrivalResult__c = 'OK'; raesdObj5.Main_OneToOne__c = true; raesdObj5.Confirm_Lost_Date__c = null; raesdObj5.Lost_item_giveup__c = false; raesdObj5.Loaner_Giveup_Time__c = System.now(); raesdObj5.Loaner_accsessary__c = true; raesdObj5.IndexFromUniqueKey__c = 2; raesdObj5.FSD_OneToOneAccessory_Cnt__c = 1; raesdObj5.ApplyPersonAppended__c = false; raesdObj5.TransferCount__c = 1; raesdObj5.FSD_SortInt__c = 02; raesdObj5.Asset__c = asset2.Id; raesdObj5.StockDown__c = true; raesdObj5.StockDown_staff__c = UserInfo.getUserId(); raesdObj5.StockDown_time__c = Datetime.now(); raesdObj5.Pre_inspection_time__c = Datetime.now(); raesdObj5.Inspection_staff__c = UserInfo.getUserId(); raesdObj5.Inspection_result__c = 'OK'; raesdObj5.OnStock_By_Cancel__c = false; TransferApplyDetail__c raesdObj6 = new TransferApplyDetail__c(); raesdObj6.TransferApply__c = raObj1.Id; raesdObj6.TransferApplySummary__c = raesObj1.Id; raesdObj6.Return_DeliverySlip__c = null; raesdObj6.Check_lost_Item_Final__c = '欠品'; raesdObj6.OneToOneAccessory__c = true; raesdObj6.ArrivalResult__c = 'OK'; raesdObj6.Main_OneToOne__c = true; raesdObj6.Confirm_Lost_Date__c = null; raesdObj6.Lost_item_giveup__c = false; raesdObj6.Loaner_Giveup_Time__c = System.now(); raesdObj6.Loaner_accsessary__c = true; raesdObj6.IndexFromUniqueKey__c = 2; raesdObj6.FSD_OneToOneAccessory_Cnt__c = 1; raesdObj6.ApplyPersonAppended__c = false; raesdObj6.TransferCount__c = 1; raesdObj6.FSD_SortInt__c = 02; raesdObj6.Asset__c = asset2.Id; raesdObj6.StockDown__c = true; raesdObj6.StockDown_staff__c = UserInfo.getUserId(); raesdObj6.StockDown_time__c = Datetime.now(); raesdObj6.Pre_inspection_time__c = Datetime.now(); raesdObj6.Inspection_staff__c = UserInfo.getUserId(); raesdObj6.Inspection_result__c = 'OK'; raesdObj6.OnStock_By_Cancel__c = false; insert raesdObj6; List tsList = [select id,Number_of_NG_received__c from TransferApplySummary__c ]; List dlist = [select id,RecordType_F__c,TAESD_Status__c,Return_DeliverySlip__c,Check_lost_Item_F__c,OneToOneAccessory__c,ArrivalResult__c,Lost_item_check_day_F__c,TransferApplySummary__c,TransferApplyDetail__c.TransferApplySummary__r.Number_of_NG_received__c from TransferApplyDetail__c]; for (TransferApplySummary__c d : tsList) { System.debug('33333:::'+d.Number_of_NG_received__c ); } Database.executeBatch(new LoanerReminderSubmitLostBatchForTr()); } } }