New file |
| | |
| | | // 2023/05/11 多年保修合同 合同消费率分子分母赋值 Batch测试类 |
| | | @isTest |
| | | private class SummaryConsumptionRateBatchTest { |
| | | static testMethod void testBatch() { |
| | | System.Test.startTest(); |
| | | database.executeBatch(new SummaryConsumptionRateBatch(),200); |
| | | List<Maintenance_Contract__c> mcUpdateList = [SELECT Id,Name,VM_Consumption_Rate_Molecular__c,VM_Consumption_Rate_Denominator__c FROM |
| | | Maintenance_Contract__c WHERE RecordType_Name__c = '多年保修合同' AND RecordType_DeveloperName__c = 'VM_Contract' |
| | | AND (Status__c = '契約' OR Status__c = '契約満了') And Name = '::tect contract' |
| | | ]; |
| | | System.assert(mcUpdateList.size() > 0); |
| | | System.Test.stopTest(); |
| | | } |
| | | @testSetup |
| | | private static void setUpDate(){ |
| | | //2023/03/30 跳过RepairAgainAnTrigger |
| | | // StaticParameter.RepairAgainAnStaTrigger = false; |
| | | // 病院を作る |
| | | Date toDayTime = Date.today(); |
| | | Account hospital = new Account(); |
| | | hospital.recordtypeId = [Select Id FROM RecordType WHERE IsActive = true and SobjectType = 'Account' and DeveloperName = 'HP'].id; |
| | | hospital.Name = 'hospitalabc'; |
| | | hospital.Is_Active__c = '有効'; |
| | | hospital.Attribute_Type__c = '卫生部'; |
| | | hospital.Speciality_Type__c = '综合医院'; |
| | | hospital.Grade__c = '一级'; |
| | | hospital.IF_Coverage_Target_HP__c = '1'; |
| | | hospital.OCM_Category__c = 'SLTV'; |
| | | hospital.Is_Medical__c = '医疗机构'; |
| | | hospital.Town__c = '东京'; |
| | | Oly_TriggerHandler.bypass('NFM701ControllerHandler'); |
| | | Oly_TriggerHandler.bypass('UpdateContractAimAmountHandler'); |
| | | 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 = System.Label.Account_Asset_FJZ; |
| | | dep.ParentId = strategicDep[0].Id; |
| | | dep.Department_Class__c = strategicDep[0].Id; |
| | | dep.Hospital__c = hospital.Id; |
| | | Oly_TriggerHandler.bypass('NFM701ControllerHandler'); |
| | | Oly_TriggerHandler.bypass('UpdateContractAimAmountHandler'); |
| | | insert dep; |
| | | |
| | | |
| | | |
| | | // 产品 |
| | | Product2 pro1 = new Product2(Name='name01',IsActive=true,Family='GI', |
| | | Category5__c = '11', |
| | | Service_Category3__c ='软性镜', |
| | | Fixture_Model_No__c='n01',Serial_Lot_No__c='S/N tracing', |
| | | Fixture_Model_No_T__c = 'n01', |
| | | Maintenance_Price_Year__c = 999, |
| | | Extend_Gurantee_Start_MD__c = Date.newInstance(toDayTime.year(),3,2), |
| | | Extend_Gurantee_End_MD__c = Date.newInstance(3999,12,31), |
| | | Extend_new_product_gurantee_MD__c = true, |
| | | PartSupplyFinishDate__c = Date.newInstance(toDayTime.year()+2,3,2), |
| | | ProductCode_Ext__c='pc01',Manual_Entry__c=false,Brand_Name__c='奥林巴斯', |
| | | Category2__c='本体', |
| | | Category3__c='电子镜'); |
| | | Product2 pro2 = new Product2(Name='name02',IsActive=true,Family='GI', |
| | | Service_Category3__c ='软性镜', |
| | | Fixture_Model_No__c='n02',Serial_Lot_No__c='Lot tracing', |
| | | ProductCode_Ext__c='pc02',Manual_Entry__c=false,Brand_Name__c='奥林巴斯', |
| | | Category2__c='本体', |
| | | Extend_Gurantee_Start_MD__c = Date.newInstance(toDayTime.year(),3,2), |
| | | Extend_Gurantee_End_MD__c = Date.newInstance(3999,12,31), |
| | | Extend_new_product_gurantee_MD__c = true, |
| | | PartSupplyFinishDate__c = Date.newInstance(toDayTime.year()+2,3,2), |
| | | Maintenance_Price_Year__c = 999, |
| | | Category3__c='纤维镜'); |
| | | Product2 pro3 = new Product2(Name='name03',IsActive=true,Family='GI', |
| | | Service_Category3__c ='软性镜', |
| | | Fixture_Model_No__c='n03',Serial_Lot_No__c='Lot tracing', |
| | | PartSupplyFinishDate__c = Date.newInstance(toDayTime.year()+2,3,2), |
| | | ProductCode_Ext__c='pc03',Manual_Entry__c=false,Brand_Name__c='奥林巴斯', |
| | | Category2__c='本体', |
| | | Extend_Gurantee_Start_MD__c = Date.newInstance(toDayTime.year(),3,2), |
| | | Extend_Gurantee_End_MD__c = Date.newInstance(3999,12,31), |
| | | Extend_new_product_gurantee_MD__c = true, |
| | | Maintenance_Price_Year__c = 999, |
| | | Category3__c='电子镜'); |
| | | Product2 pro4 = new Product2(Name='name04',IsActive=true,Family='GI', |
| | | Service_Category3__c ='软性镜', |
| | | Fixture_Model_No__c='n04',Serial_Lot_No__c='Lot tracing', |
| | | ProductCode_Ext__c='pc04',Manual_Entry__c=false,Brand_Name__c='奥林巴斯', |
| | | Category4__c='SD EndoEYE', |
| | | Extend_Gurantee_Start_MD__c = Date.newInstance(toDayTime.year(),3,2), |
| | | Extend_Gurantee_End_MD__c = Date.newInstance(3999,12,31), |
| | | Extend_new_product_gurantee_MD__c = true, |
| | | PartSupplyFinishDate__c = Date.newInstance(toDayTime.year()+2,3,2), |
| | | Maintenance_Price_Year__c = 999); |
| | | |
| | | Product2 pro5 = new Product2(Name='name05',IsActive=true,Family='GI', |
| | | Service_Category3__c ='软性镜', |
| | | Fixture_Model_No__c='n05',Serial_Lot_No__c='Lot tracing',Brand_Name__c='奥林巴斯', |
| | | // Category2__c='本体', |
| | | Extend_Gurantee_Start_MD__c = Date.newInstance(toDayTime.year(),3,2), |
| | | Extend_Gurantee_End_MD__c = Date.newInstance(3999,12,31), |
| | | Extend_new_product_gurantee_MD__c = true, |
| | | Maintenance_Price_Year__c = 999, |
| | | PartSupplyFinishDate__c = Date.newInstance(toDayTime.year()+2,3,2), |
| | | ProductCode_Ext__c='pc05',Manual_Entry__c=false, |
| | | Category3__c = 'EUS主机'); |
| | | insert new Product2[] {pro1, pro2, pro3,pro4,pro5}; |
| | | |
| | | |
| | | |
| | | Maintenance_Contract__c contract = new Maintenance_Contract__c(); |
| | | contract.Name = 'tect contract'; |
| | | contract.status__c ='契約'; |
| | | contract.Maintenance_Contract_No__c = 'Kami_Contract_No'; |
| | | contract.Contract_Conclusion_Date__c = Date.today(); |
| | | contract.Hospital__c = hospital.Id; |
| | | contract.Department_Class__c = strategicDep[0].Id; |
| | | contract.Department__c = dep.Id; |
| | | contract.Contract_Start_Date__c=Date.newInstance(toDayTime.year()-2,5,2); |
| | | contract.Contract_End_Date__c = Date.newInstance(toDayTime.year(),5,20); |
| | | contract.SalesOfficeCode_selection__c = '北京RC'; |
| | | contract.RecordTypeId = Schema.SObjectType.Maintenance_Contract__c.getRecordTypeInfosByDeveloperName().get('VM_Contract').getRecordTypeId(); |
| | | insert contract; |
| | | System.assert(contract.Id != null); |
| | | |
| | | List<Maintenance_Contract__c> MaintenanceContract=[select id,Name from Maintenance_Contract__c]; |
| | | //---------------------------主体 两个附属品(个体管理 数量管理) |
| | | // 保有设备A (主体) |
| | | Asset assetA1 = new Asset(Asset_Owner__c = 'Olympus'); |
| | | // assetA1.RecordTypeId = System.Label.Asset_RecordType; |
| | | // 2023/03/30 医院保有设备 |
| | | assetA1.RecordTypeId = Schema.SObjectType.Asset.getRecordTypeInfosByDeveloperName().get('HPAsset').getRecordTypeId(); |
| | | assetA1.SerialNumber = 'ass01'; |
| | | assetA1.Name = 'ass01'; |
| | | assetA1.AccountId = dep.Id; |
| | | assetA1.Guarantee_period_for_products__c = toDayTime.addMonths(6); |
| | | assetA1.Department_Class__c = strategicDep[0].Id; |
| | | assetA1.Hospital__c = hospital.Id; |
| | | assetA1.Product2Id = pro1.Id; |
| | | assetA1.Quantity = 1; |
| | | // assetA1.Asset_Year__c = Date.today().addYears(-1); |
| | | |
| | | assetA1.Status = '使用中'; |
| | | 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 = '1.华北营业本部'; |
| | | assetA1.Internal_asset_location__c = '北京 备品中心'; |
| | | assetA1.Product_category__c = 'GI'; |
| | | assetA1.Equipment_Type__c = '产品试用'; |
| | | assetA1.SalesProvince__c = '北京'; |
| | | assetA1.WH_location__c = '货架号1'; |
| | | assetA1.Asset_loaner_category__c = '固定资产'; |
| | | assetA1.CompanyOfEquipment__c = '123'; |
| | | assetA1.Internal_Asset_number__c = '123'; |
| | | assetA1.CurrentContract__c=MaintenanceContract[0].Id; |
| | | assetA1.InstallDate =Date.newInstance(2021, 5, 1); |
| | | |
| | | // assetA1.AssetManageConfirm__c = true; |
| | | // 保有设备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 = '使用中'; |
| | | // assetA1.Asset_Year__c = Date.today().addYears(-1); |
| | | assetA2.Manage_type__c = '数量管理'; |
| | | assetA2.Loaner_accsessary__c = true; |
| | | assetA2.Product_category__c = 'GI'; |
| | | assetA2.Delete_Flag__c = false; |
| | | assetA2.Guarantee_period_for_products__c = toDayTime; |
| | | assetA2.Freeze_sign__c = false; |
| | | assetA2.Out_of_wh__c = 3; |
| | | |
| | | assetA2.Frozen_Quantity__c = 2; |
| | | assetA2.Salesdepartment__c = '1.华北营业本部'; |
| | | assetA2.Internal_asset_location__c = '北京 备品中心'; |
| | | assetA2.Product_category__c = 'GI'; |
| | | assetA2.Equipment_Type__c = '产品试用'; |
| | | assetA2.SalesProvince__c = '北京'; |
| | | assetA2.WH_location__c = '货架号2'; |
| | | assetA2.Asset_loaner_category__c = '固定资产'; |
| | | assetA2.CompanyOfEquipment__c = '123'; |
| | | assetA2.Internal_Asset_number__c = '123'; |
| | | assetA2.CurrentContract__c=MaintenanceContract[0].Id; |
| | | assetA2.InstallDate =Date.newInstance(2016, 5, 1); |
| | | |
| | | // assetA2.AssetManageConfirm__c = true; |
| | | // 保有设备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 = 10; |
| | | assetA3.Status = '使用中'; |
| | | assetA3.Manage_type__c = '数量管理'; |
| | | assetA3.Loaner_accsessary__c = true; |
| | | assetA3.Product_category__c = 'GI'; |
| | | assetA3.Delete_Flag__c = false; |
| | | assetA3.Guarantee_period_for_products__c = toDayTime; |
| | | |
| | | assetA3.Freeze_sign__c = false; |
| | | assetA3.Out_of_wh__c = 3; |
| | | assetA3.Salesdepartment__c = '1.华北营业本部'; |
| | | assetA3.Internal_asset_location__c = '北京 备品中心'; |
| | | assetA3.Product_category__c = 'GI'; |
| | | assetA3.Equipment_Type__c = '产品试用'; |
| | | assetA3.SalesProvince__c = '北京'; |
| | | assetA3.WH_location__c = '货架号3'; |
| | | assetA3.Abandoned_Inventory__c = 1; |
| | | assetA3.Asset_loaner_category__c = '固定资产'; |
| | | assetA3.CompanyOfEquipment__c = '123'; |
| | | assetA3.Internal_Asset_number__c = '123'; |
| | | assetA3.CurrentContract__c=MaintenanceContract[0].Id; |
| | | |
| | | // 保有设备A (附属品 数量管理) |
| | | Asset assetA4 = new Asset(Asset_Owner__c = 'Olympus'); |
| | | assetA4.RecordTypeId = System.Label.Asset_RecordType; |
| | | assetA4.SerialNumber = 'ass04'; |
| | | assetA4.Name = 'ass04'; |
| | | assetA4.AccountId = dep.Id; |
| | | assetA4.Department_Class__c = strategicDep[0].Id; |
| | | assetA4.Hospital__c = hospital.Id; |
| | | assetA4.Product2Id = pro4.Id; |
| | | assetA4.Quantity = 10; |
| | | assetA4.Guarantee_period_for_products__c = toDayTime; |
| | | assetA4.Status = '使用中'; |
| | | |
| | | assetA4.Manage_type__c = '数量管理'; |
| | | assetA4.Loaner_accsessary__c = true; |
| | | assetA4.Product_category__c = 'GI'; |
| | | assetA4.Delete_Flag__c = false; |
| | | assetA4.Freeze_sign__c = false; |
| | | assetA4.Out_of_wh__c = 3; |
| | | assetA4.Frozen_Quantity__c = 2; |
| | | assetA4.Salesdepartment__c = '1.华北营业本部'; |
| | | assetA4.Internal_asset_location__c = '北京 备品中心'; |
| | | assetA4.Product_category__c = 'GI'; |
| | | assetA4.Equipment_Type__c = '产品试用'; |
| | | assetA4.SalesProvince__c = '北京'; |
| | | assetA4.WH_location__c = '货架号2'; |
| | | assetA4.Asset_loaner_category__c = '固定资产'; |
| | | assetA4.CompanyOfEquipment__c = '123'; |
| | | assetA4.Internal_Asset_number__c = '123'; |
| | | assetA4.CurrentContract__c=MaintenanceContract[0].Id; |
| | | // assetA2.AssetManageConfirm__c = true; |
| | | |
| | | // 保有设备A (附属品 数量管理) |
| | | Asset assetA5 = new Asset(Asset_Owner__c = 'Olympus'); |
| | | assetA5.RecordTypeId = System.Label.Asset_RecordType; |
| | | assetA5.SerialNumber = 'ass05'; |
| | | assetA5.Name = 'ass05'; |
| | | assetA5.AccountId = dep.Id; |
| | | assetA5.Department_Class__c = strategicDep[0].Id; |
| | | assetA5.Hospital__c = hospital.Id; |
| | | assetA5.Product2Id = pro5.Id; |
| | | assetA5.Quantity = 10; |
| | | assetA5.Status = '使用中'; |
| | | assetA5.Manage_type__c = '数量管理'; |
| | | assetA5.Loaner_accsessary__c = true; |
| | | assetA5.Product_category__c = 'GI'; |
| | | assetA5.Delete_Flag__c = false; |
| | | assetA5.Guarantee_period_for_products__c = toDayTime; |
| | | |
| | | assetA5.Freeze_sign__c = false; |
| | | assetA5.Out_of_wh__c = 3; |
| | | assetA5.Frozen_Quantity__c = 2; |
| | | assetA5.Salesdepartment__c = '1.华北营业本部'; |
| | | assetA5.Internal_asset_location__c = '北京 备品中心'; |
| | | assetA5.Product_category__c = 'GI'; |
| | | assetA5.Equipment_Type__c = '产品试用'; |
| | | assetA5.SalesProvince__c = '北京'; |
| | | assetA5.WH_location__c = '货架号2'; |
| | | assetA5.Asset_loaner_category__c = '固定资产'; |
| | | assetA5.CompanyOfEquipment__c = '123'; |
| | | assetA5.Internal_Asset_number__c = '123'; |
| | | assetA5.CurrentContract__c=MaintenanceContract[0].Id; |
| | | // assetA2.AssetManageConfirm__c = true; |
| | | Oly_TriggerHandler.bypass('AssetHandlerCheck'); |
| | | insert new Asset[] {assetA1, assetA2, assetA3,assetA4,assetA5}; |
| | | List<Asset> Assetss = new Asset[] {assetA1, assetA2, assetA3,assetA4,assetA5}; |
| | | |
| | | Maintenance_Contract_Asset__c mca = new Maintenance_Contract_Asset__c(); |
| | | // mca.Asset__c = Assetss[0].Id; |
| | | mca.Asset__c = assetA1.Id; |
| | | |
| | | mca.Maintenance_Contract__c = MaintenanceContract[0].Id; |
| | | mca.endDateGurantee_Text__c = Date.today().addDays(1); |
| | | mca.Summary_FZ__c = 200; |
| | | insert mca; |
| | | |
| | | System.assert(mca.Id != null); |
| | | |
| | | //维修表创建(包含在维修表的保有设备) |
| | | Repair__c repairObj1 = new Repair__c(); |
| | | repairObj1.Delivered_Product__c = Assetss[0].Id; |
| | | repairObj1.Discount_Price__c = 1000; |
| | | repairObj1.Hospital__c = hospital.Id; |
| | | repairObj1.Department_Class__c = strategicDep[0].Id; |
| | | repairObj1.Account__c = hospital.Id; |
| | | repairObj1.SalesOfficeCode_selection__c = '北京石景山'; |
| | | repairObj1.On_site_repair__c = 'RC修理'; |
| | | repairObj1.Failure_Occurrence_Date__c = Date.today(); |
| | | repairObj1.Agreed_Date__c = Date.today().addYears(-1); |
| | | repairObj1.Repair_List_Price__c = 2000; |
| | | |
| | | |
| | | // insert repairObj1; |
| | | |
| | | Repair__c repairObj2 = new Repair__c(); |
| | | repairObj2.Discount_Price__c = 2000; |
| | | repairObj2.Delivered_Product__c = Assetss[1].Id; |
| | | repairObj2.Hospital__c = hospital.Id; |
| | | repairObj2.Department_Class__c = strategicDep[0].Id; |
| | | repairObj2.Account__c = hospital.Id; |
| | | repairObj2.SalesOfficeCode_selection__c = '北京石景山'; |
| | | repairObj2.On_site_repair__c = 'RC修理'; |
| | | repairObj2.Failure_Occurrence_Date__c = Date.today(); |
| | | repairObj2.Agreed_Date__c = Date.today().addYears(-1); |
| | | repairObj2.Repair_List_Price__c = 1000; |
| | | |
| | | |
| | | Repair__c repairObj3 = new Repair__c(); |
| | | repairObj3.Discount_Price__c = 2000; |
| | | repairObj3.Delivered_Product__c = Assetss[2].Id; |
| | | repairObj3.Hospital__c = hospital.Id; |
| | | repairObj3.Department_Class__c = strategicDep[0].Id; |
| | | repairObj3.Account__c = hospital.Id; |
| | | repairObj3.SalesOfficeCode_selection__c = '北京石景山'; |
| | | repairObj3.On_site_repair__c = 'RC修理'; |
| | | repairObj3.Failure_Occurrence_Date__c = Date.today(); |
| | | repairObj3.Agreed_Date__c = Date.today().addYears(-1); |
| | | repairObj3.Repair_List_Price__c = 2000; |
| | | |
| | | |
| | | insert new Repair__c[] {repairObj1, repairObj2, repairObj3}; |
| | | |
| | | Repair_Quotation__c rq = new Repair_Quotation__c(); |
| | | rq.Name = 'testNFM104'; |
| | | rq.Repair__c = repairObj1.Id; |
| | | rq.MessageGroupNumber__c = '1'; |
| | | rq.ListPrice__c =2000; |
| | | insert rq; |
| | | // StaticParameter.RepairAgainAnStaTrigger = true; |
| | | } |
| | | } |