@isTest private class NFM110WebServiceTest { static Account company; static Account section1; // 呼吸科 static Account section2; // 消化科 static Account olympus; static Account olympus1; // 呼吸科 static Account olympus2; // 消化科 static Account depart1; static Account depart2; static void initHpData() { RecordType rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '病院']; RecordType rectDpt1 = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '診療科 呼吸科']; RecordType rectDpt2 = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '診療科 消化科']; // テストデータ company = new Account(RecordTypeId = rectCo.Id, Name = 'NFM110TestCompany'); olympus = new Account(RecordTypeId = rectCo.Id, AgentCode_Ext__c = '9999999', Name = 'olympus'); insert new Account[] {company, olympus}; company = [select Management_Code__c, Management_Code_Auto__c, Name, Id from Account where Id =:company.Id]; section1 = [select Management_Code__c, Management_Code_Auto__c, Name, Id, Department_Class_Label__c from Account where ParentId =:company.Id and RecordType.name = '戦略科室分類 呼吸科']; section2 = [select Management_Code__c, Management_Code_Auto__c, Name, Id, Department_Class_Label__c from Account where ParentId =:company.Id and RecordType.name = '戦略科室分類 消化科']; olympus1 = [select Management_Code__c, Management_Code_Auto__c, Name, Id, Department_Class_Label__c from Account where ParentId =:olympus.Id and RecordType.name = '戦略科室分類 呼吸科']; olympus2 = [select Management_Code__c, Management_Code_Auto__c, Name, Id, Department_Class_Label__c from Account where ParentId =:olympus.Id and RecordType.name = '戦略科室分類 消化科']; System.debug('section1.Department_Class_Label__c='+section1.Department_Class_Label__c); System.debug('section2.Department_Class_Label__c='+section2.Department_Class_Label__c); depart1 = new Account(RecordTypeId = rectDpt1.Id, Name = '*', ParentId = section1.Id, Department_Class__c = section1.Id, Hospital__c = company.Id, Department_Name__c = 'NFM110TestDepart1'); depart2 = new Account(RecordTypeId = rectDpt2.Id, Name = '*', ParentId = section2.Id, Department_Class__c = section2.Id, Hospital__c = company.Id, Department_Name__c = 'NFM110TestDepart2'); Account ocm = new Account(RecordTypeId = rectDpt2.Id, Name = '*', ParentId = section2.Id, Department_Class__c = section2.Id, Hospital__c = company.Id, AgentCode_Ext__c = '9999900', Department_Name__c = 'NFM110TestDepart3'); Account olympus_return = new Account(RecordTypeId = rectDpt2.Id, Name = '*', ParentId = olympus2.Id, Department_Class__c = olympus2.Id, Hospital__c = olympus.Id, AgentCode_Ext__c = '9999901', Department_Name__c = 'olympus_return'); insert new Account[] {depart1, depart2, ocm, olympus_return}; depart1 = [select Management_Code__c, Management_Code_Auto__c, Name, Id from Account where Id =:depart1.Id]; depart2 = [select Management_Code__c, Management_Code_Auto__c, Name, Id from Account where Id =:depart2.Id]; } @isTest static void test_void() { initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='NFM110Prd1',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; // null NFM110WebService.NFM110(null); NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); // Monitoringをセットしない NFM110WebService.NFM110(ProductsDelivery); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; // GeneralDataをセットしない NFM110WebService.NFM110(ProductsDelivery); ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; // generalData1.DeliveryNoteをセットしない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '02'; NFM110WebService.NFM110(ProductsDelivery); generalData1.DeliveryNote = 'DeliveryNote'; // DnInformationをセットしない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '03'; NFM110WebService.NFM110(ProductsDelivery); NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; // 病院と診療科の管理コードをセットしない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '04'; NFM110WebService.NFM110(ProductsDelivery); generalData1.EndUserNo = 'NFM110TestABCD'; generalData1.DepartmentNo = 'NFM110TestDCBA'; // 病院と診療科の管理コードが存在しない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '05'; NFM110WebService.NFM110(ProductsDelivery); generalData1.EndUserNo = company.Management_Code_Auto__c; // 診療科の管理コードが存在しない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '06'; NFM110WebService.NFM110(ProductsDelivery); generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; // DnInformationの必須項目をセットしない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '07'; NFM110WebService.NFM110(ProductsDelivery); dnInfo1.SorLMark = 'S'; // DnInformationの必須項目をセットしない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '08'; NFM110WebService.NFM110(ProductsDelivery); dnInfo1.OTCode = 'NFM110Prd1'; // DnInformationの必須項目をセットしない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '09'; NFM110WebService.NFM110(ProductsDelivery); dnInfo1.OTCode = 'NFM110TstPrd1234'; dnInfo1.SerialNoorLotNo = '2577010001675'; // 商品コードが存在しない ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '10'; NFM110WebService.NFM110(ProductsDelivery); Asset[] rslts = [select Id from Asset]; System.assertEquals(0, rslts.size()); } @isTest static void test_insert() { initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='NFM110Prd1',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; dnInfo1.SorLMark = 'S'; dnInfo1.OTCode = prd.ProductCode_Ext__c; dnInfo1.SerialNoorLotNo = '2577010001675'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Asset[] rslts = [select Id, Return_Flag__c, AccountId, Department_Class__c, Hospital__c, Product2Id, SerialNumber, SLMark__c, IF_Information_From__c, InstallDate from Asset]; List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = false and Type__c = 'NFM110' order by CreatedDate desc]; //System.assertEquals('1', rowbl[0].ErrorLog__c); System.assertEquals(1, rslts.size()); if(rslts.size() > 0){ System.assertEquals(1, rslts.size()); System.assertEquals(false, rslts[0].Return_Flag__c); System.assertEquals(depart1.Id, rslts[0].AccountId); System.assertEquals(section1.Id, rslts[0].Department_Class__c); System.assertEquals(company.Id, rslts[0].Hospital__c); System.assertEquals(prd.Id, rslts[0].Product2Id); System.assertEquals(dnInfo1.SerialNoorLotNo, rslts[0]. SerialNumber); System.assertEquals('Serial Number', rslts[0]. SLMark__c); System.assertEquals(true, rslts[0]. IF_Information_From__c); System.assertEquals(null, rslts[0]. InstallDate); } } // DepartmentNo = null @isTest static void test_insert_01() { initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='NFM110Prd1',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Opportunity opp = new Opportunity(Name='aiueo', StageName='出荷', CloseDate=Date.today()); insert opp; Opportunity[] opps = [select Id, Name, Opportunity_No__c from Opportunity where Id = :opp.Id ]; Statu_Achievements__c sta = new Statu_Achievements__c( Name='test01', Opportunity__c = opp.Id, DeliveryStatus__c = 'test', PaymentRate__c = '1234', ContractAmount__c = 0, End_User_price__c = 0, AssignmentStatus__c = '全部分配', Last_week__c = '5 货齐,未付款,无用户合同', X2weeks_ago__c = '4 备货中', X3Weeks_ago__c = '3 已付款,无用户合同', X4weeks_ago__c = '2 待付款', X5weeks_ago__c = '1 全没有' ); insert sta; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = null; generalData1.SoNo = sta.Name; generalData1.InquiryNo = opps[0].Opportunity_No__c + ','; dnInfo1.SorLMark = 'S'; dnInfo1.OTCode = prd.ProductCode_Ext__c; dnInfo1.SerialNoorLotNo = '2577010001675'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Asset[] rslts = [select Id, Hospital__c, AccountId, Product2Id, Backorder__c from Asset]; //System.assertEquals(1, rslts.size()); //System.assertEquals(company.Id, rslts[0].Hospital__c); //System.assertEquals(company.Id, rslts[0].AccountId); //System.assertEquals(prd.Id, rslts[0].Product2Id); //System.assertEquals(sta.Id, rslts[0].Backorder__c); } @isTest static void coc_test() { initHpData(); List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Consumable_order__c coc = new Consumable_order__c(Name = 'Name001',Order_status__c = '批准',RecordTypeid = conOrder_Order[0].Id); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001',Consumable_order__c = coc.id,Consumable_Product__c =pro1.id,RecordTypeId =conOrderDetail_Order[0].Id); insert codc; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = coc.Name + ','; dnInfo1.SorLMark = 'S'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '2577010001675'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order__c[] coc1 = [select id,name from Consumable_order__c where id =:coc.id]; System.assertEquals(1, coc1.size()); } @isTest static void test_update() { User loginUser = [Select Id, Alias, Province__c from User where Id =: UserInfo.getUserId()]; loginUser.Batch_User__c = true; loginUser.responsibility__c = '华北营业一部'; loginUser.OCM_Management_Province__c = '北京'; update loginUser; initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false,MDM_Model_No__c = 'NFM110Ast1'); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c = prd.Id); insert pro1; Asset ast = new Asset(Name='NFM110Ast1', AccountId=depart1.Id, Department_Class__c=section1.Id, Hospital__c=company.Id, Product2Id=prd.Id, SerialNumber='2577010001675', Guarantee_period_for_products__c=Date.today() ); insert ast; Opportunity opp1 = new Opportunity(Name='aiueo1', StageName='出荷', CurrencyIsoCode='CNY', CloseDate=Date.today()); insert opp1; Statu_Achievements__c sta11 = new Statu_Achievements__c(Name='SO0000001', Opportunity__c=opp1.Id, ContractNO__c='sta11', DeliveryStatus__c = '未交付',ContractAmount__c = 0); insert sta11; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; generalData1.SoNo = sta11.Name; generalData1.InquiryNo = sta11.Name + ','; dnInfo1.SorLMark = 'S'; dnInfo1.OTCode = prd.ProductCode_Ext__c; dnInfo1.Barcode = 'testbarcode001'; dnInfo1.SerialNoorLotNo = ast.SerialNumber; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); List prdList = [select Id, Name, ProductCode, ProductCode_Ext__c, MDM_Model_No__c from Product2 where ProductCode_Ext__c = :prd.ProductCode_Ext__c]; System.assertEquals(1, prdList.size()); Asset[] rslts = [select Id, Return_Flag__c from Asset where Id=:ast.Id]; System.assertEquals(1, rslts.size()); // retry_cnt__c がクリアされること List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = true and Type__c = 'NFM110' order by CreatedDate desc]; System.assertEquals(1, rowbl.size()); rowbl[0].retry_cnt__c = 1; update rowbl; NFM110WebService.execute(rowbl[0].id); System.Test.stopTest(); List bl = [Select Id, Is_Error__c, Type__c, Log__c, ErrorLog__c,retry_cnt__c from BatchIF_Log__c where Id = :rowbl[0].id]; System.assertEquals(0, bl[0].retry_cnt__c); } @isTest static void test_delete() { User loginUser = [Select Id, Alias, Province__c from User where Id =: UserInfo.getUserId()]; loginUser.Batch_User__c = true; loginUser.responsibility__c = '华北营业一部'; loginUser.OCM_Management_Province__c = '北京'; update loginUser; initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Asset ast = new Asset(Name='NFM110Ast1', AccountId=depart1.Id, Department_Class__c=section1.Id, Hospital__c=company.Id, Product2Id=prd.Id, SerialNumber='2577010001675', Guarantee_period_for_products__c=Date.today() ); insert ast; Opportunity opp1 = new Opportunity(Name='aiueo1', StageName='出荷', CurrencyIsoCode='CNY', CloseDate=Date.today()); insert opp1; Statu_Achievements__c sta11 = new Statu_Achievements__c(Name='SO0000001', Opportunity__c=opp1.Id, ContractNO__c='sta11', DeliveryStatus__c = '未交付',ContractAmount__c = 0); insert sta11; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; generalData1.SoNo = sta11.Name; generalData1.InquiryNo = sta11.Name + ','; generalData1.ReturnMark = '1'; dnInfo1.SorLMark = 'S'; dnInfo1.OTCode = prd.ProductCode_Ext__c; dnInfo1.SerialNoorLotNo = ast.SerialNumber; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Asset[] rslts = [select Id, Return_Flag__c from Asset where Id=:ast.Id]; System.assertEquals(1, rslts.size()); //System.assertEquals(true, rslts[0].Return_Flag__c); } @isTest static void coc_send() { initHpData(); List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Consumable_order__c coc = new Consumable_order__c(Name = 'Name001',Order_status__c = '批准',RecordTypeid = conOrder_Order[0].Id); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001',Consumable_order__c = coc.id,Consumable_Product__c =pro1.id,RecordTypeId =conOrderDetail_Order[0].Id); insert codc; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = 'Name001,'; dnInfo1.SorLMark = 'S'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '2577010001675'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order__c[] coc1 = [select id,name from Consumable_order__c where id =:coc.id]; System.assertEquals(1, coc1.size()); } @isTest static void coc_consumable() { initHpData(); List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } List rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '販売店']; if (rectCo.size() == 0) { return; } List rectCotac = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '契約']; if (rectCotac.size() == 0) { return; } //测试经销商信息 Account myAccount2 = new Account(name='Testaccount002',Dealer_discount__c =20,RecordTypeId = rectCo[0].Id,Product_Limit_Date__c = 'Test01|5|55,Test02|2|4'); insert myAccount2; //测试合同信息 Account contact = new Account(name='Testaccount002', RecordTypeId = rectCotac[0].Id,SpecialDealerName__c = 'Testaccount002', ParentId = myAccount2.Id,Agent_Ref__c = myAccount2.Id,Delete_Flag__c = false, Contract_Department_Class__c = 'ET',Contract_Decide_Start_Date__c = Date.today().addDays(-1), Contract_Decide_End_Date__c = Date.today().addDays(1),AgencyContract_Management_Code__c = '5555555'); insert contact; contact = [select Management_Code__c from Account where id = :contact.Id]; Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false,Dealer_special_Object__c = true); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Consumable_order__c coc = new Consumable_order__c(Name = 'Name001',Order_status__c = '批准',RecordTypeid = conOrder_Order[0].Id); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001',Consumable_order__c = coc.id,Consumable_Product__c =pro1.id,RecordTypeId =conOrderDetail_Order[0].Id,Consumable_count__c = 1); insert codc; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = contact.Management_Code__c; generalData1.DepartmentNo = contact.Management_Code__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = 'Name001,Name001'; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '85K'; dnInfo1.Barcode = 'testbarcode001250AAAAA'; dnInfo1.TracingCode = 'AAAAA'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order__c[] coc1 = [select id,name from Consumable_order__c where id =:coc.id]; System.assertEquals(1, coc1.size()); //List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = false and Type__c = 'NFM110' order by CreatedDate desc]; //System.assertEquals('1', rowbl[0].ErrorLog__c); Consumable_order_details2__c[] cod2 = [select id,name from Consumable_order_details2__c where Consumable_order_minor__c =:coc.id]; System.assertEquals(1, cod2.size()); } @isTest static void coc_consumable_InquiryNo() { initHpData(); List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } List rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '販売店']; if (rectCo.size() == 0) { return; } List rectCotac = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '契約']; if (rectCotac.size() == 0) { return; } //测试经销商信息 Account myAccount2 = new Account(name='Testaccount002',Dealer_discount__c =20,RecordTypeId = rectCo[0].Id,Product_Limit_Date__c = 'Test01|5|55,Test02|2|4'); insert myAccount2; //测试合同信息 Account contact = new Account(name='Testaccount002', RecordTypeId = rectCotac[0].Id,SpecialDealerName__c = 'Testaccount002',ParentId = myAccount2.Id,Agent_Ref__c = myAccount2.Id,Delete_Flag__c = false,Contract_Department_Class__c = 'ET',Contract_Decide_Start_Date__c = Date.today().addDays(-1),Contract_Decide_End_Date__c = Date.today().addDays(1)); insert contact; contact = [select Management_Code__c from Account where id = :contact.Id]; //System.assertEquals('99999', contact.Management_Code__c); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false,Dealer_special_Object__c = true); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Consumable_order__c coc = new Consumable_order__c(Name = 'Name002',Order_status__c = '批准',RecordTypeid = conOrder_Order[0].Id); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001',Consumable_order__c = coc.id,Consumable_Product__c =pro1.id,RecordTypeId =conOrderDetail_Order[0].Id,Consumable_count__c = 1); insert codc; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = '000' + contact.Management_Code__c; generalData1.DepartmentNo = '000' + contact.Management_Code__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = 'Name002,Name002'; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '85K'; dnInfo1.Barcode = 'testbarcode001250AAAAA'; dnInfo1.TracingCode = 'AAAAA'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order__c[] coc1 = [select id,name from Consumable_order__c where id =:coc.id]; System.assertEquals(1, coc1.size()); List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = false and Type__c = 'NFM110' order by CreatedDate desc]; //System.assertEquals('1', rowbl[0].ErrorLog__c); Consumable_order_details2__c[] cod2 = [select id,name from Consumable_order_details2__c]; System.assertEquals(1, cod2.size()); } @isTest //直接到货再入库对应 static void coc_doubleArrive() { initHpData(); StaticParameter.EscapeConsumableOrderDetail2Trigger = true; List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } List rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '販売店']; if (rectCo.size() == 0) { return; } List rectCotac = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '契約']; if (rectCotac.size() == 0) { return; } //测试经销商信息 Account myAccount2 = new Account(name='Testaccount002',Dealer_discount__c =20,RecordTypeId = rectCo[0].Id,Product_Limit_Date__c = 'Test01|5|55,Test02|2|4'); insert myAccount2; //测试合同信息 Account contact = new Account(name='Testaccount002', RecordTypeId = rectCotac[0].Id,SpecialDealerName__c = 'Testaccount002',ParentId = myAccount2.Id,Agent_Ref__c = myAccount2.Id,Delete_Flag__c = false,Contract_Department_Class__c = 'ET',Contract_Decide_Start_Date__c = Date.today().addDays(-1),Contract_Decide_End_Date__c = Date.today().addDays(1)); insert contact; contact = [select Management_Code__c from Account where id = :contact.Id]; Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false,Dealer_special_Object__c = true); insert prd; Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Consumable_order__c coc = new Consumable_order__c(Name = 'Name001',Order_status__c = '批准',RecordTypeid = conOrder_Order[0].Id); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001',Consumable_order__c = coc.id,Consumable_Product__c =pro1.id,RecordTypeId =conOrderDetail_Order[0].Id); insert codc; Consumable_order_details2__c codc2 = new Consumable_order_details2__c(Name='det2001',Consumable_order_minor__c = coc.id,Consumable_Product__c =pro1.id,RecordTypeId =System.Label.RT_ConOrderDetail2_Delivery, Asset_Model_No__c = 'NFM110Prd1',Bar_Code__c = 'testbarcode0011085K250AAAAA',Arrive_date__c = Date.today(),Direct_Arrive_Product__c = true,TracingCode__c = 'AAAAA',SerialLotNo__c = '85K'); insert codc2; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = contact.Management_Code__c; generalData1.DepartmentNo = contact.Management_Code__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = 'Name001,Name001'; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '85K'; dnInfo1.Barcode = 'testbarcode0011085K250AAAAA'; dnInfo1.TracingCode = 'AAAAA'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order_details2__c[] cod2 = [select id,name,Direct_Arrive_Product__c from Consumable_order_details2__c]; System.assertEquals(1, cod2.size()); System.assertEquals(false, cod2[0].Direct_Arrive_Product__c); //List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = false and Type__c = 'NFM110' order by CreatedDate desc]; //System.assertEquals('1', rowbl[0].ErrorLog__c); } //促销产品 static testMethod void coc_romotionPro() { initHpData(); StaticParameter.EscapeConsumableOrderDetail2Trigger = true; List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } List rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '販売店']; if (rectCo.size() == 0) { return; } List rectContract = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '契約']; if (rectCo.size() == 0) { return; } Id pricebookId = ControllerUtil.getStandardPricebook().Id; // 产品 Product2 prd1 = new Product2( Name='name01', IsActive=true, Asset_Model_No__c='NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c=false, //SFDA_Status__c='有効', Intra_Trade_List_RMB_Date1__c=Date.today().addDays(-1), Intra_Trade_List_RMB_Date2__c=Date.today().addDays(-1), Intra_Trade_List_RMB_End_Date1__c=Date.today().addDays(1), Intra_Trade_List_RMB_End_Date2__c=Date.today().addDays(1), Intra_Trade_List_RMB_1__c=100, Intra_Trade_List_RMB_2__c=200, Intra_Trade_Cost_RMB_Date1__c=Date.today().addDays(-1), Intra_Trade_Cost_RMB_Date2__c=Date.today().addDays(-1), Intra_Trade_Cost_RMB_End_Date1__c=Date.today().addDays(1), Intra_Trade_Cost_RMB_End_Date2__c=Date.today().addDays(1), Intra_Trade_Cost_RMB_1__c=10, Intra_Trade_Cost_RMB_2__c=20, Dealer_special_Object__c = true, SFDA_Approbated_Status__c = '不要', Product_Status__c = '正常销售' ); insert new Product2[] {prd1}; // 価格表エントリを作成する PricebookEntry entry = new PricebookEntry( Pricebook2Id=pricebookId, Product2Id=prd1.Id); entry.UnitPrice = 0; entry.IsActive = true; entry.UseStandardPrice = false; entry.CurrencyIsoCode = 'CNY'; insert new PricebookEntry[] {entry}; //经销商、联系人、用户信息 Account myAccount1 = new Account(name='Testaccount001', Dealer_discount__c =20, Ban_On_Use_Date__c = Date.today().addDays(1), Business_Paper_Expiration_Date__c = Date.today().addDays(1), Tax_Practice_Expiration_Date__c = Date.today().addDays(1), Medical_Equipment_Expiration_Date__c = Date.today().addDays(1), RecordTypeId = rectCo[0].Id); insert myAccount1; //医疗器械经营许可证 License_Information__c linc = new License_Information__c( name='Test20181204', LicenseType__c = '医疗器械经营许可证', BusinessLicense__c = '20180522', ValidFrom__c = date.newinstance(2018, 05, 22), ValidTo__c = date.newinstance(2088, 05, 22), Scope3__c = '6815;6822;6823;6825', LicenseAndAccount__c = myAccount1.Id ); insert linc; Product_Register__c prc = new Product_Register__c(Name = '国械注进20162220210', MedPrdClass__c = '3', ValidFrom__c = date.newinstance(2018, 07, 22), ValidTo__c = date.newinstance(2028, 07, 22), RegisterNoClass_Old__c = '6815', RegisterNoClass_New__c = '6815', RegisterNoStatus__c = '不要' ); insert prc; //新旧关系对照表 Product_Register_contrast__c prcc = new Product_Register_contrast__c( Name = 'Test20181204', Register_new__c = '314', Register_old__c = '36815' ); insert prcc; //产品-产品注册证关系 Product_Register_Link__c prlc = new Product_Register_Link__c( Product2__c = prd1.Id, Product_Register__c = prc.Id ); insert prlc; Account acc1 = [select Id,Name,Is_Active_Formula__c from Account where Id = : myAccount1.Id]; System.assertEquals('有效', acc1.Is_Active_Formula__c); //经销商有效合同 Account myAccount2 = new Account(name='Testaccount002', RecordTypeId = rectContract[0].Id, Contract_Decide_Start_Date__c = Date.today().addDays(-1), Contract_Decide_End_Date__c =Date.today().addDays(1), Contract_Start_Date__c = Date.today().addDays(-1), Contract_End_Date__c =Date.today().addDays(1), Agent_Ref__c =myAccount1.Id, ET_SP_Dealer__c = true, Business_Assistant__c = UserInfo.getUserId(), ParentId =myAccount1.Id); insert myAccount2; Account acc2 = [select Id,Name,Management_Code__c,Is_Active_Formula__c from Account where Id = : myAccount2.Id]; System.assertEquals('有效', acc2.Is_Active_Formula__c); Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd1.id); //Product2__c pro2 = new Product2__c(Name='Pro002',OT_CODE_Text__c='NFM110Prd2',Product2__c=prd2.id); insert new Product2__c[] {pro1}; Consumable_order__c coc = new Consumable_order__c(Name = 'Name001', Dealer_Info__c = myAccount1.Id, Order_status__c = '批准', RecordTypeid = conOrder_Order[0].Id, Contract_application_decision__c ='Name001' ,SalesManager__c = UserInfo.getUserId(), Order_effective_contact__c = myAccount2.Id ); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001', Consumable_order__c = coc.id, Consumable_Product__c =pro1.id, RecordTypeId =conOrderDetail_Order[0].Id, Consumable_count__c = 2, Intra_Trade_List_RMB__c = 100); insert codc; System.Test.startTest(); SendConsumableordertosap.sendSAP(coc.id); //System.assertEquals('11111111', SendConsumableordertosap.sendSAP(coc.id)); //System.Test.stopTest(); //coc.Name= 'Name0011'; //update coc; //Opportunity opp1 = new Opportunity(Name='aiueo10107', StageName='出荷', CurrencyIsoCode='CNY', CloseDate=Date.today(),Purchase_Type__c = 'ET24時間販売' // ,Sales_Root__c = '販売店'); //insert opp1; Opportunity[] coc12 = [select id,Name,Opportunity_No__c,SAP_Province__c from Opportunity]; System.assertEquals(1, coc12.size()); NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = acc2.Management_Code__c; generalData1.DepartmentNo = acc2.Management_Code__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = coc12[0].Opportunity_No__c + ','; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '85K'; dnInfo1.Barcode = 'testbarcode001250AAAAA'; dnInfo1.TracingCode = 'AAAAA'; //System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order_details2__c[] cod2 = [select id,name,Direct_Arrive_Product__c from Consumable_order_details2__c]; System.assertEquals(1, cod2.size()); System.assertEquals(false, cod2[0].Direct_Arrive_Product__c); //List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = false and Type__c = 'NFM110' order by CreatedDate desc]; //System.assertEquals('1', rowbl[0].ErrorLog__c); } //促销产品 static testMethod void coc_romotionPro1() { initHpData(); StaticParameter.EscapeConsumableOrderDetail2Trigger = true; List conOrder_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_order__c' and Name = '01 订单']; if (conOrder_Order.size() == 0) { return; } List conOrderDetail_Order = [select Id from RecordType where IsActive = true and SobjectType = 'Consumable_orderdetails__c' and Name = '订单']; if (conOrderDetail_Order.size() == 0) { return; } List rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '販売店']; if (rectCo.size() == 0) { return; } List rectContract = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '契約']; if (rectCo.size() == 0) { return; } Id pricebookId = ControllerUtil.getStandardPricebook().Id; // 产品 Product2 prd1 = new Product2( Name='name01', IsActive=true, Asset_Model_No__c='NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c=false, //SFDA_Status__c='有効', Intra_Trade_List_RMB_Date1__c=Date.today().addDays(-1), Intra_Trade_List_RMB_Date2__c=Date.today().addDays(-1), Intra_Trade_List_RMB_End_Date1__c=Date.today().addDays(1), Intra_Trade_List_RMB_End_Date2__c=Date.today().addDays(1), Intra_Trade_List_RMB_1__c=100, Intra_Trade_List_RMB_2__c=200, Intra_Trade_Cost_RMB_Date1__c=Date.today().addDays(-1), Intra_Trade_Cost_RMB_Date2__c=Date.today().addDays(-1), Intra_Trade_Cost_RMB_End_Date1__c=Date.today().addDays(1), Intra_Trade_Cost_RMB_End_Date2__c=Date.today().addDays(1), Intra_Trade_Cost_RMB_1__c=10, Intra_Trade_Cost_RMB_2__c=20, Dealer_special_Object__c = true, SFDA_Approbated_Status__c = '不要', Product_Status__c = '正常销售' ); insert new Product2[] {prd1}; // 価格表エントリを作成する PricebookEntry entry = new PricebookEntry( Pricebook2Id=pricebookId, Product2Id=prd1.Id); entry.UnitPrice = 0; entry.IsActive = true; entry.UseStandardPrice = false; entry.CurrencyIsoCode = 'CNY'; insert new PricebookEntry[] {entry}; //经销商、联系人、用户信息 Account myAccount1 = new Account(name='Testaccount001', Dealer_discount__c =20, Ban_On_Use_Date__c = Date.today().addDays(1), Business_Paper_Expiration_Date__c = Date.today().addDays(1), Tax_Practice_Expiration_Date__c = Date.today().addDays(1), Medical_Equipment_Expiration_Date__c = Date.today().addDays(1), RecordTypeId = rectCo[0].Id); insert myAccount1; //医疗器械经营许可证 License_Information__c linc = new License_Information__c( name='Test20181204', LicenseType__c = '医疗器械经营许可证', BusinessLicense__c = '20180522', ValidFrom__c = date.newinstance(2018, 05, 22), ValidTo__c = date.newinstance(2088, 05, 22), Scope3__c = '6815;6822;6823;6825', LicenseAndAccount__c = myAccount1.Id ); insert linc; Product_Register__c prc = new Product_Register__c(Name = '国械注进20162220210', MedPrdClass__c = '3', ValidFrom__c = date.newinstance(2018, 07, 22), ValidTo__c = date.newinstance(2028, 07, 22), RegisterNoClass_Old__c = '6815', RegisterNoClass_New__c = '6815', RegisterNoStatus__c = '不要' ); insert prc; //新旧关系对照表 Product_Register_contrast__c prcc = new Product_Register_contrast__c( Name = 'Test20181204', Register_new__c = '314', Register_old__c = '36815' ); insert prcc; //产品-产品注册证关系 Product_Register_Link__c prlc = new Product_Register_Link__c( Product2__c = prd1.Id, Product_Register__c = prc.Id ); insert prlc; Account acc1 = [select Id,Name,Is_Active_Formula__c from Account where Id = : myAccount1.Id]; System.assertEquals('有效', acc1.Is_Active_Formula__c); //经销商有效合同 Account myAccount2 = new Account(name='Testaccount002', RecordTypeId = rectContract[0].Id, Contract_Decide_Start_Date__c = Date.today().addDays(-1), Contract_Decide_End_Date__c =Date.today().addDays(1), Contract_Start_Date__c = Date.today().addDays(-1), Contract_End_Date__c =Date.today().addDays(1), Agent_Ref__c =myAccount1.Id, ET_SP_Dealer__c = true, Business_Assistant__c = UserInfo.getUserId(), ParentId =myAccount1.Id); insert myAccount2; Account acc2 = [select Id,Name,Management_Code__c,Is_Active_Formula__c from Account where Id = : myAccount2.Id]; System.assertEquals('有效', acc2.Is_Active_Formula__c); Product2__c pro1 = new Product2__c(Name='Pro001',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd1.id); //Product2__c pro2 = new Product2__c(Name='Pro002',OT_CODE_Text__c='NFM110Prd2',Product2__c=prd2.id); insert new Product2__c[] {pro1}; Consumable_order__c coc = new Consumable_order__c(Name = 'Name001', Dealer_Info__c = myAccount1.Id, Order_status__c = '批准', RecordTypeid = conOrder_Order[0].Id, Contract_application_decision__c ='Name001' ,SalesManager__c = UserInfo.getUserId(), Order_effective_contact__c = myAccount2.Id ); insert coc; Consumable_orderdetails__c codc = new Consumable_orderdetails__c(Name='orderdetails001', Consumable_order__c = coc.id, Consumable_Product__c =pro1.id, RecordTypeId =conOrderDetail_Order[0].Id, Consumable_count__c = 2, Intra_Trade_List_RMB__c = 100); insert codc; System.Test.startTest(); //SendConsumableordertosap.sendSAP(coc.id); //System.assertEquals('11111111', SendConsumableordertosap.sendSAP(coc.id)); //System.Test.stopTest(); //coc.Name= 'Name0011'; //update coc; Opportunity opp1 = new Opportunity(Name='aiueo10107', StageName='出荷', CurrencyIsoCode='CNY', CloseDate=Date.today(),Purchase_Type__c = 'ET24時間販売' ,Sales_Root__c = '販売店'); insert opp1; Opportunity[] coc12 = [select id,Name,Opportunity_No__c,SAP_Province__c from Opportunity]; System.assertEquals(1, coc12.size()); NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = acc2.Management_Code__c; generalData1.DepartmentNo = acc2.Management_Code__c; //generalData1.SoNo = coc.Name; generalData1.InquiryNo = coc12[0].Opportunity_No__c + ','; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = pro1.OT_CODE_Text__c; dnInfo1.SerialNoorLotNo = '85K'; dnInfo1.Barcode = 'testbarcode001250AAAAA'; dnInfo1.TracingCode = 'AAAAA'; //System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Consumable_order_details2__c[] cod2 = [select id,name,Direct_Arrive_Product__c from Consumable_order_details2__c]; System.assertEquals(1, cod2.size()); System.assertEquals(false, cod2[0].Direct_Arrive_Product__c); //List rowbl = [Select Id, Log__c, ErrorLog__c from BatchIF_Log__c where RowDataFlg__c = false and Type__c = 'NFM110' order by CreatedDate desc]; //System.assertEquals('1', rowbl[0].ErrorLog__c); } @isTest //直销产品发货 static void direct_sales() { initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false); insert prd; Product2__c pro1 = new Product2__c(Name='NFM110Prd1',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Opportunity opp = new Opportunity(Name='aiueo', StageName='出荷', CloseDate=Date.today(),Sales_Root__c = 'OCM直接販売'); insert opp; Opportunity opps = [select Id, Name, Opportunity_No__c,Sales_Root__c from Opportunity where Id = :opp.Id ]; System.assertEquals('OCM直接販売', opps.Sales_Root__c); Statu_Achievements__c sta = new Statu_Achievements__c( Name='test01', Opportunity__c = opp.Id, DeliveryStatus__c = 'test', PaymentRate__c = '1234', ContractAmount__c = 0, End_User_price__c = 0, AssignmentStatus__c = '全部分配', Last_week__c = '5 货齐,未付款,无用户合同', X2weeks_ago__c = '4 备货中', X3Weeks_ago__c = '3 已付款,无用户合同', X4weeks_ago__c = '2 待付款', X5weeks_ago__c = '1 全没有' ); insert sta; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; generalData1.SoNo = sta.Name; generalData1.InquiryNo = opps.Opportunity_No__c + ',test01'; generalData1.ReturnMark = ''; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = prd.ProductCode_Ext__c; dnInfo1.SerialNoorLotNo = '2577010001675'; dnInfo1.Barcode = 'Barcodetest250AAAA'; dnInfo1.TracingCode = 'AAAAA'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Asset[] rslts = [select Id, Hospital__c, AccountId, Product2Id, Backorder__c from Asset]; System.assertEquals(1, rslts.size()); } @isTest //直销退货发货 static void direct_return() { initHpData(); Product2 prd = new Product2(Name = 'NFM110Prd1', ProductCode = 'NFM110Prd1', ProductCode_Ext__c = 'NFM110Prd1', Manual_Entry__c = false,Dealer_special_Object__c = true,MDM_Model_No__c = 'NFM110Prd1'); insert prd; Product2__c pro1 = new Product2__c(Name='NFM110Prd1',OT_CODE_Text__c='NFM110Prd1',Product2__c=prd.id); insert pro1; Product2 prd2 = new Product2(Name = 'NFM110Prd2', ProductCode = 'NFM110Prd2', ProductCode_Ext__c = 'NFM110Prd2', Manual_Entry__c = false,Dealer_special_Object__c = true,MDM_Model_No__c = 'NFM110Prd1'); insert prd2; Product2__c pro2 = new Product2__c(Name='NFM110Prd2',OT_CODE_Text__c='NFM110Prd2',Product2__c=prd2.id); insert pro2; Asset ast = new Asset(Name='NFM110Ast2', AccountId=depart1.Id, Department_Class__c=section1.Id, Hospital__c=company.Id, Product2Id=prd.Id, SerialNumber='2577010001676(BBBBB)', Guarantee_period_for_products__c=Date.today() ); insert ast; Opportunity opp = new Opportunity(Name='aiueo', StageName='出荷', CloseDate=Date.today(),Sales_Root__c = 'OCM直接販売'); insert opp; Opportunity opps = [select Id, Name, Opportunity_No__c,Sales_Root__c from Opportunity where Id = :opp.Id ]; System.assertEquals('OCM直接販売', opps.Sales_Root__c); Statu_Achievements__c sta = new Statu_Achievements__c( Name='test01', Opportunity__c = opp.Id, DeliveryStatus__c = 'test', PaymentRate__c = '1234', ContractAmount__c = 0, End_User_price__c = 0, AssignmentStatus__c = '全部分配', Last_week__c = '5 货齐,未付款,无用户合同', X2weeks_ago__c = '4 备货中', X3Weeks_ago__c = '3 已付款,无用户合同', X4weeks_ago__c = '2 待付款', X5weeks_ago__c = '1 全没有' ); insert sta; NFM110WebService.GeneralData generalData1 = new NFM110WebService.GeneralData(); NFM110WebService.ProductsDelivery ProductsDelivery = new NFM110WebService.ProductsDelivery(); Datetime nowDT = Datetime.now(); String nowStr = nowDT.format('yyyyMMddHHmm'); ProductsDelivery.Monitoring = new NFMUtil.Monitoring(); ProductsDelivery.Monitoring.MessageGroupNumber = nowStr + '01'; ProductsDelivery.GeneralData = new NFM110WebService.GeneralData[] { generalData1 }; generalData1.DeliveryNote = 'DeliveryNote'; NFM110WebService.DnInformation dnInfo1 = new NFM110WebService.DnInformation(); NFM110WebService.DnInformation dnInfo2 = new NFM110WebService.DnInformation(); generalData1.DnInformation = new NFM110WebService.DnInformation[] { dnInfo1,dnInfo2 }; generalData1.EndUserNo = company.Management_Code_Auto__c; generalData1.DepartmentNo = depart1.Management_Code_Auto__c; generalData1.SoNo = sta.Name; generalData1.InquiryNo = opps.Opportunity_No__c + ',test01'; generalData1.ReturnMark = '1'; dnInfo1.SorLMark = 'L'; dnInfo1.OTCode = prd.ProductCode_Ext__c; dnInfo1.SerialNoorLotNo = '2577010001675'; dnInfo1.Barcode = 'Barcodetest250AAAA'; dnInfo1.TracingCode = 'AAAAA'; dnInfo1.Qty = '1'; dnInfo2.SorLMark = 'L'; dnInfo2.OTCode = prd2.ProductCode_Ext__c; dnInfo2.SerialNoorLotNo = '2577010001676'; dnInfo2.Barcode = 'Barcodetest250BBBBB'; dnInfo2.TracingCode = 'BBBBB'; dnInfo2.Qty = '1'; System.Test.startTest(); NFM110WebService.NFM110(ProductsDelivery); System.Test.stopTest(); Asset[] rslts = [select Id, Hospital__c, AccountId, Product2Id, Backorder__c from Asset]; System.assertEquals(1, rslts.size()); Consumable_order_details2__c[] cod2 = [select id,name,Direct_Arrive_Product__c from Consumable_order_details2__c]; System.assertEquals(2, cod2.size()); } }