11d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert/* 21d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Copyright (C) 2008 The Guava Authors 31d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * 41d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Licensed under the Apache License, Version 2.0 (the "License"); 51d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * you may not use this file except in compliance with the License. 61d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * You may obtain a copy of the License at 71d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * 81d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * http://www.apache.org/licenses/LICENSE-2.0 91d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * 101d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Unless required by applicable law or agreed to in writing, software 111d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * distributed under the License is distributed on an "AS IS" BASIS, 121d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 131d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * See the License for the specific language governing permissions and 141d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * limitations under the License. 151d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert */ 161d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 171d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertpackage com.google.common.testing; 181d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 191d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport com.google.common.annotations.Beta; 201d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 211d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.ArrayList; 221d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.Collections; 231d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.List; 241d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.logging.Handler; 251d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertimport java.util.logging.LogRecord; 261d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 271d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert/** 281d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Tests may use this to intercept messages that are logged by the code under 291d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * test. Example: 301d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * <pre> 311d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * TestLogHandler handler; 321d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * 331d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * protected void setUp() throws Exception { 341d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * super.setUp(); 351d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * handler = new TestLogHandler(); 361d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * SomeClass.logger.addHandler(handler); 371d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * addTearDown(new TearDown() { 381d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * public void tearDown() throws Exception { 391d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * SomeClass.logger.removeHandler(handler); 401d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * } 411d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * }); 421d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * } 431d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * 441d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * public void test() { 451d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * SomeClass.foo(); 461d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * LogRecord firstRecord = handler.getStoredLogRecords().get(0); 471d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * assertEquals("some message", firstRecord.getMessage()); 481d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * } 491d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * </pre> 501d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * 511d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * @author Kevin Bourrillion 521d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * @since 10.0 531d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert */ 541d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert@Beta 551d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringertpublic class TestLogHandler extends Handler { 561d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert /** We will keep a private list of all logged records */ 571d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert private final List<LogRecord> list = 581d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert Collections.synchronizedList(new ArrayList<LogRecord>()); 591d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 601d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert /** 611d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Adds the most recently logged record to our list. 621d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert */ 631d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert @Override 641d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert public void publish(LogRecord record) { 651d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert list.add(record); 661d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert } 671d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 681d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert @Override 691d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert public void flush() { } 701d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 711d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert @Override 721d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert public void close() { } 731d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 741d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert public void clear() { 751d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert list.clear(); 761d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert } 771d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert 781d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert /** 791d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * Fetch the list of logged records 801d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert * @return unmodifiable LogRecord list of all logged records 811d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert */ 821d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert public List<LogRecord> getStoredLogRecords() { 831d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert List<LogRecord> result = new ArrayList<LogRecord>(list); 841d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert return Collections.unmodifiableList(result); 851d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert } 861d580d0f6ee4f21eb309ba7b509d2c6d671c4044Bjorn Bringert} 87