Package org.exoplatform.services.jcr.cluster.load.webdav

Source Code of org.exoplatform.services.jcr.cluster.load.webdav.WebDavTestAgent

/*
* Copyright (C) 2010 eXo Platform SAS.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software 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.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.services.jcr.cluster.load.webdav;

import org.exoplatform.common.http.HTTPStatus;
import org.exoplatform.common.http.client.HTTPResponse;
import org.exoplatform.services.jcr.cluster.JCRWebdavConnection;
import org.exoplatform.services.jcr.cluster.load.NodeInfo;
import org.exoplatform.services.jcr.cluster.load.ResultCollector;

import java.util.List;
import java.util.Random;
import java.util.UUID;
import java.util.concurrent.CountDownLatch;

/**
* @author <a href="mailto:Sergey.Kabashnyuk@exoplatform.org">Sergey Kabashnyuk</a>
* @version $Id: exo-jboss-codetemplates.xml 34360 2009-07-22 23:58:59Z ksm $
*
*/
public class WebDavTestAgent extends AbstractWebDavTestAgent
{

   private String testRoot;

   private boolean readFresh = true;

   /**
    * @param nodesPath
    * @param responceResults
    * @param startSignal
    * @param READ_VALUE
    * @param random
    */
   public WebDavTestAgent(String testRoot, List<NodeInfo> nodesPath, ResultCollector resultCollector,
      CountDownLatch startSignal, int READ_VALUE, Random random, boolean isReadThread)
   {
      super(nodesPath, resultCollector, startSignal, READ_VALUE, random, isReadThread);
      this.testRoot = testRoot;
   }

   /**
    * @see org.exoplatform.services.jcr.cluster.load.AbstractTestAgent#doRead(java.util.List)
    */
   @Override
   public void doRead(List<NodeInfo> nodesPath, ResultCollector resultCollector)
   {
      if (nodesPath.size() > 0)
      {

         String readNodePath = null;
         while (readNodePath == null)
         {
            NodeInfo nodeInfo = nodesPath.get(random.nextInt(nodesPath.size()));
            if (!readFresh && (System.currentTimeMillis() - nodeInfo.getCreated()) < 30000)
            {
               return;
            }

            readNodePath = nodeInfo.getPath();

         }
         long start = System.currentTimeMillis();
         JCRWebdavConnection conn = null;
         try
         {
            conn = getNewConnection();
            HTTPResponse response = conn.getNode(readNodePath);
            if (response.getStatusCode() == HTTPStatus.OK)
            {
               resultCollector.addResult(true, System.currentTimeMillis() - start);
            }
            else
            {
               System.out.println("Can not get (response code " + response.getStatusCode()
                  + new String(response.getData()) + " ) node with path : " + readNodePath);

            }

         }
         catch (Exception e)
         {
            System.out.println(e.getLocalizedMessage());
         }
         finally
         {
            if (conn != null)
            {
               conn.stop();
            }
         }

      }
   }

   /**
    * @see org.exoplatform.services.jcr.cluster.load.AbstractTestAgent#prepare()
    */
   @Override
   protected void prepare()
   {
      testRoot = createDirIfAbsent(testRoot, UUID.randomUUID().toString(), new ResultCollector());
   }

   /**
    * @see org.exoplatform.services.jcr.cluster.load.AbstractTestAgent#doWrite(java.util.List)
    */
   @Override
   public void doWrite(List<NodeInfo> nodesPath, ResultCollector resultCollector)
   {

      JCRWebdavConnection connection = null;
      try
      {
         connection = getNewConnection();
         String putFile = testRoot + "/" + UUID.randomUUID().toString();

         long start = System.currentTimeMillis();
         HTTPResponse response = connection.addNode(putFile, ("__the_data_in_nt+file__").getBytes(), "text/plain");

         if (response.getStatusCode() == HTTPStatus.CREATED)
         {
            resultCollector.addResult(false, System.currentTimeMillis() - start);
            nodesPath.add(new NodeInfo(putFile, System.currentTimeMillis()));
         }
         else
         {
            System.out.println(Thread.currentThread().getName() + " : Can not add (response code "
               + response.getStatusCode() + new String(response.getData()) + " ) file with path : " + putFile);

         }

      }
      catch (Exception e)
      {
         System.out.println(e.getLocalizedMessage());
      }
      finally
      {
         if (connection != null)
         {
            connection.stop();
         }
      }
   }

   /**
    * Create WebDav node if not exist
    * @param root
    * @param name
    * @param data
    * @return
    */
   public String createDirIfAbsent(String root, String name, ResultCollector resultCollector)
   {
      String path = root.length() == 0 ? name : root + "/" + name;
      JCRWebdavConnection connection = null;
      try
      {
         connection = getNewConnection();

         long start = System.currentTimeMillis();
         HTTPResponse nodeResponce = connection.getNode(path);
         //add information about read

         resultCollector.addResult(true, System.currentTimeMillis() - start);
         if (nodeResponce.getStatusCode() != HTTPStatus.OK)
         {
            start = System.currentTimeMillis();
            HTTPResponse addResponce = connection.addDir(path);
            //add information about write

            if (addResponce.getStatusCode() == HTTPStatus.CREATED)
            {
               resultCollector.addResult(false, System.currentTimeMillis() - start);
            }
            else
            {
               System.out.println(Thread.currentThread().getName() + " : Can not add (response code "
                  + addResponce.getStatusCode() + new String(addResponce.getData()) + " ) node with path : " + path);

            }
         }
      }
      catch (Exception e)
      {
         System.out.println(e.getLocalizedMessage());
      }
      finally
      {
         if (connection != null)
         {
            connection.stop();
         }
      }
      return path;
   }

   /**
    * Create WebDav node if not exist
    * @param root
    * @param uuid
    * @param data
    * @return
    */
   public String createDirIfAbsent(String root, UUID uuid, ResultCollector resultCollector)
   {
      String uuidPath = uuid.toString();
      String l1 = createDirIfAbsent(root, uuidPath.substring(0, 8), resultCollector);
      //      String l2 = createDirIfAbsent(l1, uuidPath.substring(9, 13), result);
      //      String l3 = createDirIfAbsent(l2, uuidPath.substring(14, 18), result);
      //      String l4 = createDirIfAbsent(l3, uuidPath.substring(19, 23), result);
      return createDirIfAbsent(l1, uuidPath.substring(9), resultCollector);

   }
}
TOP

Related Classes of org.exoplatform.services.jcr.cluster.load.webdav.WebDavTestAgent

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.