/* * (C) Copyright 2014 Kurento (http://kurento.org/) * * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Lesser General Public License * (LGPL) version 2.1 which accompanies this distribution, and is available at * http://www.gnu.org/licenses/lgpl-2.1.html * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * */ package com.kurento.kmf.test.base; import java.io.File; import java.io.IOException; import org.apache.commons.io.FileUtils; import org.junit.internal.runners.model.MultipleFailureException; import org.junit.rules.TestWatcher; import org.junit.runner.Description; import com.kurento.kmf.test.services.KurentoServicesTestHelper; /** * Utility class to print KMS log when a test fails. * * @author Boni Garcia (bgarcia@gsyc.es) * @since 4.2.3 */ @SuppressWarnings("deprecation") public class KmsLogOnFailure extends TestWatcher { @Override protected void failed(Throwable e, Description description) { if (KurentoServicesTestHelper.printKmsLog()) { File logFile = KurentoServicesTestHelper.getServerLogFile(); if (logFile != null && logFile.exists()) { System.err .println("******************************************************************************"); System.err.println("Log file path: " + logFile.getAbsolutePath()); System.err.println("Content:"); try { for (String line : FileUtils.readLines(logFile)) { System.err.println(line); } } catch (IOException e1) { System.err.println("Error reading lines in log file"); e1.printStackTrace(); } System.err .println("******************************************************************************"); } } } @SuppressWarnings({ "unused" }) private void showException(Throwable e) { if (e instanceof org.junit.internal.runners.model.MultipleFailureException) { MultipleFailureException multipleEx = (MultipleFailureException) e; for (Throwable failure : multipleEx.getFailures()) { failure.printStackTrace(); } } else { e.printStackTrace(); } } }