@isTest private class OCMManagementProvinceBatchTest { @isTest static void test_method_one() { ControllerUtil.EscapeNFM001Trigger = true; Profile p = [select id from Profile where id =:System.Label.ProfileId_SystemAdmin]; String loginId = UserInfo.getUserId(); User sys = [select id from User where Id = :loginId]; User u1 = new User(Test_staff__c = true); u1.LastName = '_サンブリッジ'; u1.FirstName = 'あ'; u1.Batch_User__c = true; u1.Alias = 'あ'; u1.Email = 'olympusTest01@sunbridge.com'; u1.Username = 'olympusTest10@sunbridge.com'; u1.CommunityNickname = 'あ1'; u1.IsActive = true; u1.EmailEncodingKey = 'ISO-2022-JP'; u1.TimeZoneSidKey = 'Asia/Tokyo'; u1.LocaleSidKey = 'ja_JP'; u1.LanguageLocaleKey = 'ja'; u1.ProfileId = p.id; u1.Job_Category__c = '销售服务'; u1.Province__c = '東京'; User u2 = new User(Test_staff__c = true); u2.LastName = '_サンブリッジ'; u2.FirstName = 'い'; u2.Batch_User__c = true; u2.Alias = 'い'; u2.Email = 'olympusTest02@sunbridge.com'; u2.Username = 'olympusTest02@sunbridge.com'; u2.CommunityNickname = 'い'; u2.IsActive = true; u2.EmailEncodingKey = 'ISO-2022-JP'; u2.TimeZoneSidKey = 'Asia/Tokyo'; u2.LocaleSidKey = 'ja_JP'; u2.LanguageLocaleKey = 'ja'; u2.ProfileId = p.id; u2.Job_Category__c = '销售推广'; u2.Province__c = '東京'; User u3 = new User(Test_staff__c = true); u3.LastName = '_サンブリッジ'; u3.Batch_User__c = true; u3.FirstName = 'う'; u3.Alias = 'う'; u3.Email = 'olympusTest03@sunbridge.com'; u3.Username = 'olympusTest03@sunbridge.com'; u3.CommunityNickname = 'う'; u3.IsActive = true; u3.EmailEncodingKey = 'ISO-2022-JP'; u3.TimeZoneSidKey = 'Asia/Tokyo'; u3.LocaleSidKey = 'ja_JP'; u3.LanguageLocaleKey = 'ja'; u3.ProfileId = p.id; u3.Job_Category__c = '支援'; u3.Province__c = '東京'; u3.Dept__c = '能量事业本部'; insert new User[] {u1, u2, u3}; System.runAs(sys) { OCM_Management_Province__c mp1 = new OCM_Management_Province__c(); mp1.Name = '北京'; mp1.GI_assistant__c = u1.Id; mp1.SP_assistant__c = u1.Id; mp1.Energy_assistant__c = u1.Id; OCM_Management_Province__c mp2 = new OCM_Management_Province__c(); mp2.Name = '上海'; mp2.GI_assistant__c = u2.Id; mp2.SP_assistant__c = u2.Id; mp2.Energy_assistant__c = u2.Id; OCM_Management_Province__c mp3 = new OCM_Management_Province__c(); mp3.Name = '深圳'; mp3.GI_assistant__c = u3.Id; mp3.SP_assistant__c = u3.Id; mp3.Energy_assistant__c = u3.Id; OCM_Management_Province__c mp4 = new OCM_Management_Province__c(); mp4.Name = '特约经销商管理支援本部'; mp4.GI_assistant__c = loginId; mp4.SP_assistant__c = loginId; mp4.Energy_assistant__c = loginId; insert new OCM_Management_Province__c[] {mp1, mp2, mp3, mp4}; Address_Level__c al1 = new Address_Level__c(); al1.Name = '北京市'; al1.Level1_Code__c = 'CN-01'; al1.Level1_Sys_No__c = '353341'; Address_Level__c al2 = new Address_Level__c(); al2.Name = '上海市'; al2.Level1_Code__c = 'CN-16'; al2.Level1_Sys_No__c = '353334'; Address_Level__c al3 = new Address_Level__c(); al3.Name = '广东省'; al3.Level1_Code__c = 'CN-22'; al3.Level1_Sys_No__c = '353343'; insert new Address_Level__c[] {al1, al2, al3}; Address_Level2__c al21 = new Address_Level2__c(); al21.Level1_Code__c = 'CN-01'; al21.Level1_Sys_No__c = '353341'; al21.Level1_Name__c = '北京市'; al21.Name = '海淀区'; al21.Level2_Code__c = 'CN-0123'; al21.Level2_Sys_No__c = '353664'; al21.Address_Level__c = al1.id; Address_Level2__c al22 = new Address_Level2__c(); al22.Level1_Code__c = 'CN-16'; al22.Level1_Sys_No__c = '353334'; al22.Level1_Name__c = '上海市'; al22.Name = '徐汇区'; al22.Level2_Code__c = 'CN-1631'; al22.Level2_Sys_No__c = '353572'; al22.Address_Level__c = al2.id; Address_Level2__c al23 = new Address_Level2__c(); al23.Level1_Code__c = 'CN-22'; al23.Level1_Sys_No__c = '353343'; al23.Level1_Name__c = '广东省'; al23.Name = '深圳市'; al23.Level2_Code__c = 'CN-2259'; al23.Level2_Sys_No__c = '353700'; al23.Address_Level__c = al3.id; insert new Address_Level2__c[] {al21, al22, al23}; RecordType rectCo = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and DeveloperName = 'Hp']; List rectDpt = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and DeveloperName IN ('Department_GI', 'Department_GS') order by DeveloperName]; Account acc1 = new Account(); acc1.RecordTypeId = rectCo.Id; acc1.Name = 'HP test1'; //acc1.OCM_Management_Province__c = mp1.Id; acc1.State_Master__c = al1.Id; acc1.City_Master__c = al21.Id; Account acc2 = new Account(); acc2.RecordTypeId = rectCo.Id; acc2.Name = 'HP test2'; //acc2.OCM_Management_Province__c = mp2.Id; acc2.State_Master__c = al2.Id; acc2.City_Master__c = al22.Id; Account acc3 = new Account(); acc3.RecordTypeId = rectCo.Id; acc3.Name = 'HP test3'; //acc3.OCM_Management_Province__c = mp3.Id; acc3.State_Master__c = al3.Id; acc3.City_Master__c = al23.Id; insert new Account[] {acc1, acc2, acc3}; List dept1 = [select Id, Name from Account where ParentId = :acc1.Id and Department_Class_Label__c = '消化科']; List dept2 = [select Id, Name from Account where ParentId = :acc2.Id and Department_Class_Label__c = '普外科']; List dept3 = [select Id, Name from Account where ParentId = :acc3.Id and Department_Class_Label__c = '消化科']; dept3[0].OwnerId = u3.Id; update dept3[0]; Account depart1 = new Account(); depart1.RecordTypeId = rectDpt[0].Id; depart1.Name = '*'; depart1.Department_Name__c = '診療科1'; depart1.ParentId = dept1[0].Id; depart1.Department_Class__c = dept1[0].Id; depart1.Hospital__c = acc1.Id; Account depart2 = new Account(); depart2.RecordTypeId = rectDpt[1].Id; depart2.Name = '*'; depart2.Department_Name__c = '診療科2'; depart2.ParentId = dept2[0].Id; depart2.Department_Class__c = dept2[0].Id; depart2.Hospital__c = acc2.Id; Account depart3 = new Account(); depart3.RecordTypeId = rectDpt[0].Id; depart3.Name = '*'; depart3.Department_Name__c = '診療科3'; depart3.ParentId = dept3[0].Id; depart3.Department_Class__c = dept3[0].Id; depart3.Hospital__c = acc3.Id; insert new Account[] {depart1, depart2, depart3}; RecordType oppVND = [select id from RecordType where IsActive = true and SobjectType = 'Opportunity' and DeveloperName = 'Opportunity']; System.Test.startTest(); Opportunity opp1 = new Opportunity( Name = 'test opp1', StageName = '引合', CurrencyIsoCode = 'USD', CloseDate = Date.today(), AccountId = depart1.Id, RecordTypeId = oppVND.Id, Closing_Bid_Date__c = Date.today().addDays(-5), Hospital__c = acc1.Id, Competitor__c = 'A', Opportunity_Category__c = 'GI' ); Opportunity opp2 = new Opportunity( Name = 'test opp2', StageName = '引合', CurrencyIsoCode = 'USD', CloseDate = Date.today(), AccountId = depart2.Id, RecordTypeId = oppVND.Id, Closing_Bid_Date__c = Date.today().addDays(-5), Hospital__c = acc2.Id, Competitor__c = 'B', Opportunity_Category__c = 'SP' ); Opportunity opp3 = new Opportunity( Name = 'test opp3', StageName = '引合', CurrencyIsoCode = 'USD', CloseDate = Date.today(), AccountId = depart3.Id, RecordTypeId = oppVND.Id, Closing_Bid_Date__c = Date.today().addDays(-5), Hospital__c = acc3.Id, Competitor__c = 'B', Opportunity_Category__c = 'GI', OwnerId = u3.Id, owner_not_automatically_update__c = true ); Opportunity opp4 = new Opportunity( Name = 'test opp4', StageName = '引合', CurrencyIsoCode = 'USD', CloseDate = Date.today(), AccountId = depart3.Id, RecordTypeId = oppVND.Id, Closing_Bid_Date__c = Date.today().addDays(-5), Hospital__c = acc3.Id, Competitor__c = 'B', Opportunity_Category__c = 'GI', Distributor_InCharge_opp__c = true ); insert new Opportunity[] {opp1, opp2, opp3, opp4}; List oppList = [select id,Sales_assistant_name_text__c from Opportunity order by Name]; System.assertEquals(u1.Id, oppList[0].Sales_assistant_name_text__c); System.assertEquals(u2.Id, oppList[1].Sales_assistant_name_text__c); System.assertEquals(u3.Id, oppList[2].Sales_assistant_name_text__c); System.assertEquals(loginId, oppList[3].Sales_assistant_name_text__c); opp1.Sales_assistant_name_text__c = null; opp2.Sales_assistant_name_text__c = null; opp3.Sales_assistant_name_text__c = null; opp4.Sales_assistant_name_text__c = null; update new Opportunity[] {opp1, opp2, opp3, opp4}; OCMManagementProvinceWebService.updateOpportunity(); System.Test.stopTest(); } } @isTest static void test_method_two() { Id pricebookId = ControllerUtil.getStandardPricebook().Id; Product2 product = new Product2( Name='テスト商品'); product.SFDA_Status__c = '有効'; product.Intra_Trade_List_RMB_1__c = 100; product.Intra_Trade_List_RMB_Date1__c = date.today(); product.Intra_Trade_Cost_RMB_1__c = 200; product.Intra_Trade_Cost_RMB_Date1__c = date.today(); product.Manual_Entry__c = false; product.Asset_Model_No__c = '11111'; product.ProductCode = 'OTV-SP1H-NA-12E'; insert product; PricebookEntry entry = new PricebookEntry( Pricebook2Id=pricebookId, Product2Id=product.Id); entry.UnitPrice = 0; entry.IsActive = true; entry.UseStandardPrice = false; entry.CurrencyIsoCode = 'CNY'; insert entry; Opportunity opp = new Opportunity(); opp.Name='aiueo'; opp.StageName='contact'; opp.Trade__c = '内貿'; opp.CloseDate=Date.today(); opp.CurrencyIsoCode = 'CNY'; opp.Estimation_List_Price__c = 100; opp.Wholesale_Price__c = 101; opp.Dealer_Final_Price__c = 102; opp.OCM_Agent1_Price__c = 103; opp.Stocking_Price__c = 104; opp.Estimation_No__c = '105'; opp.Estimation_Name__c = '106'; opp.Estimation_Id__c = '107'; insert opp; OpportunityLineItem oppli = new OpportunityLineItem(); oppli.OpportunityId = opp.Id; oppli.Id__c = '110'; oppli.SFDA_Status__c = '有効'; oppli.Name__c = '111'; oppli.ListPrice__c = 112; oppli.Quantity = 113; oppli.UnitPrice = 114; oppli.UnitPrice__c = 115; oppli.Qty_Unit__c = '116'; oppli.Cost__c = 117; oppli.BSS_Category__c = 'G&R'; oppli.Item_Order__c = 1; oppli.PricebookEntryId = entry.Id; insert oppli; Quote quo = new Quote(); quo.Name = '206'; quo.OpportunityId = opp.Id; quo.Quote_No__c = '205'; quo.Estimation_List_Price__c = 200; quo.Dealer_Final_Price__c = 202; quo.Stocking_Price__c = 204; quo.OCM_Sales_Forecast__c = 201; quo.OCM_Agent1_Price__c = 203; quo.Pricebook2Id = pricebookId; insert quo; QuoteLineItem qli = new QuoteLineItem(); qli.QuoteId = quo.Id; qli.Id__c = '210'; qli.SFDA_Status__c = '有効'; qli.Name__c = '211'; qli.ListPrice__c = 212; qli.Quantity = 213; qli.UnitPrice__c = 215; qli.UnitPrice = 0; qli.Qty_Unit__c = '216'; qli.Cost__c = 217; qli.BSS_Category__c = 'ET'; qli.Subtotal__c = 218; qli.PricebookEntryId = entry.Id; insert qli; opp.Estimation_Id__c = quo.Id; opp.Estimation_Decision__c = true; update opp; opp.Estimation_Decision__c = false; update opp; } }