@isTest
|
private class RentalAssignAndQueueWSTest {
|
private static final RecordType campaignRC = [SELECT Id, DeveloperName FROM RecordType WHERE DeveloperName = 'Internal_training' AND SObjectType = 'Campaign'];
|
// AWSServiceTool2没上线就把这部分注释 start 20220408
|
@TestSetup
|
static void setup(){
|
TestDataUtility.CreatePIPolicyConfigurations(new string[]{'Agency_Contact__c','Contact'});
|
}
|
|
@isTest
|
static void Test1(){
|
Test.setMock(HttpCalloutMock.class, new HttpMock());
|
|
List<Agency_Contact__c> lra = new List<Agency_Contact__c>();
|
lra.add(new Agency_Contact__c(
|
));
|
insert lra;
|
Test.startTest();
|
//system.debug(PIHelper.getPIIntegrationInfo('Agency_Contact__c').newEncryptUrl);
|
AWSServiceTool2.EncryptPushCore(Json.serialize(lra),'Agency_Contact__c');
|
AWSServiceTool2.EncryptPushFuture(null,null);
|
Test.stopTest();
|
}
|
|
@isTest
|
static void Test2(){
|
Test.setMock(HttpCalloutMock.class, new HttpMock());
|
|
List<Agency_Contact__c> lra = new List<Agency_Contact__c>();
|
lra.add(new Agency_Contact__c(
|
Aws_Data_Id__c = '123456'
|
));
|
insert lra;
|
Test.startTest();
|
//system.debug(PIHelper.getPIIntegrationInfo('Agency_Contact__c').newEncryptUrl);
|
AWSServiceTool2.EncryptPushCore(Json.serialize(lra),'Agency_Contact__c');
|
Test.stopTest();
|
}
|
|
@isTest
|
static void Test3(){
|
Test.setMock(HttpCalloutMock.class, new HttpMock());
|
|
|
Test.startTest();
|
AWSServiceTool2.EncryptPushData(new string[]{'0031000000O4Cff'});
|
|
Test.stopTest();
|
}
|
|
//@isTest
|
// static void Test2(){
|
// Test.setMock(HttpCalloutMock.class, new HttpMock());
|
|
// List<Agency_Contact__c> lra = new List<Agency_Contact__c>();
|
// lra.add(new Agency_Contact__c(
|
// Id = 'a2R1m0000007BPD',
|
// Aws_Data_Id__c = '123456'
|
// ));
|
// Test.startTest();
|
// //system.debug(PIHelper.getPIIntegrationInfo('Agency_Contact__c').newEncryptUrl);
|
// AWSServiceTool2.EncryptPushCore(Json.serialize(lra),'Agency_Contact__c');
|
// Test.stopTest();
|
// }
|
|
class HttpMock implements HttpCalloutMock{
|
public HTTPResponse respond(HTTPRequest request) {
|
// 创建一个假的回应
|
System.debug('------------------------------------------------------');
|
HttpResponse response = new HttpResponse();
|
string body = '';
|
system.debug(request.getEndpoint());
|
if(request.getEndpoint().contains('token')){
|
system.debug('url=token');
|
response.setHeader('Content-Type', 'application/json');
|
body='{ "message": "", "object": "freqfewqfewewfewfew", "status": "", "success": true, "timestamp": 0, "txId": "" }';
|
} else if(request.getEndpoint().contains('insert')){
|
system.debug('url=Insert');
|
response.setHeader('Content-Type', 'application/json');
|
body='{ "message": "", "object": [ { "dataId": "123456", "directShippmentAddress": "", "directShippmentAddressEncrypt": "", "isDelete": 0, "phoneNumber": "", "phoneNumberEncrypt": "", "sfRecordId": "a2R1m0000007BPD" } ], "status": "", "success": true, "timestamp": 0, "txId": "" }';
|
} else if(request.getEndpoint().contains('update')){
|
system.debug('url=update');
|
response.setHeader('Content-Type', 'application/json');
|
body='{ "message": "", "object": [ { "dataId": "123456", "directShippmentAddress": "", "directShippmentAddressEncrypt": "", "isDelete": 0, "phoneNumber": "", "phoneNumberEncrypt": "", "sfRecordId": "a2R1m0000007BPD" } ], "status": "", "success": true, "timestamp": 0, "txId": "" }';
|
} else{
|
|
}
|
|
response.setBody(body);
|
response.setStatus('OK');
|
response.setStatusCode(200);
|
return response;
|
// }
|
}
|
}
|
// AWSServiceTool2没上线就把这部分注释 end
|
static testMethod void testMethod1() {
|
ControllerUtil.EscapeNFM001Trigger = true; // OLY_OCM-643 追加ControllerUtil.EscapeNFM001Trigger
|
Oly_TriggerHandler.bypass(Product2Handler.Class.getName());
|
// Oly_TriggerHandler.bypass(AssetHandler.Class.getName());
|
Oly_TriggerHandler.bypass(FixtureSetDetailHandler.Class.getName());
|
// Oly_TriggerHandler.bypass(RentalApplyTriggerHandler.Class.getName());
|
// Oly_TriggerHandler.bypass(RentalApplyEquipmentSetHandler.Class.getName());
|
// // Oly_TriggerHandler.bypass(RentalApplyEquipmentSetDetailHandler.Class.getName());
|
User thisUser = [ select Id from User where Id = :UserInfo.getUserId() ];
|
System.runAs ( thisUser ) {
|
// 省
|
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;
|
|
StaticParameter.EscapeAccountTrigger = true;
|
// 戦略科室を得る
|
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,
|
Loaner_categoryI__c='test01',Loaner_categoryII__c='test01');
|
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,
|
Loaner_categoryI__c='test02',Loaner_categoryII__c='test02');
|
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,
|
Loaner_categoryI__c='test03',Loaner_categoryII__c='test03');
|
insert new Product2[] {pro1, pro2, pro3};
|
|
//备品借出申请
|
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.Request_return_day__c = Date.toDay();
|
raObj.Status__c = '草案中';
|
raObj.Phone_number__c = '1234567890';
|
raObj.Loaner_medical_Staff__c = contact2.Id;
|
raObj.Cross_Region_Assign__c = null;
|
insert raObj;
|
|
// 保有设备
|
Asset asset1 = new Asset(Asset_Owner__c = 'Olympus');
|
asset1.RecordTypeId = System.Label.Asset_RecordType;
|
asset1.SerialNumber = 'asset1';
|
asset1.Name = 'asset1';
|
asset1.AccountId = dep.Id;
|
asset1.Department_Class__c = strategicDep[0].Id;
|
asset1.Hospital__c = hospital.Id;
|
asset1.Product2Id = pro1.Id;
|
asset1.Quantity = 1;
|
asset1.Status = '不明';
|
asset1.Manage_type__c = '个体管理';
|
asset1.Loaner_accsessary__c = false;
|
asset1.Out_of_wh__c = 0;
|
asset1.Salesdepartment__c = '1.华北营业本部';
|
asset1.Internal_asset_location__c = '北京 备品中心';
|
asset1.Product_category__c = 'GI';
|
asset1.Equipment_Type__c = '产品试用';
|
asset1.SalesProvince__c = '北京';
|
asset1.CompanyOfEquipment__c = '北京';
|
asset1.Internal_Asset_number__c = '0001';
|
|
Asset asset2 = new Asset(Asset_Owner__c = 'Olympus');
|
asset2.RecordTypeId = System.Label.Asset_RecordType;
|
asset2.SerialNumber = 'asset2';
|
asset2.Name = 'asset2';
|
asset2.AccountId = dep.Id;
|
asset2.Department_Class__c = strategicDep[0].Id;
|
asset2.Hospital__c = hospital.Id;
|
asset2.Product2Id = pro2.Id;
|
asset2.Quantity = 1;
|
asset2.Status = '不明';
|
asset2.Manage_type__c = '个体管理';
|
asset2.Loaner_accsessary__c = true;
|
asset2.Out_of_wh__c = 0;
|
asset2.Salesdepartment__c = '1.华北营业本部';
|
asset2.Internal_asset_location__c = '北京 备品中心';
|
asset2.Product_category__c = 'GI';
|
asset2.Equipment_Type__c = '产品试用';
|
asset2.SalesProvince__c = '北京';
|
asset2.CompanyOfEquipment__c = '北京';
|
asset2.Internal_Asset_number__c = '0002';
|
|
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 = 50;
|
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';
|
insert new Asset[] {asset1, asset2, asset3};
|
|
// 备品配套
|
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 fsdObjA1 = new Fixture_Set_Detail__c();
|
fsdObjA1.Name = '备品配套明细名1';
|
fsdObjA1.Name_CHN_Created__c = '中文名称1';
|
fsdObjA1.Product2__c = pro1.Id;
|
fsdObjA1.Fixture_Set__c = fsObj1.Id;
|
fsdObjA1.Is_Body__c = true;
|
fsdObjA1.Is_Optional__c = false;
|
fsdObjA1.UniqueKey__c = fsObj1.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 = fsObj1.Id;
|
fsdObjA2.Is_Body__c = false;
|
fsdObjA2.Is_Optional__c = true;
|
fsdObjA2.UniqueKey__c = fsObj1.Id + ':' + pro2.Id;
|
fsdObjA2.SortInt__c = 2;
|
|
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 = fsObj1.Id;
|
fsdObjA3.Is_Body__c = false;
|
fsdObjA3.Is_Optional__c = true;
|
fsdObjA3.UniqueKey__c = fsObj1.Id + ':' + pro3.Id;
|
fsdObjA3.SortInt__c = 3;
|
insert new Fixture_Set_Detail__c[] {fsdObjA1,fsdObjA2,fsdObjA3};
|
|
// 借出备品配套一览
|
Rental_Apply_Equipment_Set__c raesObj = new Rental_Apply_Equipment_Set__c();
|
raesObj.Rental_Apply__c = raObj.Id;
|
raesObj.Fixture_Set__c = fsObj1.Id;
|
raesObj.Cancel_Select__c = false;
|
raesObj.Rental_Start_Date__c = Date.toDay();
|
raesObj.Rental_End_Date__c = Date.toDay();
|
raesObj.IndexFromUniqueKey__c = 1;
|
raesObj.UniqueKey__c = '1:'+ fsObj1.Id + ':1';
|
insert raesObj;
|
|
// 借出备品配套一览明细
|
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 = 1;
|
raesdObj1.Queue_Number__c = null;
|
raesdObj1.Is_Body__c = true;
|
raesdObj1.Rental_Apply_Equipment_Set__c = raesObj.Id;
|
raesdObj1.IndexFromUniqueKey__c = 1;
|
raesdObj1.UniqueKey__c = '1:'+ raesObj.Id + ':' + fsdObjA1.Id + ':1';
|
raesdObj1.FSD_OneToOneAccessory_Cnt__c = 0;
|
raesdObj1.FSD_Is_Optional__c = false;
|
raesdObj1.FSD_Is_OneToOne__c = false;
|
raesdObj1.ApplyPersonAppended__c = false;
|
raesdObj1.FSD_Fixture_Model_No__c = 'n01';
|
raesdObj1.Fixture_Model_No_text__c = 'n01';
|
|
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 = 1;
|
raesdObj2.Queue_Number__c = null;
|
raesdObj2.Is_Body__c = false;
|
raesdObj2.Rental_Apply_Equipment_Set__c = raesObj.Id;
|
raesdObj2.IndexFromUniqueKey__c = 2;
|
raesdObj2.UniqueKey__c = '1:'+ raesObj.Id + ':' + fsdObjA2.Id + ':2';
|
raesdObj2.FSD_OneToOneAccessory_Cnt__c = 0;
|
raesdObj2.FSD_Is_Optional__c = false;
|
raesdObj2.FSD_Is_OneToOne__c = false;
|
raesdObj2.ApplyPersonAppended__c = false;
|
raesdObj2.FSD_Fixture_Model_No__c = 'n02';
|
raesdObj2.Fixture_Model_No_text__c = 'n02';
|
|
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 = 1;
|
raesdObj3.Queue_Number__c = 1;
|
raesdObj3.Is_Body__c = false;
|
raesdObj3.Rental_Apply_Equipment_Set__c = raesObj.Id;
|
raesdObj3.IndexFromUniqueKey__c = 3;
|
raesdObj3.UniqueKey__c = '1:'+ raesObj.Id + ':' + fsdObjA3.Id + ':3';
|
raesdObj3.FSD_OneToOneAccessory_Cnt__c = 2;
|
raesdObj3.FSD_Is_Optional__c = false;
|
raesdObj3.FSD_Is_OneToOne__c = false;
|
raesdObj3.ApplyPersonAppended__c = false;
|
raesdObj3.FSD_Fixture_Model_No__c = 'n03';
|
raesdObj3.Fixture_Model_No_text__c = 'n03';
|
insert new Rental_Apply_Equipment_Set_Detail__c[] {raesdObj1,raesdObj2,raesdObj3};
|
System.debug('raObj.o'+raObj.Status__c+'123123=='+raesObj.RAES_Status__c + '000' + raesdObj1.RAESD_Status__c);
|
|
// 申请单变为已批准
|
raObj.Status__c = '已批准';
|
update raObj;
|
|
Repair__c repairObj1 = new Repair__c();
|
repairObj1.Delivered_Product__c = asset1.Id;
|
repairObj1.Hospital__c = hospital.Id;
|
repairObj1.Department_Class__c = strategicDep[0].Id;
|
repairObj1.Account__c = dep.Id;
|
repairObj1.SalesOfficeCode_selection__c = '北京石景山';
|
repairObj1.On_site_repair__c = 'RC修理';
|
repairObj1.AWS_Data_Id__c = 'test001';
|
repairObj1.Failure_Occurrence_Date__c = Date.today();
|
insert new Repair__c[]{repairObj1};
|
List<String> ids = new List<String>();
|
ids.add(raObj.Id);
|
Test.startTest();
|
List<Rental_Apply_Equipment_Set_Detail__c> raesdObjList = [SELECT Id,Cancel_Select__c, Rental_Apply_Equipment_Set__c, Rental_Apply_Equipment_Set__r.RAES_Status__c,EquipmentSet_Detail_Status_Status__c
|
FROM Rental_Apply_Equipment_Set_Detail__c
|
WHERE Rental_Apply__c IN: ids
|
];
|
List<Rental_Apply_Equipment_Set__c> raesObjList = [SELECT Id, RAES_Status__c
|
FROM Rental_Apply_Equipment_Set__c
|
WHERE Rental_Apply__c IN: ids
|
];
|
List<Rental_Apply__c> raObjList = [SELECT Id, Cross_Region_Assign__c
|
FROM Rental_Apply__c
|
WHERE Id IN: ids
|
];
|
System.debug('raObj.o'+raObj.Status__c+'123123'+raesdObj1.EquipmentSet_Detail_Status_Status__c+'123123=='+raesObj.RAES_Status__c);
|
System.debug('raObj.o'+raObj.Status__c+'123123'+raesdObjList+'123123=='+raesObj.RAES_Status__c);
|
System.debug('raObj.o'+raObj.Status__c+'123123'+raesObjList+'123123=='+raesObj.RAES_Status__c);
|
System.enqueueJob(new RentalFixtureSetAssignAndQueueWebService(ids));
|
RentalFixtureSetAssignAndQueueWebService.setAssignAndQueue(ids);
|
Test.stopTest();
|
}
|
}
|
|
static testMethod void myUnitTest1() {
|
Oly_TriggerHandler.bypass('ContactTrigger');
|
Oly_TriggerHandler.bypass('ContactTriggerHandler');
|
Oly_TriggerHandler.bypass('AssetTrigger');
|
Oly_TriggerHandler.bypass('AssetHandler');
|
Oly_TriggerHandler.bypass('MaintenanceContractTrigger');
|
Oly_TriggerHandler.bypass('MaintenanceContractAfterUpdate');
|
Oly_TriggerHandler.bypass('MaintenanceContractBeforeDelete');
|
Oly_TriggerHandler.bypass('MaintenanceContractHpDeptUpd');
|
Oly_TriggerHandler.bypass('NFM106Controller');
|
Oly_TriggerHandler.bypass('NFM106Trigger');
|
Oly_TriggerHandler.bypass('AssetRecordTypeUpd');
|
Oly_TriggerHandler.bypass('NFM101Controller');
|
Oly_TriggerHandler.bypass('NFM001Controller');
|
Oly_TriggerHandler.bypass('SyncProduct2');
|
Oly_TriggerHandler.bypass('RentalApplyBeforeUpdate');
|
Oly_TriggerHandler.bypass('RentalApplyShareHandler');
|
Oly_TriggerHandler.bypass('ContactTriggerHandler');
|
// Oly_TriggerHandler.bypass('RentalApplyEquipmentSetDetailHandler');
|
|
ControllerUtil.EscapeNFM001Trigger = true;
|
StaticParameter.EscapeNFM001Trigger = true;
|
StaticParameter.EscapeNFM001AgencyContractTrigger = true;
|
StaticParameter.EscapeNFM001AgencyContractTrigger2 = true;
|
StaticParameter.EscapeOppandStaTrigger = true;
|
StaticParameter.EscapeRaTrigger = true;
|
|
User thisUser = [ select Id from User where Id = :UserInfo.getUserId() ];
|
System.runAs ( thisUser ) {
|
// om001037 康秋文 om001744-吕世伟
|
User myUser_Test = [select ID,name,email,Work_Location__c from user where Employee_No__c = 'om001814'];
|
// 省
|
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;
|
|
Campaign target = new Campaign();
|
target.Name = 'test campaign';
|
target.RecordTypeId = campaignRC.Id; // 内部トレーニング
|
insert target;
|
// 病院を作る
|
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 = new Account();
|
strategicDep.recordtypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Account' and DeveloperName = 'Department_Class_OTH'].id;
|
strategicDep.Name = 'Olympus社内 其他';
|
strategicDep.Department_Class_Label__c = '其他';
|
strategicDep.Hospital__c = hospital.Id;
|
strategicDep.AgentCode_Ext__c = '9999999';
|
strategicDep.ParentId = hospital.Id;
|
insert strategicDep;
|
|
// 診療科を作る
|
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.Department_Class_Label__c = '其他';
|
dep.AgentCode_Ext__c = '9999998';
|
dep.ParentId = strategicDep.Id;
|
dep.Department_Class__c = strategicDep.Id;
|
dep.Hospital__c = hospital.Id;
|
// dep.Department_Class_Name__c = '其他';
|
insert dep;
|
|
// Contact contact2 = new Contact();
|
// contact2.AccountId = dep.Id;
|
// contact2.LastName = '責任者';
|
// 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;
|
|
// 产品
|
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',
|
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',
|
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',
|
ProductCode_Ext__c='pc03',Manual_Entry__c=false);
|
insert new Product2[] {pro1, pro2, pro3};
|
|
|
//---------------------------主体 两个附属品(个体管理 数量管理)
|
// 保有设备A (主体)
|
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.Id;
|
assetA1.Hospital__c = hospital.Id;
|
assetA1.Product2Id = pro1.Id;
|
// assetA1.Quantity = 1;
|
assetA1.Status = '有库存';
|
assetA1.AssetManageConfirm__c = true;
|
assetA1.Manage_type__c = '个体管理';
|
assetA1.Loaner_accsessary__c = false;
|
assetA1.Product_category__c = 'GI';
|
assetA1.Delete_Flag__c = false;
|
assetA1.Freeze_sign__c = false;
|
assetA1.Out_of_wh__c = 0;
|
assetA1.Salesdepartment__c = '2.东北营业本部';
|
assetA1.Internal_asset_location__c = '长春';
|
assetA1.Product_category__c = 'GI';
|
assetA1.Equipment_Type__c = '产品试用';
|
assetA1.SalesProvince__c = '天津';
|
assetA1.Quantity = 999;
|
// 保有设备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.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.Product_category__c = 'GI';
|
assetA2.Delete_Flag__c = false;
|
assetA2.Freeze_sign__c = false;
|
assetA2.Out_of_wh__c = 3;
|
assetA2.Salesdepartment__c = '1.华北营业本部';
|
assetA2.Internal_asset_location__c = '天津';
|
assetA2.Product_category__c = 'GI';
|
assetA2.Equipment_Type__c = '产品试用';
|
assetA2.SalesProvince__c = '天津';
|
assetA2.Quantity = 999;
|
// 保有设备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.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.Product_category__c = 'GI';
|
assetA3.Delete_Flag__c = false;
|
assetA3.Freeze_sign__c = false;
|
assetA3.Out_of_wh__c = 0;
|
assetA3.Salesdepartment__c = '1.华北营业本部';
|
assetA3.Internal_asset_location__c = '天津';
|
assetA3.Product_category__c = 'GI';
|
assetA3.Equipment_Type__c = '产品试用';
|
assetA3.SalesProvince__c = '天津';
|
assetA3.Quantity = 999;
|
insert new Asset[] {assetA1, assetA2, assetA3};
|
|
Fixture_Set__c fsObj1 = new Fixture_Set__c();
|
fsObj1.Name = 'n01';
|
fsObj1.Loaner_code__c = 'n01';
|
fsObj1.Fixture_Set_Body_Model_No__c = 'n01';
|
fsObj1.Loaner_name__c = 'name1';
|
fsObj1.Loaner_categoryI__c = '周边仪器';
|
fsObj1.Loaner_categoryII__c = '台车';
|
insert fsObj1;
|
// 备品配套明细
|
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 = fsObj1.Id;
|
fsdObjA1.Is_Body__c = true;
|
fsdObjA1.Is_Optional__c = false;
|
fsdObjA1.Is_OneToOne__c = false;
|
fsdObjA1.UniqueKey__c = fsObj1.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 = fsObj1.Id;
|
fsdObjA2.Is_Body__c = false;
|
fsdObjA2.Is_Optional__c = false;
|
fsdObjA2.Is_OneToOne__c = true;
|
fsdObjA2.UniqueKey__c = fsObj1.Id + ':' + pro2.Id;
|
fsdObjA2.SortInt__c = 2;
|
|
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 = fsObj1.Id;
|
fsdObjA3.Is_Body__c = false;
|
fsdObjA3.Is_Optional__c = false;
|
fsdObjA3.Is_OneToOne__c = true;
|
fsdObjA3.UniqueKey__c = fsObj1.Id + ':' + pro3.Id;
|
fsdObjA3.SortInt__c = 3;
|
insert new Fixture_Set_Detail__c[] {fsdObjA1, fsdObjA2, fsdObjA3};
|
|
|
Rental_Apply__c raObj = new Rental_Apply__c();
|
raObj.Name = 'testra';
|
raObj.RecordTypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Rental_Apply__c' and DeveloperName = 'StandardRequest'].id;
|
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 = '11012';
|
raObj.direct_shippment_address__c = '天津市';
|
raObj.Hospital__c = hospital.Id;
|
raObj.Strategic_dept__c = strategicDep.Id;
|
raObj.Account__c = dep.Id;
|
raObj.Request_shipping_day__c = Date.toDay(); // 希望到货日
|
raObj.Hope_Lonaer_date_Num__c = 1; // 希望借用天数
|
raObj.applyUser__c = myUser_Test.id;
|
raObj.Person_In_Charge__c = myUser_Test.id;
|
raObj.OwnerId = myUser_Test.id;
|
raObj.Phone_number__c = '1234567890';
|
raObj.Loaner_medical_Staff__c = contact2.Id;
|
raObj.Add_Approval_Status__c = '';
|
// raObj.OPD_OrderNum__c = 1;
|
raObj.Rental_Status__c = '已批准';
|
raObj.Request_approval_time__c = Datetime.now();
|
insert raObj;
|
|
// 借出备品配套一览
|
Rental_Apply__c raObjSelect = [SELECT Id,RA_Status__c,RA_Status_Text__c,WorkPlace__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 = fsObj1.Id;
|
raesObj.IndexFromUniqueKey__c = 1;
|
raesObj.UniqueKey__c = '1:'+ fsObj1.Id + ':1';
|
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.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 = '产品试用';
|
insert raesdObj1;
|
raesObj.First_RAESD__c = raesdObj1.Id;
|
update raesObj;
|
// // 借出备品配套一览明细
|
// 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.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 = '产品试用';
|
// 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.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;
|
|
raObj.Status__c = '已批准';
|
update raObj;
|
|
// raesdObj1.Equipment_Type_text__c = '产品试用';
|
// update raesdObj1;
|
// raObj.direct_shippment_address__c = 'test2';
|
// upsert raObj;
|
// 借出备品配套一览
|
// List<Rental_Apply__c> raObjSelectList = [SELECT Id,RA_Status__c,RA_Status_Text__c FROM Rental_Apply__c WHERE Id =: raObj.Id];
|
List<String> raIdList = new List<String>();
|
// for(Rental_Apply__c ra:raObjSelectList){
|
raIdList.add(raObj.Id);
|
// }
|
// System.debug('zyhtest===Test'+raObjSelectList);
|
// System.debug('zyhtest===Test'+raesdObj1.Equipment_Type_text__c+raesdObj2.Equipment_Type_text__c+raesdObj3.Equipment_Type_text__c);
|
System.Test.startTest();
|
// Database.executeBatch(new AuthRentalApplySplitBatch(raIdList),1);
|
System.enqueueJob(new RentalFixtureSetAssignAndQueueWebService(raIdList));
|
Set<String> str = new Set<String>();
|
str.add('arg0');
|
RentalFixtureSetAssignAndQueueWebService.makeAccessorySoql('123','123', str,'123');
|
RentalFixtureSetAssignAndQueueWebService.getCampaignType('2M');
|
RentalFixtureSetAssignAndQueueWebService.getCampaignType('2S1');
|
RentalFixtureSetAssignAndQueueWebService.getCampaignType('2S5');
|
RentalFixtureSetAssignAndQueueWebService.getInternalAssetlocation('GZ');
|
RentalFixtureSetAssignAndQueueWebService.getInternalAssetlocation('SH');
|
RentalFixtureSetAssignAndQueueWebService.getInternalAssetlocation('');
|
// AuthRentalApplySplitController ausplit = new AuthRentalApplySplitController();
|
// ausplit.init(raIdList);
|
System.Test.stopTest();
|
}
|
}
|
static testMethod void myUnitTest2() {
|
Oly_TriggerHandler.bypass('ContactTrigger');
|
Oly_TriggerHandler.bypass('ContactTriggerHandler');
|
Oly_TriggerHandler.bypass('AssetTrigger');
|
Oly_TriggerHandler.bypass('AssetHandler');
|
Oly_TriggerHandler.bypass('MaintenanceContractTrigger');
|
Oly_TriggerHandler.bypass('MaintenanceContractAfterUpdate');
|
Oly_TriggerHandler.bypass('MaintenanceContractBeforeDelete');
|
Oly_TriggerHandler.bypass('MaintenanceContractHpDeptUpd');
|
Oly_TriggerHandler.bypass('NFM106Controller');
|
Oly_TriggerHandler.bypass('NFM106Trigger');
|
Oly_TriggerHandler.bypass('AssetRecordTypeUpd');
|
Oly_TriggerHandler.bypass('NFM101Controller');
|
Oly_TriggerHandler.bypass('NFM001Controller');
|
Oly_TriggerHandler.bypass('SyncProduct2');
|
Oly_TriggerHandler.bypass('RentalApplyBeforeUpdate');
|
Oly_TriggerHandler.bypass('ContactTriggerHandler');
|
// Oly_TriggerHandler.bypass('RentalApplyEquipmentSetDetailHandler');
|
|
ControllerUtil.EscapeNFM001Trigger = true;
|
StaticParameter.EscapeNFM001Trigger = true;
|
StaticParameter.EscapeNFM001AgencyContractTrigger = true;
|
StaticParameter.EscapeNFM001AgencyContractTrigger2 = true;
|
StaticParameter.EscapeOppandStaTrigger = true;
|
StaticParameter.EscapeRaTrigger = true;
|
|
User thisUser = [ select Id from User where Id = :UserInfo.getUserId() ];
|
System.runAs ( thisUser ) {
|
// om001037 康秋文 om001744-吕世伟
|
User myUser_Test = [select ID,name,email,Work_Location__c from user where Employee_No__c = 'om001744'];
|
// 省
|
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;
|
|
Campaign target = new Campaign();
|
target.Name = 'test campaign';
|
target.RecordTypeId = campaignRC.Id; // 内部トレーニング
|
insert target;
|
// 病院を作る
|
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 = new Account();
|
strategicDep.recordtypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Account' and DeveloperName = 'Department_Class_OTH'].id;
|
strategicDep.Name = 'Olympus社内 其他';
|
strategicDep.Department_Class_Label__c = '其他';
|
strategicDep.Hospital__c = hospital.Id;
|
strategicDep.AgentCode_Ext__c = '9999999';
|
strategicDep.ParentId = hospital.Id;
|
insert strategicDep;
|
|
// 診療科を作る
|
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.Department_Class_Label__c = '其他';
|
dep.AgentCode_Ext__c = '9999998';
|
dep.ParentId = strategicDep.Id;
|
dep.Department_Class__c = strategicDep.Id;
|
dep.Hospital__c = hospital.Id;
|
// dep.Department_Class_Name__c = '其他';
|
insert dep;
|
|
// Contact contact2 = new Contact();
|
// contact2.AccountId = dep.Id;
|
// contact2.LastName = '責任者';
|
// 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;
|
|
// 产品
|
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',
|
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',
|
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',
|
ProductCode_Ext__c='pc03',Manual_Entry__c=false);
|
insert new Product2[] {pro1, pro2, pro3};
|
|
|
//---------------------------主体 两个附属品(个体管理 数量管理)
|
// 保有设备A (主体)
|
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.Id;
|
assetA1.Hospital__c = hospital.Id;
|
assetA1.Product2Id = pro1.Id;
|
// assetA1.Quantity = 1;
|
assetA1.Status = '有库存';
|
assetA1.AssetManageConfirm__c = true;
|
assetA1.Manage_type__c = '个体管理';
|
assetA1.Loaner_accsessary__c = false;
|
assetA1.Product_category__c = 'GI';
|
assetA1.Delete_Flag__c = false;
|
assetA1.Freeze_sign__c = false;
|
assetA1.Out_of_wh__c = 0;
|
assetA1.Salesdepartment__c = '2.东北营业本部';
|
assetA1.Internal_asset_location__c = '长春';
|
assetA1.Product_category__c = 'GI';
|
assetA1.Equipment_Type__c = '产品试用';
|
assetA1.SalesProvince__c = '天津';
|
assetA1.Quantity = 999;
|
// 保有设备A (主体)
|
Asset assetA4 = new Asset(Asset_Owner__c = 'Olympus');
|
assetA4.RecordTypeId = System.Label.Asset_RecordType;
|
assetA4.SerialNumber = 'ass01';
|
assetA4.Name = 'ass01';
|
assetA4.AccountId = dep.Id;
|
assetA4.Department_Class__c = strategicDep.Id;
|
assetA4.Hospital__c = hospital.Id;
|
assetA4.Product2Id = pro1.Id;
|
// assetA1.Quantity = 1;
|
assetA4.Status = '有库存';
|
assetA4.AssetManageConfirm__c = true;
|
assetA4.Manage_type__c = '数量管理';
|
assetA4.Loaner_accsessary__c = false;
|
assetA4.Product_category__c = 'GI';
|
assetA4.Delete_Flag__c = false;
|
assetA4.Freeze_sign__c = false;
|
assetA4.Out_of_wh__c = 0;
|
assetA4.Salesdepartment__c = '0.备品中心';
|
assetA4.Internal_asset_location__c = '长春';
|
assetA4.Product_category__c = 'GI';
|
assetA4.Equipment_Type__c = '产品试用';
|
assetA4.SalesProvince__c = '天津';
|
assetA4.Quantity = 999;
|
// 保有设备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.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.Product_category__c = 'GI';
|
assetA2.Delete_Flag__c = false;
|
assetA2.Freeze_sign__c = false;
|
assetA2.Out_of_wh__c = 3;
|
assetA2.Salesdepartment__c = '1.华北营业本部';
|
assetA2.Internal_asset_location__c = '天津';
|
assetA2.Product_category__c = 'GI';
|
assetA2.Equipment_Type__c = '产品试用';
|
assetA2.SalesProvince__c = '天津';
|
assetA2.Quantity = 999;
|
// 保有设备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.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.Product_category__c = 'GI';
|
assetA3.Delete_Flag__c = false;
|
assetA3.Freeze_sign__c = false;
|
assetA3.Out_of_wh__c = 0;
|
assetA3.Salesdepartment__c = '1.华北营业本部';
|
assetA3.Internal_asset_location__c = '北京';
|
assetA3.Product_category__c = 'GI';
|
assetA3.Equipment_Type__c = '产品试用';
|
assetA3.SalesProvince__c = '天津';
|
assetA3.Quantity = 999;
|
insert new Asset[] {assetA1, assetA2, assetA3};
|
|
Fixture_Set__c fsObj1 = new Fixture_Set__c();
|
fsObj1.Name = 'n01';
|
fsObj1.Loaner_code__c = 'n01';
|
fsObj1.Fixture_Set_Body_Model_No__c = 'n01';
|
fsObj1.Loaner_name__c = 'name1';
|
fsObj1.Loaner_categoryI__c = '周边仪器';
|
fsObj1.Loaner_categoryII__c = '台车';
|
insert fsObj1;
|
// 备品配套明细
|
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 = fsObj1.Id;
|
fsdObjA1.Is_Body__c = true;
|
fsdObjA1.Is_Optional__c = false;
|
fsdObjA1.Is_OneToOne__c = false;
|
fsdObjA1.UniqueKey__c = fsObj1.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 = fsObj1.Id;
|
fsdObjA2.Is_Body__c = false;
|
fsdObjA2.Is_Optional__c = false;
|
fsdObjA2.Is_OneToOne__c = true;
|
fsdObjA2.UniqueKey__c = fsObj1.Id + ':' + pro2.Id;
|
fsdObjA2.SortInt__c = 2;
|
|
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 = fsObj1.Id;
|
fsdObjA3.Is_Body__c = false;
|
fsdObjA3.Is_Optional__c = false;
|
fsdObjA3.Is_OneToOne__c = true;
|
fsdObjA3.UniqueKey__c = fsObj1.Id + ':' + pro3.Id;
|
fsdObjA3.SortInt__c = 3;
|
insert new Fixture_Set_Detail__c[] {fsdObjA1, fsdObjA2, fsdObjA3};
|
// OPDPlan__c oPDPlan0 = new OPDPlan__c();
|
// oPDPlan0.Status__c = '草案中';
|
// oPDPlan0.OPDPlan_ImplementDate__c = Date.today().addDays(1);
|
// oPDPlan0.NoOpp_Reason__c = 'HCP对应';
|
// insert oPDPlan0;
|
|
Rental_Apply__c raObj = new Rental_Apply__c();
|
raObj.Name = 'testra';
|
raObj.RecordTypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Rental_Apply__c' and DeveloperName = 'StandardRequest'].id;
|
raObj.Product_category__c = 'GI';
|
raObj.Demo_purpose1__c = '维修代用';
|
raObj.demo_purpose2__c = FixtureUtil.raDemo_purpose2MAP.get('yibanyonghu');
|
raObj.direct_send__c = '医疗机构';
|
raObj.Loaner_received_staff__c = '王五';
|
raObj.Loaner_received_staff_phone__c = '11012';
|
raObj.direct_shippment_address__c = '天津市';
|
raObj.Hospital__c = hospital.Id;
|
raObj.Strategic_dept__c = strategicDep.Id;
|
raObj.Account__c = dep.Id;
|
raObj.Request_shipping_day__c = Date.toDay(); // 希望到货日
|
// raObj.Hope_Lonaer_date_Num__c = 1; // 希望借用天数
|
raObj.applyUser__c = myUser_Test.id;
|
raObj.Person_In_Charge__c = myUser_Test.id;
|
raObj.OwnerId = myUser_Test.id;
|
raObj.Phone_number__c = '1234567890';
|
raObj.Loaner_medical_Staff__c = contact2.Id;
|
raObj.Add_Approval_Status__c = '';
|
// raObj.OPD_OrderNum__c = 1;
|
raObj.Rental_Status__c = '已批准';
|
raObj.Request_approval_time__c = Datetime.now();
|
insert raObj;
|
|
// 借出备品配套一览
|
Rental_Apply__c raObjSelect = [SELECT Id,RA_Status__c,RA_Status_Text__c,WorkPlace__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 = fsObj1.Id;
|
raesObj.IndexFromUniqueKey__c = 1;
|
raesObj.UniqueKey__c = '1:'+ fsObj1.Id + ':1';
|
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.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 = '产品试用';
|
insert raesdObj1;
|
raesObj.First_RAESD__c = raesdObj1.Id;
|
update raesObj;
|
// // 借出备品配套一览明细
|
// 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.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 = '产品试用';
|
// 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.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;
|
|
raObj.Status__c = '已批准';
|
update raObj;
|
|
// raesdObj1.Equipment_Type_text__c = '产品试用';
|
// update raesdObj1;
|
// raObj.direct_shippment_address__c = 'test2';
|
// upsert raObj;
|
// 借出备品配套一览
|
// List<Rental_Apply__c> raObjSelectList = [SELECT Id,RA_Status__c,RA_Status_Text__c FROM Rental_Apply__c WHERE Id =: raObj.Id];
|
List<String> raIdList = new List<String>();
|
// for(Rental_Apply__c ra:raObjSelectList){
|
raIdList.add(raObj.Id);
|
// }
|
// System.debug('zyhtest===Test'+raObjSelectList);
|
// System.debug('zyhtest===Test'+raesdObj1.Equipment_Type_text__c+raesdObj2.Equipment_Type_text__c+raesdObj3.Equipment_Type_text__c);
|
System.Test.startTest();
|
// Database.executeBatch(new AuthRentalApplySplitBatch(raIdList),1);
|
System.enqueueJob(new RentalFixtureSetAssignAndQueueWebService(raIdList));
|
Set<String> str = new Set<String>();
|
str.add('arg0');
|
RentalFixtureSetAssignAndQueueWebService.makeAccessorySoql('123','123', str,'123');
|
RentalFixtureSetAssignAndQueueWebService.getCampaignType('2M');
|
RentalFixtureSetAssignAndQueueWebService.getCampaignType('2S1');
|
RentalFixtureSetAssignAndQueueWebService.getCampaignType('2S5');
|
RentalFixtureSetAssignAndQueueWebService.getInternalAssetlocation('GZ');
|
RentalFixtureSetAssignAndQueueWebService.getInternalAssetlocation('SH');
|
RentalFixtureSetAssignAndQueueWebService.getInternalAssetlocation('');
|
RentalFixtureSetAssignAndQueueWebService.upFugailv();
|
// AuthRentalApplySplitController ausplit = new AuthRentalApplySplitController();
|
// ausplit.init(raIdList);
|
System.Test.stopTest();
|
}
|
}
|
}
|