/* jBilling - The Enterprise Open Source Billing System Copyright (C) 2003-2011 Enterprise jBilling Software Ltd. and Emiliano Conde This file is part of jbilling. jbilling is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. jbilling 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 Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with jbilling. If not, see <http://www.gnu.org/licenses/>. */ package com.sapienter.jbilling.server.provisioning.task; import java.util.Map; import org.apache.log4j.Logger; import com.sapienter.jbilling.server.pluggableTask.TaskException; /** * Dummy CAI communication class for testing CAIProvisioningTask. */ public class TestCommunication implements IExternalCommunication { private static final Logger LOG = Logger.getLogger(TestCommunication.class); public void connect(Map<String, String> parameters) throws TaskException { LOG.debug("Connect"); } public String send(String command) throws TaskException { LOG.debug("Command: " + command); // return success (without a TRANSID) for login/logout commands if (command.startsWith("LOGIN:") || command.equals("LOGOUT;")) { return "RESP:0;"; } // wait for command rules task transaction to complete //pause(2000); int transidIndexStart = command.indexOf(':', command.indexOf(':') + 1) + 9; int transidIndexEnd = command.indexOf(":", transidIndexStart); String transid = command.substring(transidIndexStart, transidIndexEnd); // return success as well as the input fields String response = "RESP:TRANSID," + transid + ":0" + command.substring(transidIndexEnd, command.length()); LOG.debug("Response: " + response); return response; } public void close() throws TaskException { LOG.debug("Close"); } private void pause(long t) { LOG.debug("TestCommunication: pausing for " + t + " ms..."); try { Thread.sleep(t); } catch (InterruptedException e) { } } }