8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26 package test.com.sun.javafx.binding; 27 28 import com.sun.javafx.binding.Logging; 29 import java.util.logging.Handler; 30 import java.util.logging.Level; 31 import java.util.logging.LogManager; 32 import java.util.logging.LogRecord; 33 import java.util.logging.Logger; 34 35 import static org.junit.Assert.*; 36 37 public class ErrorLoggingUtiltity { 38 39 static { 40 // initialize PlatformLogger 41 Logging.getLogger(); 42 } 43 44 // getLogManager will redirect existing PlatformLogger to the Logger 45 private static final Logger logger = LogManager.getLogManager().getLogger("javafx.beans"); 46 47 Level level; 48 LogRecord lastRecord; 49 50 Handler handler = new Handler() { 51 52 @Override 53 public void publish(LogRecord record) { 54 lastRecord = record; 55 } 56 57 @Override 58 public void flush() { 59 } 60 61 @Override 62 public void close() throws SecurityException { 63 } 64 }; 65 66 public void start() { 67 reset(); 68 level = logger.getLevel(); 69 logger.setLevel(Level.ALL); 70 logger.addHandler(handler); 71 } 72 73 public void stop() { 74 logger.setLevel(level); 75 logger.removeHandler(handler); 76 } 77 78 public void reset() { 79 lastRecord = null; 80 } 81 82 public void checkFine(Class expectedException) { 83 check(Level.FINE, expectedException); 84 } 85 86 public void check(Level expectedLevel, Class expectedException) { 87 assertNotNull(lastRecord); 88 assertEquals(expectedLevel, lastRecord.getLevel()); 89 assertTrue(expectedException.isAssignableFrom(lastRecord.getThrown().getClass())); 90 reset(); 91 } 92 93 public boolean isEmpty() { 94 return lastRecord == null; 95 } 96 } | 8 * particular file as subject to the "Classpath" exception as provided 9 * by Oracle in the LICENSE file that accompanied this code. 10 * 11 * This code is distributed in the hope that it will be useful, but WITHOUT 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 14 * version 2 for more details (a copy is included in the LICENSE file that 15 * accompanied this code). 16 * 17 * You should have received a copy of the GNU General Public License version 18 * 2 along with this work; if not, write to the Free Software Foundation, 19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20 * 21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 22 * or visit www.oracle.com if you need additional information or have any 23 * questions. 24 */ 25 26 package test.com.sun.javafx.binding; 27 28 import static org.junit.Assert.*; 29 30 import com.sun.javafx.logging.PlatformLogger.Level; 31 32 import com.sun.javafx.binding.Logging; 33 import com.sun.javafx.binding.Logging.ErrorLogger.ErrorLogRecord; 34 import com.sun.javafx.binding.Logging.ErrorLogger; 35 36 public class ErrorLoggingUtiltity { 37 38 private static ErrorLogger loggingHolder = Logging.getLogger(); 39 40 public static void start() { 41 reset(); 42 // level = logger.getLevel(); 43 // logger.setLevel(Level.ALL); 44 // logger.addHandler(handler); 45 } 46 47 public static void stop() { 48 // logger.setLevel(level); 49 // logger.removeHandler(handler); 50 } 51 52 public static void reset() { 53 loggingHolder.setErrorLogRecord(null); 54 } 55 56 public static boolean isEmpty() { 57 return loggingHolder.getErrorLogRecord() == null; 58 } 59 60 /** 61 * Convenience method for check(Level.FINE, expectedException) 62 */ 63 public static void checkFine(Class<?> expectedException) { 64 check(Level.FINE, expectedException); 65 } 66 67 /** 68 * Convenience method for check(Level.WARNING, expectedException) 69 */ 70 public static void checkWarning(Class<?> expectedException) { 71 check(Level.WARNING, expectedException); 72 } 73 74 private static void check(Level expectedLevel, Class<?> expectedException) { 75 ErrorLogRecord errorLogRecord = loggingHolder.getErrorLogRecord(); 76 assertNotNull(errorLogRecord); 77 assertEquals(expectedLevel, errorLogRecord.getLevel()); 78 assertTrue(expectedException.isAssignableFrom(errorLogRecord.getThrown().getClass())); 79 reset(); 80 } 81 } |