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