@isTest private class RentalApplySplitControllerTest { /*static void setupTestData() { // 省 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 = '責任者'; 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}; // 保有设备 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}; ////备品借出申请 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.Status__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 = 16; //raObj.Request_return_day__c = Date.toDay(); raObj.Phone_number__c = '1234567890'; raObj.Loaner_medical_Staff__c = contact2.Id; insert raObj; //备品借出历史 Rental_Apply_Equipment_Set__c raescObj1 = new Rental_Apply_Equipment_Set__c(); raescObj1.Rental_Apply__c = raObj.Id; raescObj1.Fixture_Set__c = fsObj1.Id; raescObj1.Rental_Num__c = 1; raescObj1.Cancel_Select__c = false; raescObj1.Rental_Start_Date__c = Date.toDay(); raescObj1.Rental_End_Date__c = Date.toDay(); raescObj1.IndexFromUniqueKey__c = 1; raescObj1.UniqueKey__c = '1:'+ fsObj1.Id + ':1'; Rental_Apply_Equipment_Set__c raescObj2 = new Rental_Apply_Equipment_Set__c(); raescObj2.Rental_Apply__c = raObj.Id; raescObj2.Fixture_Set__c = fsObj1.Id; raescObj2.Rental_Num__c = 1; raescObj2.Cancel_Select__c = false; raescObj2.Rental_Start_Date__c = Date.toDay(); raescObj2.Rental_End_Date__c = Date.toDay(); raescObj2.IndexFromUniqueKey__c = 3; raescObj2.UniqueKey__c = '1:'+ fsObj1.Id + ':2'; Rental_Apply_Equipment_Set__c raescObj3 = new Rental_Apply_Equipment_Set__c(); raescObj3.Rental_Apply__c = raObj.Id; raescObj3.Fixture_Set__c = fsObj1.Id; raescObj3.Rental_Num__c = 2; raescObj3.Cancel_Select__c = false; raescObj3.Rental_Start_Date__c = Date.toDay(); raescObj3.Rental_End_Date__c = Date.toDay(); raescObj3.IndexFromUniqueKey__c = 2; raescObj3.UniqueKey__c = '1:'+ fsObj1.Id + ':3'; Rental_Apply_Equipment_Set__c raescObj4 = new Rental_Apply_Equipment_Set__c(); raescObj4.Rental_Apply__c = raObj.Id; raescObj4.Fixture_Set__c = fsObj1.Id; raescObj4.Rental_Num__c = 2; raescObj4.Cancel_Select__c = false; raescObj4.Rental_Start_Date__c = Date.toDay(); raescObj4.Rental_End_Date__c = Date.toDay(); raescObj4.IndexFromUniqueKey__c = 4; raescObj4.UniqueKey__c = '1:'+ fsObj1.Id + ':4'; Rental_Apply_Equipment_Set__c raescObj5 = new Rental_Apply_Equipment_Set__c(); raescObj5.Rental_Apply__c = raObj.Id; raescObj5.Fixture_Set__c = fsObj1.Id; raescObj5.Rental_Num__c = 3; raescObj5.Cancel_Select__c = false; raescObj5.Rental_Start_Date__c = Date.toDay(); raescObj5.Rental_End_Date__c = Date.toDay(); raescObj5.IndexFromUniqueKey__c = 5; raescObj5.UniqueKey__c = '1:'+ fsObj1.Id + ':5'; insert new Rental_Apply_Equipment_Set__c[] {raescObj1, raescObj2, raescObj3, raescObj4, raescObj5}; // 借出备品配套一览明细 Rental_Apply_Equipment_Set_Detail__c raesdObjC1 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObjC1.Rental_Apply__c = raObj.Id; raesdObjC1.Fixture_Set_Detail__c = fsdObj1.Id; raesdObjC1.Rental_Num__c = 1; raesdObjC1.Queue_Number__c = null; raesdObjC1.Is_Body__c = false; raesdObjC1.Rental_Apply_Equipment_Set__c = raescObj1.Id; raesdObjC1.Asset__c = asset1.Id; raesdObjC1.IndexFromUniqueKey__c = 1; raesdObjC1.UniqueKey__c = '1:'+ raescObj1.Id + ':' + fsdObj1.Id + ':1'; raesdObjC1.Salesdepartment_before__c = '1.华北营业本部'; raesdObjC1.Internal_asset_location_before__c = '北京 备品中心'; raesdObjC1.Product_category_text__c = 'GI'; raesdObjC1.Equipment_Type_text__c = '产品试用'; insert raesdObjC1; raObj.Status__c = '已批准'; FixtureUtil.withoutUpdate(new Rental_Apply__c[]{raObj}); }*/ // 分单功能url传入的是一览Ids拼接,以‘,’隔开 /*static String raescObjIds(Integer rentalNum) { List raescObjs = [select Id from Rental_Apply_Equipment_Set__c where Rental_Num__c =:rentalNum]; String ids = ''; for (Rental_Apply_Equipment_Set__c raesTemp : raescObjs) { ids += raesTemp.Id + ','; } if (ids.length() > 1) { ids = ids.substring(0,ids.length()-1); } return ids; }*/ // private static User getUser() { // String timenow = Datetime.now().format('yyyyMMddHHmmss'); // User hpOwner = new User(Test_staff__c = true, LastName = 'TestLi20210615', FirstName = 'TestLi20210615F', // Alias = 'hp', CommunityNickname = 'TestLi20210615', Email = 'Test@sunbridge.com', // Username = 'Test' + timenow + '@sunbridge.com', IsActive = true, EmailEncodingKey = 'ISO-2022-JP', // TimeZoneSidKey = 'Asia/Tokyo', LocaleSidKey = 'ja_JP', LanguageLocaleKey = 'ja', // ProfileId = System.Label.ProfileId_SystemAdmin, // Dept__c = '医疗华北营业本部', Province__c = '北京'); // insert hpOwner; // return hpOwner; // } private static User u; static void setupTestData() { System.runAs(new User(Id = Userinfo.getUserId())) { StaticParameter.EscapeNFM001AgencyContractTrigger = true; StaticParameter.EscapeNFM001Trigger = true; Oly_TriggerHandler.bypass(ContactTriggerHandler.class.getName()); Oly_TriggerHandler.bypass(AgencyHospitalHandler.class.getName()); Oly_TriggerHandler.bypass(RentalApplyTriggerHandler.class.getName()); // システム管理者 u = new User(Test_staff__c = true); u.LastName = '_サンブリッジ'; u.FirstName = 'う'; u.Alias = 'う'; u.Email = 'olympusTest03@sunbridge.com'; u.Username = 'olympusTest03@sunbridge.com'; u.CommunityNickname = 'う'; u.IsActive = true; u.EmailEncodingKey = 'ISO-2022-JP'; u.TimeZoneSidKey = 'Asia/Tokyo'; u.LocaleSidKey = 'ja_JP'; u.LanguageLocaleKey = 'ja'; u.ProfileId = System.Label.ProfileId_SystemAdmin; u.Province__c = '北京'; u.Dept__c = '医疗华北营业本部'; u.Use_Start_Date__c = Date.today().addMonths(-6); insert u; } // 省 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; // 产品 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); Product2 pro3 = new Product2(Name='name03',IsActive=true,Family='GI', Fixture_Model_No__c='n03',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'n03', Asset_Model_No__c = 'Pro3', ProductCode_Ext__c='pc03',Manual_Entry__c=false); Product2 pro4 = new Product2(Name='name04',IsActive=true,Family='GI', Fixture_Model_No__c='n04',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'n04', Asset_Model_No__c = 'Pro4', ProductCode_Ext__c='pc04',Manual_Entry__c=false); Product2 pro5 = new Product2(Name='name05',IsActive=true,Family='GI', Fixture_Model_No__c='n05',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'n05', Asset_Model_No__c = 'Pro5', ProductCode_Ext__c='pc05',Manual_Entry__c=false); Product2 pro6 = new Product2(Name='name06',IsActive=true,Family='GI', Fixture_Model_No__c='n06',Serial_Lot_No__c='Lot tracing', Fixture_Model_No_T__c = 'n06', Asset_Model_No__c = 'Pro6', ProductCode_Ext__c='pc06',Manual_Entry__c=false); insert new Product2[] {pro1, pro2, pro3, pro4, pro5, pro6}; // 保有设备 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'; Asset asset3 = new Asset(Asset_Owner__c = 'Olympus'); asset3.RecordTypeId = System.Label.Asset_RecordType; asset3.SerialNumber = 'asset3'; asset3.Name = 'asset3'; asset3.AccountId = dep.Id; asset3.Department_Class__c = strategicDep[0].Id; asset3.Hospital__c = hospital.Id; asset3.Product2Id = pro3.Id; asset3.Quantity = 5; asset3.Status = '不明'; asset3.Manage_type__c = '数量管理'; asset3.Loaner_accsessary__c = true; asset3.Out_of_wh__c = 0; asset3.Salesdepartment__c = '1.华北营业本部'; asset3.Internal_asset_location__c = '北京 备品中心'; asset3.Product_category__c = 'GI'; asset3.Equipment_Type__c = '产品试用'; asset3.SalesProvince__c = '北京'; asset3.CompanyOfEquipment__c = '北京'; asset3.Internal_Asset_number__c = '0003'; Asset asset4 = new Asset(Asset_Owner__c = 'Olympus'); asset4.RecordTypeId = System.Label.Asset_RecordType; asset4.SerialNumber = 'asset4'; asset4.Name = 'asset4'; asset4.AccountId = dep.Id; asset4.Department_Class__c = strategicDep[0].Id; asset4.Hospital__c = hospital.Id; asset4.Product2Id = pro4.Id; asset4.Quantity = 10; asset4.Status = '不明'; asset4.Manage_type__c = '数量管理'; asset4.Loaner_accsessary__c = true; asset4.Out_of_wh__c = 0; asset4.Salesdepartment__c = '1.华北营业本部'; asset4.Internal_asset_location__c = '北京 备品中心'; asset4.Product_category__c = 'GI'; asset4.Equipment_Type__c = '产品试用'; asset4.SalesProvince__c = '北京'; asset4.CompanyOfEquipment__c = '北京'; asset4.Internal_Asset_number__c = '0004'; insert new Asset[] {asset1, asset2, asset3, asset4}; // 备品一对一Link表 Fixture_OneToOne_Link__c foLink1 = new Fixture_OneToOne_Link__c(); foLink1.Main_Asset__c = asset1.Id; foLink1.Accessory_Asset__c = asset2.Id; foLink1.Quantity__c = 1; Fixture_OneToOne_Link__c foLink2 = new Fixture_OneToOne_Link__c(); foLink2.Main_Asset__c = asset1.Id; foLink2.Accessory_Asset__c = asset3.Id; foLink2.Quantity__c = 1; insert new Fixture_OneToOne_Link__c[] {foLink1, foLink2}; // 备品配套 Fixture_Set__c fsObj10 = new Fixture_Set__c(); fsObj10.Name = 'set10'; fsObj10.Fixture_Set_Body_Model_No__c = 'modelNo10'; fsObj10.Loaner_name__c = 'name10'; insert fsObj10; // 备品配套明细 Fixture_Set_Detail__c fsdObj10 = new Fixture_Set_Detail__c(); fsdObj10.Name = 'set_detail10'; fsdObj10.Name_CHN_Created__c = 'set_detail10'; fsdObj10.Product2__c = pro1.Id; fsdObj10.Fixture_Set__c = fsObj10.Id; fsdObj10.Is_Body__c = true; fsdObj10.Quantity__c = 1; fsdObj10.Is_OneToOne__c = false; fsdObj10.Is_Optional__c = false; fsdObj10.UniqueKey__c = fsObj10.Id + ':' + pro1.Id; fsdObj10.SortInt__c = 1; Fixture_Set_Detail__c fsdObj11 = new Fixture_Set_Detail__c(); fsdObj11.Name = 'set_detail11'; fsdObj11.Name_CHN_Created__c = 'set_detail11'; fsdObj11.Product2__c = pro2.Id; fsdObj11.Fixture_Set__c = fsObj10.Id; fsdObj11.Is_Body__c = false; fsdObj11.Quantity__c = 1; fsdObj11.Is_OneToOne__c = false; fsdObj11.UniqueKey__c = fsObj10.Id + ':' + pro2.Id; fsdObj11.SortInt__c = 2; insert new Fixture_Set_Detail__c[] {fsdObj10, fsdObj11}; // 备品配套 Fixture_Set__c fsObj20 = new Fixture_Set__c(); fsObj20.Name = 'set20'; fsObj20.Fixture_Set_Body_Model_No__c = 'modelNo20'; fsObj20.Loaner_name__c = 'name20'; insert fsObj20; // 备品配套明细 Fixture_Set_Detail__c fsdObj20 = new Fixture_Set_Detail__c(); fsdObj20.Name = 'set_detail20'; fsdObj20.Name_CHN_Created__c = 'set_detail20'; fsdObj20.Product2__c = pro1.Id; fsdObj20.Fixture_Set__c = fsObj20.Id; fsdObj20.Is_Body__c = true; fsdObj20.Quantity__c = 1; fsdObj20.Is_OneToOne__c = false; fsdObj20.Is_Optional__c = false; fsdObj20.UniqueKey__c = fsObj20.Id + ':' + pro1.Id; fsdObj20.SortInt__c = 1; Fixture_Set_Detail__c fsdObj21 = new Fixture_Set_Detail__c(); fsdObj21.Name = 'set_detail21'; fsdObj21.Name_CHN_Created__c = 'set_detail21'; fsdObj21.Product2__c = pro2.Id; fsdObj21.Fixture_Set__c = fsObj20.Id; fsdObj21.Is_Body__c = false; fsdObj21.Quantity__c = 1; fsdObj21.Is_OneToOne__c = false; fsdObj21.UniqueKey__c = fsObj20.Id + ':' + pro2.Id; fsdObj21.SortInt__c = 2; insert new Fixture_Set_Detail__c[] {fsdObj20, fsdObj21}; // 备品配套 Fixture_Set__c fsObj30 = new Fixture_Set__c(); fsObj30.Name = 'set30'; fsObj30.Fixture_Set_Body_Model_No__c = 'modelNo30'; fsObj30.Loaner_name__c = 'name30'; insert fsObj30; // 备品配套明细 Fixture_Set_Detail__c fsdObj30 = new Fixture_Set_Detail__c(); fsdObj30.Name = 'set_detail30'; fsdObj30.Name_CHN_Created__c = 'set_detail30'; fsdObj30.Product2__c = pro1.Id; fsdObj30.Fixture_Set__c = fsObj30.Id; fsdObj30.Is_Body__c = true; fsdObj30.Quantity__c = 1; fsdObj30.Is_OneToOne__c = false; fsdObj30.Is_Optional__c = false; fsdObj30.UniqueKey__c = fsObj30.Id + ':' + pro1.Id; fsdObj30.SortInt__c = 1; Fixture_Set_Detail__c fsdObj31 = new Fixture_Set_Detail__c(); fsdObj31.Name = 'set_detail31'; fsdObj31.Name_CHN_Created__c = 'set_detail31'; fsdObj31.Product2__c = pro2.Id; fsdObj31.Fixture_Set__c = fsObj30.Id; fsdObj31.Is_Body__c = false; fsdObj31.Quantity__c = 1; fsdObj31.Is_OneToOne__c = false; fsdObj31.UniqueKey__c = fsObj30.Id + ':' + pro2.Id; fsdObj31.SortInt__c = 2; insert new Fixture_Set_Detail__c[] {fsdObj30, fsdObj31}; //备品借出申请 System.runAs(u) { 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.Status__c = '草案中'; raObj.SalesdeptSelect__c = '医疗华北营业本部'; raObj.ToAgency__c = '北京'; raObj.Hope_Lonaer_date_Num__c = 1; Map DEVELOPERNAMEMAP = Schema.SObjectType.Rental_Apply__c.getRecordTypeInfosByDeveloperName(); raObj.RecordTypeId = DEVELOPERNAMEMAP.get('StandardRequest').getRecordTypeId(); insert raObj; // 借出备品配套一览 Rental_Apply_Equipment_Set__c raesObj10 = new Rental_Apply_Equipment_Set__c(); raesObj10.Rental_Apply__c = raObj.Id; raesObj10.Fixture_Set__c = fsObj10.Id; raesObj10.Cancel_Select__c = false; raesObj10.Rental_Start_Date__c = Date.toDay(); raesObj10.Rental_End_Date__c = Date.toDay(); raesObj10.IndexFromUniqueKey__c = 1; raesObj10.UniqueKey__c = '1:'+ fsObj10.Id + ':1'; insert raesObj10; Rental_Apply_Equipment_Set__c raesObj20 = new Rental_Apply_Equipment_Set__c(); raesObj20.Rental_Apply__c = raObj.Id; raesObj20.Fixture_Set__c = fsObj20.Id; raesObj20.Cancel_Select__c = false; raesObj20.Rental_Start_Date__c = Date.toDay(); raesObj20.Rental_End_Date__c = Date.toDay(); raesObj20.IndexFromUniqueKey__c = 1; raesObj20.UniqueKey__c = '1:'+ fsObj20.Id + ':1'; insert raesObj20; Rental_Apply_Equipment_Set__c raesObj30 = new Rental_Apply_Equipment_Set__c(); raesObj30.Rental_Apply__c = raObj.Id; raesObj30.Fixture_Set__c = fsObj30.Id; raesObj30.Cancel_Select__c = false; raesObj30.Rental_Start_Date__c = Date.toDay(); raesObj30.Rental_End_Date__c = Date.toDay(); raesObj30.IndexFromUniqueKey__c = 1; raesObj30.UniqueKey__c = '1:'+ fsObj30.Id + ':1'; insert raesObj30; // 借出备品配套一览明细 Rental_Apply_Equipment_Set_Detail__c raesdObj10 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj10.Rental_Apply__c = raObj.Id; raesdObj10.Fixture_Set_Detail__c = fsdObj10.Id; raesdObj10.Rental_Num__c = 1; raesdObj10.Queue_Number__c = null; raesdObj10.Is_Body__c = true; raesdObj10.Rental_Apply_Equipment_Set__c = raesObj10.Id; raesdObj10.IndexFromUniqueKey__c = 1; raesdObj10.UniqueKey__c = '1:'+ raesObj10.Id + ':' + fsdObj10.Id + ':1'; raesdObj10.FSD_OneToOneAccessory_Cnt__c = 0; raesdObj10.FSD_Is_Optional__c = false; raesdObj10.FSD_Is_OneToOne__c = false; raesdObj10.ApplyPersonAppended__c = false; raesdObj10.FSD_Fixture_Model_No__c = 'n01'; raesdObj10.Fixture_Model_No_text__c = 'n01'; raesdObj10.Salesdepartment_before__c = '1.华北营业本部'; raesdObj10.Internal_asset_location_before__c = '北京 备品中心'; raesdObj10.Product_category_text__c = 'GI'; raesdObj10.Equipment_Type_text__c = '产品试用'; Rental_Apply_Equipment_Set_Detail__c raesdObj11 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj11.Rental_Apply__c = raObj.Id; raesdObj11.Fixture_Set_Detail__c = fsdObj11.Id; raesdObj11.Rental_Num__c = 1; raesdObj11.Queue_Number__c = null; raesdObj11.Is_Body__c = false; raesdObj11.Rental_Apply_Equipment_Set__c = raesObj10.Id; raesdObj11.IndexFromUniqueKey__c = 2; raesdObj11.UniqueKey__c = '1:'+ raesObj10.Id + ':' + fsdObj11.Id + ':2'; raesdObj11.FSD_OneToOneAccessory_Cnt__c = 0; raesdObj11.FSD_Is_Optional__c = false; raesdObj11.FSD_Is_OneToOne__c = false; raesdObj11.ApplyPersonAppended__c = false; raesdObj11.FSD_Fixture_Model_No__c = 'n02'; raesdObj11.Fixture_Model_No_text__c = 'n02'; raesdObj11.Salesdepartment_before__c = '1.华北营业本部'; raesdObj11.Internal_asset_location_before__c = '北京 备品中心'; raesdObj11.Product_category_text__c = 'GI'; raesdObj11.Equipment_Type_text__c = '产品试用'; Rental_Apply_Equipment_Set_Detail__c raesdObj20 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj20.Rental_Apply__c = raObj.Id; raesdObj20.Fixture_Set_Detail__c = fsdObj20.Id; raesdObj20.Rental_Num__c = 1; raesdObj20.Queue_Number__c = null; raesdObj20.Is_Body__c = true; raesdObj20.Rental_Apply_Equipment_Set__c = raesObj20.Id; raesdObj20.IndexFromUniqueKey__c = 1; raesdObj20.UniqueKey__c = '1:'+ raesObj20.Id + ':' + fsdObj20.Id + ':1'; raesdObj20.FSD_OneToOneAccessory_Cnt__c = 0; raesdObj20.FSD_Is_Optional__c = false; raesdObj20.FSD_Is_OneToOne__c = false; raesdObj20.ApplyPersonAppended__c = false; raesdObj20.FSD_Fixture_Model_No__c = 'n03'; raesdObj20.Fixture_Model_No_text__c = 'n03'; raesdObj20.Salesdepartment_before__c = '1.华北营业本部'; raesdObj20.Internal_asset_location_before__c = '北京 备品中心'; raesdObj20.Product_category_text__c = 'GI'; raesdObj20.Equipment_Type_text__c = '产品试用'; Rental_Apply_Equipment_Set_Detail__c raesdObj21 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj21.Rental_Apply__c = raObj.Id; raesdObj21.Fixture_Set_Detail__c = fsdObj21.Id; raesdObj21.Rental_Num__c = 1; raesdObj21.Queue_Number__c = null; raesdObj21.Is_Body__c = false; raesdObj21.Rental_Apply_Equipment_Set__c = raesObj20.Id; raesdObj21.IndexFromUniqueKey__c = 2; raesdObj21.UniqueKey__c = '1:'+ raesObj20.Id + ':' + fsdObj21.Id + ':2'; raesdObj21.FSD_OneToOneAccessory_Cnt__c = 2; raesdObj21.FSD_Is_Optional__c = false; raesdObj21.FSD_Is_OneToOne__c = false; raesdObj21.ApplyPersonAppended__c = false; raesdObj21.FSD_Fixture_Model_No__c = 'n03'; raesdObj21.Fixture_Model_No_text__c = 'n03'; raesdObj21.Salesdepartment_before__c = '1.华北营业本部'; raesdObj21.Internal_asset_location_before__c = '北京 备品中心'; raesdObj21.Product_category_text__c = 'GI'; raesdObj21.Equipment_Type_text__c = '产品试用'; Rental_Apply_Equipment_Set_Detail__c raesdObj30 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj30.Rental_Apply__c = raObj.Id; raesdObj30.Fixture_Set_Detail__c = fsdObj30.Id; raesdObj30.Rental_Num__c = 1; raesdObj30.Queue_Number__c = null; raesdObj30.Is_Body__c = true; raesdObj30.Rental_Apply_Equipment_Set__c = raesObj30.Id; raesdObj30.IndexFromUniqueKey__c = 1; raesdObj30.UniqueKey__c = '1:'+ raesObj30.Id + ':' + fsdObj30.Id + ':1'; raesdObj30.FSD_OneToOneAccessory_Cnt__c = 0; raesdObj30.FSD_Is_Optional__c = false; raesdObj30.FSD_Is_OneToOne__c = false; raesdObj30.ApplyPersonAppended__c = false; raesdObj30.FSD_Fixture_Model_No__c = 'n04'; raesdObj30.Fixture_Model_No_text__c = 'n04'; raesdObj30.Salesdepartment_before__c = '1.华北营业本部'; raesdObj30.Internal_asset_location_before__c = '北京 备品中心'; raesdObj30.Product_category_text__c = 'GI'; raesdObj30.Equipment_Type_text__c = '产品试用'; Rental_Apply_Equipment_Set_Detail__c raesdObj31 = new Rental_Apply_Equipment_Set_Detail__c(); raesdObj31.Rental_Apply__c = raObj.Id; raesdObj31.Fixture_Set_Detail__c = fsdObj31.Id; raesdObj31.Rental_Num__c = 1; raesdObj31.Queue_Number__c = null; raesdObj31.Is_Body__c = false; raesdObj31.Rental_Apply_Equipment_Set__c = raesObj30.Id; raesdObj31.IndexFromUniqueKey__c = 6; raesdObj31.UniqueKey__c = '1:'+ raesObj30.Id + ':' + fsdObj31.Id + ':6'; raesdObj31.FSD_OneToOneAccessory_Cnt__c = 1; raesdObj31.FSD_Is_Optional__c = false; raesdObj31.FSD_Is_OneToOne__c = false; raesdObj31.ApplyPersonAppended__c = false; raesdObj31.FSD_Fixture_Model_No__c = 'n04'; raesdObj31.Fixture_Model_No_text__c = 'n04'; raesdObj31.Salesdepartment_before__c = '1.华北营业本部'; raesdObj31.Internal_asset_location_before__c = '北京 备品中心'; raesdObj31.Product_category_text__c = 'GI'; raesdObj31.Equipment_Type_text__c = '产品试用'; insert new Rental_Apply_Equipment_Set_Detail__c[] {raesdObj10,raesdObj11,raesdObj20,raesdObj21,raesdObj30,raesdObj31}; Test.setCreatedDate(raObj.Id, Datetime.now().addDays(-2)); // 申请单 raObj.Status__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Yi_Pi_Zhun.ordinal()); raObj.Status_Text__c = FixtureUtil.raStatusMap.get(FixtureUtil.RaStatus.Yi_Pi_Zhun.ordinal()); raObj.NotWatch_RA_Status__c = true; raObj.Request_approval_time__c = Datetime.now().addDays(-1); update raObj; } } static Rental_Apply__c raObj { get { List raObjs = [select Id, Name, Account__c, Hospital__c, Strategic_dept__c, Loaner_medical_Staff__c FROM Rental_Apply__c]; Rental_Apply__c raObj = raObjs[0]; return raObj; }} static String recid { get { return 'objId='+raObj.Id; }} static String raescObjIds(Integer rentalNum) { List raescObjs = [select Id from Rental_Apply_Equipment_Set__c where Rental_Apply__c = :raObj.id limit :rentalNum ]; String ids = ''; for (Rental_Apply_Equipment_Set__c raesTemp : raescObjs) { ids += raesTemp.Id + ','; } if (ids.length() > 1) { ids = ids.substring(0,ids.length()-1); } return ids; } /** * @description 整单分单 **/ static testMethod void testSaveSplit() { setupTestData(); //整单备品中心到办事处 PageReference ref = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(3)); Test.setCurrentPage(ref); RentalApplySplitController controller = new RentalApplySplitController(); Test.startTest(); controller.init(); controller.test(); controller.cloneRas.ToAgency__c = '北京'; controller.cloneRas.Split_Apply_Reason__c = '现地管理分单'; controller.saveSplit(); controller.saveSplitAll(); // 整单办事处到办事处 controller.cloneRas.ToAgency__c = '天津'; controller.cloneRas.Split_Apply_Reason__c = '现地管理分单'; controller.saveSplit(); controller.saveSplitAll(); // 整单办事处到备品中心 controller.cloneRas.ToAgency__c = null; controller.cloneRas.Split_Apply_Reason__c = '分批发货分单'; controller.saveSplit(); controller.saveSplitAll(); System.assertEquals('ok', controller.saveStatus); Test.stopTest(); } /** * @description 部分分单 **/ static testMethod void testSaveSplit01() { setupTestData(); //备品中心到办事处 PageReference ref = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(2)); Test.setCurrentPage(ref); RentalApplySplitController controller = new RentalApplySplitController(); Test.startTest(); controller.init(); controller.cloneRas.ToAgency__c = '北京'; controller.cloneRas.Split_Apply_Reason__c = '现地管理分单'; controller.saveSplit(); System.assertEquals('ok', controller.saveStatus); List raList = [select Id, Name, RA_Status__c,Account__c, Hospital__c, Strategic_dept__c, Loaner_medical_Staff__c FROM Rental_Apply__c where old_Rental_Apply__c = :raObj.Id and recordtype.DeveloperName = 'AgencyRequest']; System.assertEquals(1, raList.size()); System.assertEquals('已批准', raList[0].RA_Status__c); // 整单 备品中心到备品中心 报错 PageReference ref1 = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(1)); Test.setCurrentPage(ref1); RentalApplySplitController controller1 = new RentalApplySplitController(); controller1.init(); controller1.cloneRas.ToAgency__c = null; controller1.cloneRas.Split_Apply_Reason__c = '分批发货分单'; controller1.saveSplit(); // 办事处整单 分回备品中心 List raesObjs = [select Id,RAES_Status__c,Request_Status__c from Rental_Apply_Equipment_Set__c where Rental_Apply__c = :raList[0].Id and old_Rental_Apply__c = :raObj.Id]; System.assertEquals(2, raesObjs.size()); System.assertEquals('已批准', raesObjs[0].Request_Status__c); // System.assertEquals('待分配', raesObjs[1].RAES_Status__c); // List raesdObjs = [select Id,RAESD_Status__c from Rental_Apply_Equipment_Set_Detail__c where Rental_Apply__c = :raList[0].Id]; // System.assertEquals(4, raesdObjs.size()); // System.assertEquals('待分配', raesdObjs[0].RAESD_Status__c); // System.assertEquals('待分配', raesdObjs[1].RAESD_Status__c); // System.assertEquals('待分配', raesdObjs[2].RAESD_Status__c); // System.assertEquals('待分配', raesdObjs[3].RAESD_Status__c); String ids = ''; for (Rental_Apply_Equipment_Set__c raesTemp : raesObjs) { ids += raesTemp.Id + ','; } if (ids.length() > 1) { ids = ids.substring(0,ids.length()-1); } PageReference ref2 = new PageReference('/apex/RentalApplySplit?objId='+raList[0].Id + '&raesIds=' + ids); Test.setCurrentPage(ref2); RentalApplySplitController controller2 = new RentalApplySplitController(); controller2.init(); controller2.cloneRas.ToAgency__c = null; controller2.cloneRas.Split_Apply_Reason__c = '分批发货分单'; controller2.saveSplit(); controller2.saveSplitAll(); Test.stopTest(); } /** * @description 对原申请单分单两次 **/ /*static testMethod void testSaveSplit() { system.runAs(getUser()) { setupTestData(); // ---------------------------- 对原申请单的第一次分单 ----------------------- PageReference ref = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(1)+'&split=center'); Test.setCurrentPage(ref); RentalApplySplitController controller = new RentalApplySplitController(); Test.startTest(); controller.init(); //controller.test(); controller.cloneRas.Split_Apply_Reason__c = '分批发货分单'; controller.saveSplit(); System.assertEquals('ok', controller.saveStatus); List ras = [ select Id, Name, Old_Rental_Apply__c, Status__c, Cancel_Select__c, Rental_Apply_Equipment_Set_Cnt__c, Status_Text__c, ShelfUp_ng_num__c, Wei_Received_loaner__c, Wei_Return__c, Shippment_ng_num__c, Split_Apply_Reason__c FROM Rental_Apply__c order by Name]; System.assertEquals(2, ras.size()); // 新建了申请单:ras[0]--原申请单 ras[1]--新申请单 System.assertEquals(3, ras[0].Rental_Apply_Equipment_Set_Cnt__c); System.assertEquals(ras[0].Name+'_1', ras[1].Name); System.assertEquals(2, ras[1].Rental_Apply_Equipment_Set_Cnt__c); System.assertEquals(ras[0].Id, ras[1].Old_Rental_Apply__c); System.assertEquals('分批发货分单', ras[1].Split_Apply_Reason__c); List oldRaes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :ras[0].Id]; List clonedRaes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :ras[1].Id order by Name]; System.assertEquals(3, oldRaes.size()); System.assertEquals(2, clonedRaes.size()); System.assertEquals(ras[0].Id, clonedRaes[0].Old_Rental_Apply__c); System.assertEquals(ras[0].Id, clonedRaes[1].Old_Rental_Apply__c); // 分单后的一览 Name System.assertEquals(true, Pattern.compile('.*_1:.*').matcher(clonedRaes[0].Name).matches()); System.assertEquals(true, Pattern.compile('.*_1:.*').matcher(clonedRaes[1].Name).matches()); // 配套明细被分割到新申请单 & Name更改 List raesdList = [ select Id, Name, Rental_Apply_r_Name__c, Rental_Apply__c, Rental_Apply_Equipment_Set__c from Rental_Apply_Equipment_Set_Detail__c]; System.assertEquals(1, raesdList.size()); System.assertEquals(ras[1].Id, raesdList[0].Rental_Apply__c); System.assertEquals(true, Pattern.compile('.*_1:.*').matcher(raesdList[0].Name).matches()); // ---------------------------- 对原申请单的第二次分单 ----------------------- PageReference secRef = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(2)); Test.setCurrentPage(secRef); RentalApplySplitController secController = new RentalApplySplitController(); secController.init(); secController.cloneRas.Split_Apply_Reason__c = '排队分单'; secController.saveSplit(); System.assertEquals('ok', secController.saveStatus); List secRas = [ select Id, Name, Old_Rental_Apply__c, Status__c, Cancel_Select__c, Rental_Apply_Equipment_Set_Cnt__c, Status_Text__c, ShelfUp_ng_num__c, Wei_Received_loaner__c, Wei_Return__c, Shippment_ng_num__c, Split_Apply_Reason__c FROM Rental_Apply__c order by Name]; // 又新建了申请单:secRas[0]--原申请单 secRas[1]--新申请单 secRas【2】--第二次分单新申请单 System.assertEquals(3, secRas.size()); System.assertEquals(1, secRas[0].Rental_Apply_Equipment_Set_Cnt__c); System.assertEquals(secRas[0].Name+'_2', secRas[2].Name); System.assertEquals(2, secRas[2].Rental_Apply_Equipment_Set_Cnt__c); System.assertEquals(secRas[0].Id, secRas[2].Old_Rental_Apply__c); System.assertEquals('排队分单', secRas[2].Split_Apply_Reason__c); List secOldRaes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :secRas[0].Id]; List secClonedRaes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :secRas[2].Id order by Name]; System.assertEquals(1, secOldRaes.size()); System.assertEquals(2, secClonedRaes.size()); System.assertEquals(secRas[0].Id, secClonedRaes[0].Old_Rental_Apply__c); System.assertEquals(secRas[0].Id, secClonedRaes[1].Old_Rental_Apply__c); // 分单后的一览 Name System.assertEquals(true, Pattern.compile('.*_2:.*').matcher(secClonedRaes[0].Name).matches()); System.assertEquals(true, Pattern.compile('.*_2:.*').matcher(secClonedRaes[1].Name).matches()); Test.stopTest(); } }*/ /** * @description 分单后的申请单继续分单 **/ /* static testMethod void testCloneSaveSplit() { system.runAs(getUser()) { setupTestData(); // ---------------------------- 对原申请单分单[相关assert,testSaveSplit()已判断,这里省略] ----------------------- PageReference ref = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(1)); Test.setCurrentPage(ref); RentalApplySplitController controller = new RentalApplySplitController(); Test.startTest(); controller.init(); controller.cloneRas.Split_Apply_Reason__c = '分批发货分单'; controller.saveSplit(); System.assertEquals('ok', controller.saveStatus); // ras[0]--原申请单 ras[1]--新申请单 List ras = [ select Id, Name, Old_Rental_Apply__c, Status__c, Cancel_Select__c, Rental_Apply_Equipment_Set_Cnt__c, Status_Text__c, ShelfUp_ng_num__c, Wei_Received_loaner__c, Wei_Return__c, Shippment_ng_num__c, Split_Apply_Reason__c FROM Rental_Apply__c order by Name]; // raes -- 分出来的新申请单里的一览 List raes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :ras[1].Id order by Name]; // ---------------------------- 对新申请单分单 ----------------------- PageReference secRef = new PageReference('/apex/RentalApplySplit?objId=' + ras[1].Id + '&raesIds=' + raes[0].Id); Test.setCurrentPage(secRef); RentalApplySplitController secController = new RentalApplySplitController(); secController.init(); secController.cloneRas.Split_Apply_Reason__c = '排队分单'; secController.saveSplit(); System.assertEquals('ok', secController.saveStatus); // clonedRas[0]--原申请单 clonedRas[1]--第一次分单后clone的申请单 clonedRas[2]--二次分单后clone的申请单 List clonedRas = [ select Id, Name, Old_Rental_Apply__c, Status__c, Cancel_Select__c, Rental_Apply_Equipment_Set_Cnt__c, Status_Text__c, ShelfUp_ng_num__c, Wei_Received_loaner__c, Wei_Return__c, Shippment_ng_num__c, Split_Apply_Reason__c FROM Rental_Apply__c order by Name]; System.assertEquals(3, clonedRas.size()); System.assertEquals(1, clonedRas[1].Rental_Apply_Equipment_Set_Cnt__c); System.assertEquals(1, clonedRas[2].Rental_Apply_Equipment_Set_Cnt__c); System.assertEquals(clonedRas[0].Name+'_2', clonedRas[2].Name); System.assertEquals(clonedRas[1].Id, clonedRas[2].Old_Rental_Apply__c); System.assertEquals('排队分单', clonedRas[2].Split_Apply_Reason__c); // clonedRaes[0] -- 分到最新申请单中的一览 List clonedRaes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :clonedRas[2].Id order by Name]; System.assertEquals(1, clonedRaes.size()); System.assertEquals(clonedRas[0].Id, clonedRaes[0].Old_Rental_Apply__c); // 分单后的一览 Name System.assertEquals(true, Pattern.compile('.*_2:.*').matcher(clonedRaes[0].Name).matches()); Test.stopTest(); } } */ /** * @description throw exception情况 -- for coverage **/ /*static testMethod void testErrorCover() { system.runAs(getUser()) { setupTestData(); Test.startTest(); // ---------------------------- Error: 请设置备品借出申请的Id ----------------------- PageReference ref1 = new PageReference('/apex/RentalApplySplit?' + 'recid' + '&raesIds=' + raescObjIds(1)); Test.setCurrentPage(ref1); RentalApplySplitController controller1 = new RentalApplySplitController(); controller1.init(); controller1.saveSplit(); // ---------------------------- Error: 请设置备品借出申请一览的Id ----------------------- PageReference ref2 = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(10)); Test.setCurrentPage(ref2); RentalApplySplitController controller2 = new RentalApplySplitController(); controller2.init(); controller2.saveSplit(); // ---------------------------- Error: 已选一览状态不符合分单条件 ----------------------- PageReference ref3 = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(1)+','+'raescObjIds(2)'); Test.setCurrentPage(ref3); RentalApplySplitController controller3 = new RentalApplySplitController(); controller3.init(); controller3.saveSplit(); // ---------------------------- Error: 这个申请单下必须要有一条借出备品一览,不能分单了 ----------------------- PageReference ref4 = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(1)+','+raescObjIds(2)+','+raescObjIds(3)); Test.setCurrentPage(ref4); RentalApplySplitController controller4 = new RentalApplySplitController(); controller4.init(); controller4.saveSplit(); // ---------------------------- Error: 已选一览已被分到其他申请单 ----------------------- PageReference ref5 = new PageReference('/apex/RentalApplySplit?' + recid + '&raesIds=' + raescObjIds(2)); Test.setCurrentPage(ref5); RentalApplySplitController controller5 = new RentalApplySplitController(); controller5.init(); // 新建备品借出申请 Rental_Apply__c raObj1 = new Rental_Apply__c(); raObj1.Name = 'tes1tra'; raObj1.Product_category__c = 'GI'; raObj1.Demo_purpose1__c = '产品试用'; raObj1.demo_purpose2__c = FixtureUtil.raDemo_purpose2MAP.get('shiyongwuxunjia'); raObj1.direct_send__c = '医疗机构'; raObj1.Loaner_received_staff__c = '王1五'; raObj1.Status__c = '草案中'; // 申请单状态为“草案中”时才能修改数量 raObj1.Loaner_received_staff_phone__c = '110'; raObj1.direct_shippment_address__c = '北京市'; raObj1.Hospital__c = raObj.Hospital__c; raObj1.Strategic_dept__c = raObj.Strategic_dept__c; raObj1.Account__c = raObj.Account__c; raObj1.Request_shipping_day__c = Date.toDay(); raObj1.Hope_Lonaer_date_Num__c = 16; //raObj1.Request_return_day__c = Date.toDay(); raObj1.Phone_number__c = '1234567890'; raObj1.Loaner_medical_Staff__c = raObj.Loaner_medical_Staff__c; insert raObj1; List raes = [ select Id, Name, Fixture_Set_Idx__c, Rental_Apply__c, RAES_Status__c, Old_Rental_Apply__c, RetalFSetDetail_Cnt__c, UniqueKey__c, Rental_Num__c, Cancel_Reason__c, Groupby_SortInt__c, Canceled__c, Canceled_Id__c FROM Rental_Apply_Equipment_Set__c where Rental_Apply__c = :raObj.Id and Rental_Num__c = :2 order by Name]; raes[0].Rental_Apply__c = raObj1.Id; FixtureUtil.withoutUpdate(new Rental_Apply_Equipment_Set__c[]{raes[0]}); raObj1.Status__c = '已批准'; FixtureUtil.withoutUpdate(new Rental_Apply__c[]{raObj1}); controller5.saveSplit(); Test.stopTest(); } }*/ }