All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.uiautomation.ios.wkrdp.internal.DefaultMessageHandler Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2012-2013 eBay Software Foundation and ios-driver committers
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 * in compliance with the License. You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under the License
 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 * or implied. See the License for the specific language governing permissions and limitations under
 * the License.
 */
package org.uiautomation.ios.wkrdp.internal;

import org.json.JSONObject;
import org.openqa.selenium.TimeoutException;
import org.uiautomation.ios.wkrdp.MessageHandler;
import org.uiautomation.ios.wkrdp.MessageListener;
import org.uiautomation.ios.wkrdp.ResponseFinder;
import org.uiautomation.ios.wkrdp.ResponseFinderList;
import org.uiautomation.ios.wkrdp.message.ApplicationDataMessage;
import org.uiautomation.ios.wkrdp.message.IOSMessage;
import org.uiautomation.ios.wkrdp.message.MessageFactory;

import java.util.*;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.logging.Logger;


public class DefaultMessageHandler implements MessageHandler {

  private final static long timeoutInMs = 5000;
  private final List listeners = new CopyOnWriteArrayList();
  private Set threads = new HashSet();
  private boolean stopped;
  private static final Logger log = Logger.getLogger(DefaultMessageHandler.class.getName());
  private List extraFinders = new ArrayList();
  private final MessageFactory factory = new MessageFactory();
  private final
  DefaultWebKitResponseFinder
      defaultFinder =
      new DefaultWebKitResponseFinder(timeoutInMs);

  public DefaultMessageHandler(MessageListener listener, ResponseFinder... finders) {
    listeners.add(listener);

    Collections.addAll(this.extraFinders, finders);
  }

  private static int threadCount;

  @Override
  public synchronized void handle(final String msg) {
    if (stopped) {
      throw new IllegalStateException("stopped");
    }

    Thread t = new Thread("DefaultMessageHandler-" + ++threadCount) {
      @Override
      public void run() {
        process(msg);
        threads.remove(this);
      }
    };
    threads.add(t);
    t.start();
  }

  private void process(String rawMessage) {
    IOSMessage message = factory.create(rawMessage);

    for (MessageListener l : listeners) {
      l.onMessage(message);
    }

    if (message instanceof ApplicationDataMessage) {
      JSONObject content = ((ApplicationDataMessage) message).getMessage();
      if ((content.optInt("id", -1) != -1)) {
        defaultFinder.addResponse(content);
      }
    }
  }


  @Override
  public JSONObject getResponse(int id) throws TimeoutException {
    // there can be 2 things happening here.
    // 1) the response is received.
    // 2) the response is never received because there is an alert.

    // ResponseFinder.
    // startSearch
    // interruptSearch
    // waitForResult

    long start = System.currentTimeMillis();

    List finders = new ArrayList();
    finders.add(defaultFinder);
    finders.addAll(extraFinders);

    ResponseFinderList all = new ResponseFinderList(finders, timeoutInMs);
    try {
      JSONObject res = all.findResponse(id);
      log.fine(
          "response " + id + " , " + (System.currentTimeMillis() - start) + "ms. " + res
              .toString());

      return res;
    } catch (RuntimeException e) {
      throw e;
    }
  }


  @Override
  public void addListener(MessageListener listener) {
    listeners.add(listener);
  }

  @Override
  public synchronized void stop() {
    stopped = true;
    for (Thread t : threads) {
      t.interrupt();
    }
  }


}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy