/* JTestServer is a client/server framework for testing any JVM implementation. Copyright (C) 2008 Fabien DUMINY (fduminy@jnode.org) JTestServer is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. JTestServer 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 General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package org.jtestserver.client; import gnu.testlet.runner.RunResult; import gnu.testlet.runner.XMLReportParser; import java.io.IOException; import java.io.StringReader; import java.util.logging.Level; import java.util.logging.Logger; import net.sourceforge.nanoxml.XMLParseException; import org.jtestserver.common.Status; import org.jtestserver.common.message.Descriptors; import org.jtestserver.common.message.Message; import org.jtestserver.common.protocol.Client; import org.jtestserver.common.protocol.ProtocolException; import org.jtestserver.common.protocol.TimeoutException; public class DefaultTestClient implements TestClient { private static final Logger LOGGER = Logger.getLogger(DefaultTestClient.class.getName()); private final Client<?, ?> client; public DefaultTestClient(Client<?, ?> client) { this.client = client; } @Override public RunResult runMauveTest(String test) throws ProtocolException, TimeoutException { String report = (String) Message.send(client, Descriptors.RUN_MAUVE_TEST, test); LOGGER.log(Level.INFO, "parsing xml report for " + test); return parseMauveReport(report); } protected RunResult parseMauveReport(String report) throws ProtocolException { XMLReportParser parser = new XMLReportParser(); StringReader sr = new StringReader(report); try { LOGGER.log(Level.INFO, "xml report: " + report); return parser.parse(sr); } catch (XMLParseException e) { throw new ProtocolException("invalid XML answer", e); } catch (IOException e) { throw new ProtocolException("I/O error", e); } } @Override public Status getStatus() throws ProtocolException, TimeoutException { return (Status) Message.send(client, Descriptors.GET_STATUS); } @Override public void shutdown() throws ProtocolException, TimeoutException { Message.send(client, Descriptors.SHUTDOWN); } @Override public void close() throws ProtocolException { try { shutdown(); } catch (TimeoutException e) { LOGGER.log(Level.SEVERE, "error in close", e); } client.close(); } }