@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<Rental_Apply_Equipment_Set__c> 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<String,Schema.RecordTypeInfo> 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<Rental_Apply__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply_Equipment_Set_Detail__c> 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<Rental_Apply__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply_Equipment_Set_Detail__c> 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<Rental_Apply__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply__c> 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<Rental_Apply_Equipment_Set__c> 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<Rental_Apply_Equipment_Set__c> 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();
|
|
}
|
}*/
|
}
|