@isTest private class RentalApplyEquipmentSetHandlerTest { static void setupTestData() { // OLY_OCM-643 追加EscapeNFM001Trigger ControllerUtil.EscapeNFM001Trigger = true; Oly_TriggerHandler.bypass(ContactTriggerHandler.Class.getName()); Oly_TriggerHandler.bypass(RentalApplyTriggerHandler.Class.getName()); Oly_TriggerHandler.bypass(Product2Handler.Class.getName()); Oly_TriggerHandler.bypass('AWSServiceTool2'); Oly_TriggerHandler.bypass('PIHelper'); Oly_TriggerHandler.bypass('UserToContact'); Oly_TriggerHandler.bypass('ContactTriggerHandler'); // 省 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; // 戦略科室を得る 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 = '責任者test1经销商'; contact2.LastName = '責任者test1经销商'; insert contact2; // 产品 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', Asset_Model_No__c = 'Pro1', 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', Asset_Model_No__c = 'Pro2', ProductCode_Ext__c='pc02',Manual_Entry__c=false); insert new Product2[] {pro1, pro2}; ////备品借出申请 Rental_Apply__c raObj = new Rental_Apply__c(); raObj.Name = 'testra'; raObj.Product_category__c = 'GI'; raObj.Demo_purpose1__c = '其他'; raObj.demo_purpose2__c = '其他'; 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.Request_return_day__c = Date.toDay(); raObj.Phone_number__c = '1234567890'; raObj.Loaner_medical_Staff__c = contact2.Id; raObj.Hope_Lonaer_date_Num__c = 30; insert raObj; // 保有设备 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 = 1; 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'; 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 = 1; 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'; insert new Asset[] {asset1, asset2}; // 备品配套 Fixture_Set__c fsObj1 = new Fixture_Set__c(); fsObj1.Name = 'set1'; fsObj1.Fixture_Set_Body_Model_No__c = 'modelNo1'; fsObj1.Loaner_name__c = 'name1'; insert fsObj1; // 备品配套明细 Fixture_Set_Detail__c fsdObj1 = new Fixture_Set_Detail__c(); fsdObj1.Name = 'set_detail1'; fsdObj1.Name_CHN_Created__c = 'set_detail1'; fsdObj1.Product2__c = pro1.Id; fsdObj1.Fixture_Set__c = fsObj1.Id; fsdObj1.Is_Body__c = true; fsdObj1.Quantity__c = 1; fsdObj1.Is_OneToOne__c = false; fsdObj1.Is_Optional__c = false; fsdObj1.UniqueKey__c = fsObj1.Id + ':' + pro1.Id; fsdObj1.SortInt__c = 1; Fixture_Set_Detail__c fsdObj2 = new Fixture_Set_Detail__c(); fsdObj2.Name = 'set_detail2'; fsdObj2.Name_CHN_Created__c = 'set_detail2'; fsdObj2.Product2__c = pro2.Id; fsdObj2.Fixture_Set__c = fsObj1.Id; fsdObj2.Is_Body__c = false; fsdObj2.Quantity__c = 1; fsdObj2.Is_OneToOne__c = false; fsdObj2.UniqueKey__c = fsObj1.Id + ':' + pro2.Id; fsdObj2.SortInt__c = 2; insert new Fixture_Set_Detail__c[] {fsdObj1, fsdObj2}; } static Fixture_Set__c fscObj { get { List fscObjs = [select Id from Fixture_Set__c]; System.assertEquals(fscObjs.size(), 1); Fixture_Set__c fscObj = fscObjs[0]; return fscObj; }} static Fixture_Set_Detail__c fixdetail { get { List fscObjs = [select Id from Fixture_Set_Detail__c]; Fixture_Set_Detail__c fixdetail = fscObjs[0]; return fixdetail; }} /** * OLY_OCM-530: 保证每个申请单下至少有一个一览 * 如果所有新一览的原申请单下一览为空,则所有新一览报错 */ static testMethod void testCheckOldApplyNullError1() { RentalApplyEquipmentSetHandler.testMock1(); RentalApplyEquipmentSetHandler.testMock2(); RentalApplyEquipmentSetHandler.testMock3(); RentalApplyEquipmentSetHandler.testMock4(); RentalApplyEquipmentSetHandler.testMock5(); setupTestData(); Rental_Apply__c ra1 = new Rental_Apply__c(); ra1.Name = 'test1'; ra1.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra1.Request_shipping_day__c = Date.today().addDays(3); ra1.Request_return_day__c = Date.today().addDays(8); ra1.Demo_purpose1__c = '其他'; ra1.demo_purpose2__c = '其他'; ra1.Hope_Lonaer_date_Num__c = 30; Rental_Apply__c ra2 = new Rental_Apply__c(); ra2.Name = 'test2'; ra2.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra2.Request_shipping_day__c = Date.today().addDays(3); ra2.Request_return_day__c = Date.today().addDays(8); ra2.Demo_purpose1__c = '其他'; ra2.demo_purpose2__c = '其他'; ra2.Hope_Lonaer_date_Num__c = 30; insert new Rental_Apply__c[] {ra1, ra2}; Rental_Apply_Equipment_Set__c es1 = new Rental_Apply_Equipment_Set__c(); es1.Rental_Apply__c = ra1.Id; es1.Fixture_Set__c = fscObj.Id; es1.IndexFromUniqueKey__c = 1; es1.UniqueKey__c = '1:' + fscObj.Id + ':1'; insert new Rental_Apply_Equipment_Set__c[] {es1}; Rental_Apply__c rac = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra1.Id]; System.assertEquals(1, rac.Rental_Apply_Equipment_Set_Cnt__c); try { es1.Rental_Apply__c = ra2.Id; es1.Old_Rental_Apply__c = ra1.Id; System.Test.startTest(); update es1; System.Test.stopTest(); rac = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra1.Id]; System.assertEquals(0, rac.Rental_Apply_Equipment_Set_Cnt__c); throw new ControllerUtil.myException('没有发生,一览不能为空'); } catch(Exception e) { System.assertEquals(true, e.getMessage().contains('申请单 ' + rac.Name + ', 下一览不能为空')); } } /** * OLY_OCM-530: 保证每个申请单下至少有一个一览 * 如果部分新一览的原申请下一览为空,则原申请单下一览为空的新一览报错 */ static testMethod void testCheckOldApplyNullError2() { setupTestData(); Rental_Apply__c ra1 = new Rental_Apply__c(); ra1.Name = 'test1'; ra1.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra1.Request_shipping_day__c = Date.today().addDays(3); ra1.Request_return_day__c = Date.today().addDays(8); ra1.Demo_purpose1__c = '其他'; ra1.demo_purpose2__c = '其他'; ra1.Hope_Lonaer_date_Num__c = 30; Rental_Apply__c ra2 = new Rental_Apply__c(); ra2.Name = 'test2'; ra2.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra2.Request_shipping_day__c = Date.today().addDays(3); ra2.Request_return_day__c = Date.today().addDays(8); ra2.Demo_purpose1__c = '其他'; ra2.demo_purpose2__c = '其他'; ra2.Hope_Lonaer_date_Num__c = 30; Rental_Apply__c ra3 = new Rental_Apply__c(); ra3.Name = 'test3'; ra3.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra3.Request_shipping_day__c = Date.today().addDays(3); ra3.Request_return_day__c = Date.today().addDays(8); ra3.Demo_purpose1__c = '其他'; ra3.demo_purpose2__c = '其他'; ra3.Hope_Lonaer_date_Num__c = 30; insert new Rental_Apply__c[] {ra1, ra2, ra3}; Rental_Apply_Equipment_Set__c es1 = new Rental_Apply_Equipment_Set__c(); es1.Rental_Apply__c = ra1.Id; es1.Fixture_Set__c = fscObj.Id; es1.IndexFromUniqueKey__c = 1; es1.UniqueKey__c = '1:' + fscObj.Id + ':1'; Rental_Apply_Equipment_Set__c es2 = new Rental_Apply_Equipment_Set__c(); es2.Rental_Apply__c = ra2.Id; es2.Fixture_Set__c = fscObj.Id; es2.IndexFromUniqueKey__c = 2; es2.UniqueKey__c = '1:' + fscObj.Id + ':2'; Rental_Apply_Equipment_Set__c es3 = new Rental_Apply_Equipment_Set__c(); es3.Rental_Apply__c = ra2.Id; es3.Fixture_Set__c = fscObj.Id; es3.IndexFromUniqueKey__c = 3; es3.UniqueKey__c = '1:' + fscObj.Id + ':3'; insert new Rental_Apply_Equipment_Set__c[] {es1, es2, es3}; Rental_Apply__c rac1 = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra1.Id]; System.assertEquals(1, rac1.Rental_Apply_Equipment_Set_Cnt__c); Rental_Apply__c rac2 = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra2.Id]; System.assertEquals(2, rac2.Rental_Apply_Equipment_Set_Cnt__c); Rental_Apply__c rac3 = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra3.Id]; System.assertEquals(0, rac3.Rental_Apply_Equipment_Set_Cnt__c); try { es1.Rental_Apply__c = ra3.Id; es1.Old_Rental_Apply__c = ra1.Id; es2.Rental_Apply__c = ra3.Id; es2.Old_Rental_Apply__c = ra2.Id; System.Test.startTest(); update new Rental_Apply_Equipment_Set__c[] {es1, es2}; System.Test.stopTest(); rac1 = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra1.Id]; System.assertEquals(0, rac1.Rental_Apply_Equipment_Set_Cnt__c); rac2 = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra2.Id]; System.assertEquals(1, rac2.Rental_Apply_Equipment_Set_Cnt__c); rac3 = [SELECT ID, Name, Rental_Apply_Equipment_Set_Cnt__c FROM Rental_Apply__c WHERE Id = :ra3.Id]; System.assertEquals(2, rac3.Rental_Apply_Equipment_Set_Cnt__c); throw new ControllerUtil.myException('没有发生,一览不能为空'); } catch(Exception e) { System.assertEquals(true, e.getMessage().contains('申请单 ' + rac1.Name + ', 下一览不能为空')); } } // OLY_OCM-530: 如果是非"草案中"状态,删除一览则报错 static testMethod void testDeleteEquipmentError() { setupTestData(); Rental_Apply__c ra = new Rental_Apply__c(); ra.Name = 'test'; ra.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra.Request_shipping_day__c = Date.today().addDays(3); ra.Request_return_day__c = Date.today().addDays(8); ra.Demo_purpose1__c = '其他'; ra.demo_purpose2__c = '其他'; ra.Hope_Lonaer_date_Num__c = 30; insert ra; Rental_Apply_Equipment_Set__c es1 = new Rental_Apply_Equipment_Set__c(); es1.Rental_Apply__c = ra.Id; es1.Fixture_Set__c = fscObj.Id; es1.IndexFromUniqueKey__c = 1; es1.UniqueKey__c = '1:' + fscObj.Id + ':1'; insert new Rental_Apply_Equipment_Set__c[] {es1}; System.Test.startTest(); try { ra.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Yi_Pi_Zhun.ordinal()); update ra; delete es1; } catch (Exception e) { System.assertEquals(true, e.getMessage().contains('非草案中状态的一览不能删除')); } System.Test.stopTest(); } //add by rentx 20210816 start SFDC-C448KZ static testMethod void testMethod01() { setupTestData(); Rental_Apply__c ra1 = new Rental_Apply__c(); ra1.Name = 'test1'; ra1.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra1.Request_shipping_day__c = Date.today().addDays(3); ra1.Request_return_day__c = Date.today().addDays(8); ra1.Demo_purpose1__c = '其他'; ra1.demo_purpose2__c = '其他'; ra1.Hope_Lonaer_date_Num__c = 30; Rental_Apply__c ra2 = new Rental_Apply__c(); ra2.Name = 'test2'; ra2.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Cao_An_Zhong.ordinal()); ra2.Request_shipping_day__c = Date.today().addDays(3); ra2.Request_return_day__c = Date.today().addDays(8); ra2.Demo_purpose1__c = '其他'; ra2.demo_purpose2__c = '其他'; ra2.Hope_Lonaer_date_Num__c = 30; insert new Rental_Apply__c[] {ra1, ra2}; Rental_Apply_Equipment_Set__c es1 = new Rental_Apply_Equipment_Set__c(); es1.Rental_Apply__c = ra1.Id; es1.Fixture_Set__c = fscObj.Id; es1.IndexFromUniqueKey__c = 1; es1.UniqueKey__c = '1:' + fscObj.Id + ':1'; es1.Cancel_Select__c = false; insert es1; // 借出备品配套一览明细 Rental_Apply_Equipment_Set_Detail__c raesdObjC1 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObjC1.Rental_Apply__c = ra1.Id; raesdObjC1.Fixture_Set_Detail__c = fixdetail.Id; raesdObjC1.Rental_Num__c = 1; raesdObjC1.Queue_Number__c = null; raesdObjC1.Is_Body__c = false; raesdObjC1.Rental_Apply_Equipment_Set__c = es1.Id; // raesdObjC1.Asset__c = assetC1.Id; raesdObjC1.IndexFromUniqueKey__c = 1; raesdObjC1.UniqueKey__c = '1:'+ es1.Id + ':' + fixdetail.Id + ':1'; raesdObjC1.Salesdepartment_before__c = '0.备品中心'; raesdObjC1.Internal_asset_location_before__c = '北京 备品中心'; raesdObjC1.Product_category_text__c = 'GI'; raesdObjC1.Equipment_Type_text__c = '产品试用'; insert raesdObjC1; es1.Cancel_Select__c = true; es1.Cancel_Reason__c= '主动取消'; System.Test.startTest(); update es1; System.Test.stopTest(); } //add by rentx 20210816 end SFDC-C448KZ }