@isTest private class AutomaticAssignControllerTest { static testMethod void init() { Date toDate = Date.today(); Boolean userProfileCheck = false; // 获取从次月14日至再次月13日的日期 Integer currentYear = toDate.year(); Integer currentMonth = toDate.month() + 1; Integer mMonth = (currentMonth == 12) ? 1 : currentMonth + 1; Integer mNear = (currentMonth == 12) ? currentYear + 1 : currentYear; Date startDate = Date.newInstance(mNear, mMonth, 14); RecordType rectCam = [SELECT Id FROM RecordType WHERE IsActive = true AND SobjectType = 'Campaign' AND DeveloperName = 'ServiceEngineerTraining']; Campaign cam = new Campaign(); cam.Name = 'cam'; cam.Name2__c = '1234'; cam.RecordTypeId = rectCam.Id; cam.StartDate = Date.today().addDays(-15); cam.EndDate = Date.today().addDays(18); cam.Mailflg_after45__c = true; cam.Mailflg_cancel__c = true; cam.Mailflg_before15__c = true; cam.Mailflg_before7__c = true; cam.Mailflg_after3__c = true; insert cam; 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 = '东京'; hospital.TradeComplianceStatus__c = '警示名单'; insert hospital; Opportunity opp = new Opportunity( Name='Opp', StageName='引合', CloseDate=Date.today().addDays(10), Close_Forecasted_Date__c=Date.today(), CurrencyIsoCode = 'CNY' ); insert opp; OPDPlan__c oPDPlan = new OPDPlan__c(); oPDPlan.Status__c = '计划中'; oPDPlan.OPDPlan_ImplementDate__c = Date.today().addMonths(1); oPDPlan.NoOpp_Reason__c = 'HCP对应'; //无询价理由 oPDPlan.OPDLendSortDraft__c = 1; //备品借出优先度 oPDPlan.OPDType__c = '询价'; oPDPlan.Related_Opportunity1_ID__c = opp.Id; oPDPlan.OPDPlan_ImplementDate__c = startDate; oPDPlan.NoOpp_Reason__c = ''; insert oPDPlan; 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 dep'; dep.AgentCode_Ext__c = '9999998'; dep.ParentId = strategicDep[0].Id; dep.Department_Class__c = strategicDep[0].Id; dep.Hospital__c = hospital.Id; insert dep; // Contact contact2 = new Contact(); // contact2.AccountId = dep.Id; // contact2.FirstName = '責任者'; // contact2.LastName = 'test1经销商'; // insert contact2; Contact contact2 = new Contact(); contact2.AccountId = dep.Id; contact2.RecordTypeId = Schema.SObjectType.Contact.getRecordTypeInfosByDeveloperName().get('Agency').getRecordTypeId(); //contact2.FirstName = '責任者'; contact2.LastName = 'test1经销商'; contact2.Agency_User__c = true; insert contact2; Id userName = [SELECT Id, Name FROM User WHERE Name = '陈海山'].Id; Test.startTest(); //备品借出申请 // 产品 Product2 pro1 = new Product2(Name='name01',IsActive=true,Family='GI', Fixture_Model_No__c='n01',Serial_Lot_No__c='S/N tracing', Fixture_Model_No_T__c = 'n01',CountryOfOrigin__c = 'US', ProductCode_Ext__c='pc01',Manual_Entry__c=false); Product2 pro2 = new Product2(Name='name02',IsActive=true,Family='GI', Fixture_Model_No__c='n02',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'n02', ProductCode_Ext__c='pc02',Manual_Entry__c=false); Product2 pro3 = new Product2(Name='name03',IsActive=true,Family='SP', Fixture_Model_No__c='n03',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'n03', ProductCode_Ext__c='pc03',Manual_Entry__c=false); insert new Product2[] {pro1, pro2, pro3}; Asset assetA1 = new Asset(Asset_Owner__c = 'Olympus'); assetA1.RecordTypeId = System.Label.Asset_RecordType; assetA1.SerialNumber = 'ass01'; assetA1.Name = 'ass01'; assetA1.AccountId = dep.Id; assetA1.Department_Class__c = strategicDep[0].Id; assetA1.Hospital__c = hospital.Id; assetA1.Product2Id = pro1.Id; assetA1.Quantity = 1; assetA1.Main_OneToOne__c = true; assetA1.Status = '有库存'; assetA1.Manage_type__c = '个体管理'; assetA1.Loaner_accsessary__c = false; assetA1.Out_of_wh__c = 0; assetA1.Delete_Flag__c = False; assetA1.Consumable_Guaranteen_end__c = null; assetA1.Salesdepartment__c = '1.华北营业本部'; assetA1.Internal_asset_location__c = '北京 备品中心'; assetA1.Product_category__c = 'GI'; assetA1.Equipment_Type__c = '产品试用'; assetA1.SalesProvince__c = '北京'; assetA1.CompanyOfEquipment__c = '北京'; assetA1.Internal_Asset_number__c = '0001'; assetA1.WH_location__c = '货架号1'; // 保有设备A (附属品 数量管理) Asset assetA2 = new Asset(Asset_Owner__c = 'Olympus'); assetA2.RecordTypeId = System.Label.Asset_RecordType; assetA2.SerialNumber = 'ass02'; assetA2.Name = 'ass02'; assetA2.AccountId = dep.Id; assetA2.Department_Class__c = strategicDep[0].Id; assetA2.Hospital__c = hospital.Id; assetA2.Product2Id = pro2.Id; assetA2.Quantity = 10; assetA2.Status = '有库存'; assetA2.Manage_type__c = '数量管理'; assetA2.Loaner_accsessary__c = true; assetA2.Out_of_wh__c = 3; assetA2.Delete_Flag__c = False; assetA2.Consumable_Guaranteen_end__c = null; assetA2.Salesdepartment__c = '1.华北营业本部'; assetA2.Internal_asset_location__c = '北京 备品中心'; assetA2.Product_category__c = 'GI'; assetA2.Equipment_Type__c = '产品试用'; assetA2.SalesProvince__c = '北京'; assetA2.CompanyOfEquipment__c = '北京'; // 保有设备A (附属品 个体管理) Asset assetA3 = new Asset(Asset_Owner__c = 'Olympus'); assetA3.RecordTypeId = System.Label.Asset_RecordType; assetA3.SerialNumber = 'ass03'; assetA3.Name = 'ass03'; assetA3.AccountId = dep.Id; assetA3.Department_Class__c = strategicDep[0].Id; assetA3.Hospital__c = hospital.Id; assetA3.Product2Id = pro3.Id; assetA3.Quantity = 1; assetA3.Status = '有库存'; assetA3.Manage_type__c = '个体管理'; assetA3.Loaner_accsessary__c = true; assetA3.Out_of_wh__c = 0; assetA3.Delete_Flag__c = False; assetA3.Consumable_Guaranteen_end__c = null; assetA3.Salesdepartment__c = '1.华北营业本部'; assetA3.Internal_asset_location__c = '北京 备品中心'; assetA3.Product_category__c = 'GI'; assetA3.Equipment_Type__c = '产品试用'; assetA3.SalesProvince__c = '北京'; assetA3.CompanyOfEquipment__c = '北京'; insert new Asset[] {assetA1, assetA2, assetA3}; // 备品配套1(主体 两个附属品(个体管理 数量管理)) Fixture_Set__c fsObjA1 = new Fixture_Set__c(); fsObjA1.Name = 'set1'; fsObjA1.Fixture_Set_Body_Model_No__c = 'modelNo1'; fsObjA1.Loaner_name__c = 'name1'; insert fsObjA1; // 备品配套明细 Fixture_Set_Detail__c fsdObjA1 = new Fixture_Set_Detail__c(); fsdObjA1.Name = '备品配套明细名1'; fsdObjA1.Name_CHN_Created__c = '中文名称1'; fsdObjA1.Product2__c = pro1.Id; fsdObjA1.Fixture_Set__c = fsObjA1.Id; fsdObjA1.Is_Body__c = true; fsdObjA1.Is_Optional__c = false; fsdObjA1.UniqueKey__c = fsObjA1.Id + ':' + pro1.Id; fsdObjA1.SortInt__c = 1; // 备品配套明细 Fixture_Set_Detail__c fsdObjA2 = new Fixture_Set_Detail__c(); fsdObjA2.Name = '备品配套明细名2'; fsdObjA2.Name_CHN_Created__c = '中文名称2'; fsdObjA2.Product2__c = pro2.Id; fsdObjA2.Fixture_Set__c = fsObjA1.Id; fsdObjA2.Is_Body__c = false; fsdObjA2.Is_Optional__c = true; fsdObjA2.UniqueKey__c = fsObjA1.Id + ':' + pro2.Id; fsdObjA2.SortInt__c = 1; // 备品配套明细 Fixture_Set_Detail__c fsdObjA3 = new Fixture_Set_Detail__c(); fsdObjA3.Name = '备品配套明细名3'; fsdObjA3.Name_CHN_Created__c = '中文名称3'; fsdObjA3.Product2__c = pro3.Id; fsdObjA3.Fixture_Set__c = fsObjA1.Id; fsdObjA3.Is_Body__c = false; fsdObjA3.Is_Optional__c = true; fsdObjA3.UniqueKey__c = fsObjA1.Id + ':' + pro3.Id; fsdObjA3.SortInt__c = 1; insert new Fixture_Set_Detail__c[] {fsdObjA1,fsdObjA2,fsdObjA3}; Fixture_OneToOne_Link__c foLink1 = new Fixture_OneToOne_Link__c(); foLink1.Main_Asset__c = assetA1.Id; foLink1.Accessory_Asset__c = assetA2.Id; foLink1.Quantity__c = 1; insert foLink1; Rental_Apply__c raObj = new Rental_Apply__c(); raObj.Name = 'testra'; raObj.Product_category__c = 'GI'; raObj.Demo_purpose1__c = '产品试用'; raObj.demo_purpose2__c = FixtureUtil.raDemo_purpose2MAP.get('shiyongwuxunjia'); raObj.direct_send__c = '医疗机构'; raObj.Loaner_received_staff__c = '王五'; raObj.Loaner_received_staff_phone__c = '110'; raObj.direct_shippment_address__c = '北京市'; raObj.Hospital__c = hospital.Id; raObj.Strategic_dept__c = strategicDep[0].Id; raObj.Account__c = dep.Id; raObj.Request_shipping_day__c = Date.toDay(); // 希望到货日 raObj.Hope_Lonaer_date_Num__c = 1; // 希望借用天数 raObj.applyUser__c = userName; raObj.Person_In_Charge__c = userName; raObj.Phone_number__c = '1234567890'; raObj.Loaner_medical_Staff__c = contact2.Id; raObj.Add_Approval_Status__c = ''; insert raObj; // 借出备品配套一览 Rental_Apply__c raObjSelect = [SELECT Id,RA_Status__c,RA_Status_Text__c,Hospital__c FROM Rental_Apply__c WHERE Id =: raObj.Id]; // System.debug('申请状态------' + raObjSelect.RA_Status__c); Rental_Apply_Equipment_Set__c raesObj = new Rental_Apply_Equipment_Set__c(); raesObj.Rental_Apply__c = raObj.Id; raesObj.Fixture_Set__c = fsObjA1.Id; raesObj.IndexFromUniqueKey__c = 1; raesObj.UniqueKey__c = '1:'+ fsObjA1.Id + ':1'; raesObj.Rental_End_Date__c = Date.today().addDays(15); raesObj.Rental_Start_Date__c = Date.today().addDays(5); insert raesObj; Rental_Apply_Equipment_Set__c raesObjSelect = [SELECT Id,RetalFSetDetail_Cnt__c,RAES_Status__c FROM Rental_Apply_Equipment_Set__c WHERE Id =: raesObj.Id]; // 借出备品配套一览明细 Rental_Apply_Equipment_Set_Detail__c raesdObj1 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj1.Rental_Apply__c = raObj.Id; raesdObj1.Fixture_Set_Detail__c = fsdObjA1.Id; raesdObj1.Rental_Num__c = null; raesdObj1.Queue_Number__c = null; raesdObj1.Is_Body__c = true; raesdObj1.Rental_Apply_Equipment_Set__c = raesObjSelect.Id; raesdObj1.Asset__c = assetA1.Id; raesdObj1.IndexFromUniqueKey__c = 1; // raesdObj1.Asset__c = assetA1.Id; raesdObj1.UniqueKey__c = '1:'+ raesObjSelect.Id + ':' + fsdObjA1.Id + ':1'; raesdObj1.Salesdepartment_before__c = '1.华北营业本部'; raesdObj1.Internal_asset_location_before__c = '北京 备品中心'; raesdObj1.Product_category_text__c = 'GI'; raesdObj1.Equipment_Type_text__c = '产品试用'; raesdObj1.ExternalKey__c = '123'; insert raesdObj1; // 借出备品配套一览明细 Rental_Apply_Equipment_Set_Detail__c raesdObj2 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj2.Rental_Apply__c = raObj.Id; raesdObj2.Fixture_Set_Detail__c = fsdObjA2.Id; raesdObj2.Rental_Num__c = null; raesdObj2.Queue_Number__c = null; raesdObj2.Is_Body__c = false; // raesdObj2.Cancel_Select__c = true; // raesdObj2.FSD_Is_OneToOne__c = true; raesdObj2.Rental_Apply_Equipment_Set__c = raesObjSelect.Id; raesdObj2.IndexFromUniqueKey__c = 2; raesdObj2.UniqueKey__c = '1:'+ raesObjSelect.Id + ':' + fsdObjA2.Id + ':1'; raesdObj2.Salesdepartment_before__c = '1.华北营业本部'; raesdObj2.Internal_asset_location_before__c = '北京 备品中心'; raesdObj2.Product_category_text__c = 'GI'; raesdObj2.Equipment_Type_text__c = '产品试用'; raesdObj2.Asset__c = assetA1.Id; insert raesdObj2; // 借出备品配套一览明细 Rental_Apply_Equipment_Set_Detail__c raesdObj3 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj3.Rental_Apply__c = raObj.Id; raesdObj3.Fixture_Set_Detail__c = fsdObjA3.Id; raesdObj3.Rental_Num__c = null; raesdObj3.Queue_Number__c = null; raesdObj3.Is_Body__c = false; // raesdObj3.Cancel_Select__c = true; // raesdObj3.FSD_Is_OneToOne__c = true; raesdObj3.Asset__c = assetA1.Id; raesdObj3.Rental_Apply_Equipment_Set__c = raesObjSelect.Id; raesdObj3.IndexFromUniqueKey__c = 3; raesdObj3.UniqueKey__c = '1:'+ raesObjSelect.Id + ':' + fsdObjA3.Id + ':1'; raesdObj3.Salesdepartment_before__c = '1.华北营业本部'; raesdObj3.Internal_asset_location_before__c = '北京 备品中心'; raesdObj3.Product_category_text__c = 'GI'; raesdObj3.Equipment_Type_text__c = '产品试用'; insert raesdObj3; assetA1.Last_Reserve_RAES_Detail__c = raesdObj1.Id; update assetA1; raesdObj1.FSD_OneToOneAccessory_Cnt__c = 10; update raesdObj1; raObj.Status__c = '已批准'; update raObj; Rental_Apply_Sequence__c ras1 = new Rental_Apply_Sequence__c(); ras1.ExternalKey__c = 'n01北京 备品中心0.备品中心部产品试用GI'; ras1.Demo_Purpose2__c = FixtureUtil.raDemo_purpose2MAP.get('shiyongwuxunjia'); ras1.Apply_Set_Detail__c = raesdObj1.Id; ras1.Series_No__c = 1; ras1.Salesdepartment__c = '0.备品中心'; ras1.Invalid_Flag__c = false; ras1.Product_category__c = 'GI'; ras1.Rental_Apply__c = raObj.Id; ras1.Internal_asset_location__c = '北京 备品中心'; ras1.Fixture_Model_No__c = ''; ras1.Equipment_Type__c = '产品试用'; insert ras1; // System.debug('一览状态0------' + raesObjSelect.RAES_Status__c); System.debug('一览Id------' + raesObjSelect.Id); Rental_Apply_Equipment_Set_Detail__c raesdObj1Select = [SELECT Id,FSD_OneToOneAccessory_Cnt__c,EquipmentSet_Detail_Status_Status__c FROM Rental_Apply_Equipment_Set_Detail__c WHERE Id =: raesdObj1.Id]; System.debug('一览明细一对一附属品明细件数------' + raesdObj1Select.FSD_OneToOneAccessory_Cnt__c); List raObjList = new List(); raObjList.add(raesObjSelect); String jsonRecords = JSON.serialize(raObjList); // String jsonRecord0 = '[' + JSON.serialize(raesObjSelect1) + ']'; String jsonRecords1 = '[' + JSON.serialize(ras1) + ']'; // AutomaticAssignController.autoConfirmation(jsonRecords); AutomaticAssignController.initRenApply(); AutomaticAssignController.getAssetLocationOptions(); AutomaticAssignController.getDemopurpose1PicklistOptions(); AutomaticAssignController.getProcategoryPicklistOptions(); AutomaticAssignController.selectRenApply('产品试用','1.华北','RentalApp','ProCode','Procategory','AssetLocation','RequestOwner'); AutomaticAssignController.autoConfirmation(jsonRecords); AutomaticAssignController.autoConfirmation(jsonRecords1); AutomaticAssignController.autoConfirmationConfirm(jsonRecords); Account acc = new Account(); Rental_Apply__c ra1 = [Select Id,Hospital__c,Hospital__r.TradeComplianceStatus__c FROM Rental_Apply__c LIMIT 1]; acc.Id = ra1.Hospital__c; acc.TradeComplianceStatus__c = '黑名单'; UPSERT acc; //System.assertEquals(ra1.Hospital__r.TradeComplianceStatus__c, '黑名单'); AutomaticAssignController.autoConfirmation(jsonRecords); AutomaticAssignController.autoConfirmation(jsonRecords1); AutomaticAssignController.autoConfirmationConfirm(jsonRecords); // AutomaticAssignController.initRenApply(); acc.Id = ra1.Hospital__c; acc.TradeComplianceStatus__c = '冻结,人工审批中'; UPSERT acc; AutomaticAssignController.autoConfirmation(jsonRecords); AutomaticAssignController.autoConfirmation(jsonRecords1); AutomaticAssignController.autoConfirmationConfirm(jsonRecords); Test.stopTest(); } }