@isTest private class AccountTargetTabControllerTest { static testMethod void myUnitTest() { Profile p = [select Id from Profile where id =:System.Label.ProfileId_SystemAdmin]; // ユーザー作成 User hpOwner = new User(Test_staff__c = true, LastName = 'hp', FirstName = 'owner', Alias = 'hp', CommunityNickname = 'hpOwner', Email = 'olympus_hpowner@sunbridge.com', Username = 'olympus_hpowner@sunbridge.com', IsActive = true, EmailEncodingKey = 'ISO-2022-JP', TimeZoneSidKey = 'Asia/Tokyo', LocaleSidKey = 'ja_JP', LanguageLocaleKey = 'ja', ProfileId = p.id); insert hpOwner; // 取引先作成 List rectHp = [select Id from RecordType where IsActive = true and SobjectType = 'Account' and Name = '病院']; if (rectHp.size() == 0) { return; } // layout作成 Target_account_manage__c layout = new Target_account_manage__c(); layout.Name = 'GI-Case'; layout.department_class__c = '消化科'; layout.field1__c = '{"label":"CV-290","api":"CV290"}'; layout.field2__c = '{"label":"CV-170","api":"CV170"}'; layout.field3__c = '{"label":"EU-ME2","api":"EUME2"}'; insert layout; Account hp = new Account(RecordTypeId = rectHp[0].Id, Name = 'AccountCaseHistoryTestHp1', OwnerId = hpOwner.Id); insert hp; List dc1s = [Select Id, Name, Department_Class_Label__c from Account where Parent.Id = :hp.Id and Department_Class_Label__c in ('消化科')]; // 病例数作る Account_Number_of_target__c ac1 = new Account_Number_of_target__c( Account__c = dc1s[0].Id, Account_HP__c = hp.Id, OCM_Period__c = '146P', OCM_Year__c = '2013年度' ); insert ac1; PageReference page = new PageReference('/apex/AccountTargetTab?id=' + ac1.Id + '&accid=' + dc1s[0].Id + '&t=146P'); System.Test.setCurrentPage(page); AccountTargetTabController controller = new AccountTargetTabController(); controller.init(); System.assertNotEquals(null, controller.history); // update controller.history.rec.Additional_comment__c = 'aaaaa'; controller.save(); page = new PageReference('/apex/AccountTargetTab?id=&accid=' + dc1s[0].Id + '&t='); System.Test.setCurrentPage(page); controller = new AccountTargetTabController(); controller.init(); // insert controller.history.rec.OCM_Year__c = '2014年度'; controller.save(); List acs = [select Id from Account_Number_of_target__c where Account__c = :dc1s[0].Id]; System.assertEquals(3, acs.size()); } private static integer FIELDMAX = 10; // 病例数設定に項目が正しいかどうか @isTest(SeeAllData=true) static void makeSqlTest() { List layoutList = Target_account_manage__c.getall().values(); for (Target_account_manage__c layout : layoutList) { // 病例数のみチェック if (layout.Name.startsWith('目标客户管理-')) { String soql = 'select Id'; for (Integer i = 1; i <= FIELDMAX; i++) { String strI = 'field' + i + '__c'; String fieldStr = String.valueOf(layout.get(strI)); if (String.isBlank(fieldStr) == false) { Map m = (Map) JSON.deserializeUntyped(fieldStr); String api = String.valueOf(m.get('api')); if (String.isBlank(api) == false) { // soql += ', Target_amount_' + api + '__c'; // soql += ', OPD_' + api + '__c'; // soql += ', OPD_amount_' + api + '__c'; } } } soql += ' from Account_Number_of_target__c limit 1'; List tmpList = Database.query(soql); // ExceptionがなければOK System.assertEquals(1, tmpList.size()); } } } }