[exo-jcr-commits] exo-jcr SVN: r5696 - in jcr/branches/1.15.x/exo.jcr.component.webdav/src: test/java/org/exoplatform/services/jcr/webdav/command and 1 other directory.

do-not-reply at jboss.org do-not-reply at jboss.org
Fri Feb 24 04:51:07 EST 2012


Author: nzamosenchuk
Date: 2012-02-24 04:51:05 -0500 (Fri, 24 Feb 2012)
New Revision: 5696

Modified:
   jcr/branches/1.15.x/exo.jcr.component.webdav/src/main/java/org/exoplatform/services/jcr/webdav/command/dasl/SearchResultResponseEntity.java
   jcr/branches/1.15.x/exo.jcr.component.webdav/src/test/java/org/exoplatform/services/jcr/webdav/command/TestSearch.java
Log:
EXOJCR-364 : check if uri was already written to the output stream

Modified: jcr/branches/1.15.x/exo.jcr.component.webdav/src/main/java/org/exoplatform/services/jcr/webdav/command/dasl/SearchResultResponseEntity.java
===================================================================
--- jcr/branches/1.15.x/exo.jcr.component.webdav/src/main/java/org/exoplatform/services/jcr/webdav/command/dasl/SearchResultResponseEntity.java	2012-02-24 09:46:37 UTC (rev 5695)
+++ jcr/branches/1.15.x/exo.jcr.component.webdav/src/main/java/org/exoplatform/services/jcr/webdav/command/dasl/SearchResultResponseEntity.java	2012-02-24 09:51:05 UTC (rev 5696)
@@ -125,6 +125,7 @@
          xmlStreamWriter.writeAttribute("xmlns:b", "urn:uuid:c2f41010-65b3-11d1-a29f-00aa00c14882/");
 
          NodeIterator nodeIter = queryResult.getNodes();
+         Set<URI> resultNodes = new HashSet<URI>();
          while (nodeIter.hasNext())
          {
             Node nextNode = nodeIter.nextNode();
@@ -144,44 +145,50 @@
 
             URI uri = new URI(TextUtil.escape(baseURI + nextNode.getPath(), '%', true));
 
-            Resource resource;
-            if (ResourceUtil.isVersioned(nextNode))
+            // if URI is new, and wasn't previously being written, then write it
+            if (resultNodes.add(uri))
             {
-               if (ResourceUtil.isFile(nextNode))
+               Resource resource;
+               if (ResourceUtil.isVersioned(nextNode))
                {
-                  resource = new VersionedFileResource(uri, nextNode, nsContext);
+                  if (ResourceUtil.isFile(nextNode))
+                  {
+                     resource = new VersionedFileResource(uri, nextNode, nsContext);
+                  }
+                  else
+                  {
+                     resource = new VersionedCollectionResource(uri, nextNode, nsContext);
+                  }
                }
                else
                {
-                  resource = new VersionedCollectionResource(uri, nextNode, nsContext);
+                  if (ResourceUtil.isFile(nextNode))
+                  {
+                     resource = new FileResource(uri, nextNode, nsContext);
+                  }
+                  else
+                  {
+                     resource = new CollectionResource(uri, nextNode, nsContext);
+                  }
                }
-            }
-            else
-            {
-               if (ResourceUtil.isFile(nextNode))
-               {
-                  resource = new FileResource(uri, nextNode, nsContext);
-               }
-               else
-               {
-                  resource = new CollectionResource(uri, nextNode, nsContext);
-               }
-            }
 
-            xmlStreamWriter.writeStartElement("DAV:", "response");
+               xmlStreamWriter.writeStartElement("DAV:", "response");
 
-            xmlStreamWriter.writeStartElement("DAV:", "href");
-            xmlStreamWriter.writeCharacters(resource.getIdentifier().toASCIIString());
-            xmlStreamWriter.writeEndElement();
+               xmlStreamWriter.writeStartElement("DAV:", "href");
+               xmlStreamWriter.writeCharacters(resource.getIdentifier().toASCIIString());
+               xmlStreamWriter.writeEndElement();
 
-            PropstatGroupedRepresentation propstat = new PropstatGroupedRepresentation(resource, properties, false);
+               PropstatGroupedRepresentation propstat = new PropstatGroupedRepresentation(resource, properties, false);
 
-            PropertyWriteUtil.writePropStats(xmlStreamWriter, propstat.getPropStats());
+               PropertyWriteUtil.writePropStats(xmlStreamWriter, propstat.getPropStats());
 
-            xmlStreamWriter.writeEndElement();
+               xmlStreamWriter.writeEndElement();
+            }
 
          }
-
+         // for better GC
+         resultNodes.clear();
+         resultNodes = null;
          // D:multistatus
          xmlStreamWriter.writeEndElement();
          xmlStreamWriter.writeEndDocument();
@@ -196,5 +203,4 @@
          throw new IOException(exc.getMessage());
       }
    }
-
 }

Modified: jcr/branches/1.15.x/exo.jcr.component.webdav/src/test/java/org/exoplatform/services/jcr/webdav/command/TestSearch.java
===================================================================
--- jcr/branches/1.15.x/exo.jcr.component.webdav/src/test/java/org/exoplatform/services/jcr/webdav/command/TestSearch.java	2012-02-24 09:46:37 UTC (rev 5695)
+++ jcr/branches/1.15.x/exo.jcr.component.webdav/src/test/java/org/exoplatform/services/jcr/webdav/command/TestSearch.java	2012-02-24 09:51:05 UTC (rev 5696)
@@ -27,11 +27,23 @@
 
 import java.io.ByteArrayInputStream;
 import java.io.ByteArrayOutputStream;
+import java.io.IOException;
 import java.io.InputStream;
 import java.net.URLDecoder;
+import java.util.ArrayList;
+import java.util.Calendar;
+import java.util.List;
 
+import javax.jcr.Node;
 import javax.ws.rs.core.MediaType;
+import javax.xml.namespace.QName;
+import javax.xml.stream.FactoryConfigurationError;
+import javax.xml.stream.XMLInputFactory;
+import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.stream.events.StartElement;
 
+
 /**
  * Created by The eXo Platform SAS. <br/>
  * Date: 15 Dec 2008
@@ -46,9 +58,12 @@
 
    private final String fileContent = "TEST FILE CONTENT...";
 
-   private final String sql = "<D:searchrequest xmlns:D='DAV:'>" + "<D:sql>"
+   private final String basicSql = "<D:searchrequest xmlns:D='DAV:'>" + "<D:sql>"
       + "SELECT * FROM  nt:resource WHERE contains(*, 'TEST')" + "</D:sql>" + "</D:searchrequest>";
 
+   private final String pathSql = "<D:searchrequest xmlns:D='DAV:'>" + "<D:sql>"
+            + "SELECT * FROM nt:base WHERE jcr:path LIKE '/node[%]/%'" + "</D:sql>" + "</D:searchrequest>";
+
    public void testBasicSearch() throws Exception
    {
 
@@ -61,7 +76,7 @@
 
       InputStream inputStream = new ByteArrayInputStream(fileContent.getBytes());
       TestUtils.addContent(session, fileName, inputStream, defaultFileNodeType, MediaType.TEXT_PLAIN);
-      ContainerResponse response = service(WebDAVMethods.SEARCH, getPathWS(), "", null, sql.getBytes());
+      ContainerResponse response = service(WebDAVMethods.SEARCH, getPathWS(), "", null, basicSql.getBytes());
       assertEquals(HTTPStatus.MULTISTATUS, response.getStatus());
       SearchResultResponseEntity entity = (SearchResultResponseEntity)response.getEntity();
       ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
@@ -70,6 +85,28 @@
       assertTrue(result.contains(fileName));
    }
 
+   public void testPathSearch() throws Exception
+   {
+      Node testRoot = session.getRootNode().addNode("node", defaultFolderNodeType);
+      Node node = testRoot.addNode("addedNode", defaultFileNodeType);
+      node.addNode("jcr:content", "nt:resource");
+      Node content = node.getNode("jcr:content");
+      content.setProperty("jcr:mimeType", MediaType.TEXT_PLAIN);
+      content.setProperty("jcr:lastModified", Calendar.getInstance());
+      content.setProperty("jcr:data", new ByteArrayInputStream("Text".getBytes()));
+      session.save();
+      
+      ContainerResponse response = service(WebDAVMethods.SEARCH, getPathWS(), "", null, pathSql.getBytes());
+      SearchResultResponseEntity entity = (SearchResultResponseEntity)response.getEntity();
+      ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
+      entity.write(outputStream);
+      outputStream.toByteArray();
+      List<String> found = parseNodeNames(outputStream.toByteArray());
+      System.out.println(found);
+      assertEquals(1, found.size());
+      
+   }
+
    /**
     * Here we test WebDAV SEARCH method implementation for correct response 
     * if request contains encoded non-latin characters. We send a request with
@@ -86,7 +123,7 @@
       InputStream inputStream = new ByteArrayInputStream(fileContent.getBytes());
       TestUtils.addContent(session, decodedfileName, inputStream, defaultFileNodeType, MediaType.TEXT_PLAIN);
 
-      ContainerResponse response = service(WebDAVMethods.SEARCH, getPathWS(), "", null, sql.getBytes());
+      ContainerResponse response = service(WebDAVMethods.SEARCH, getPathWS(), "", null, basicSql.getBytes());
 
       // serialize response entity to string
       SearchResultResponseEntity entity = (SearchResultResponseEntity)response.getEntity();
@@ -110,4 +147,65 @@
    {
       return null;
    }
+   
+   /**
+    * Extracts names of nodes from response XML
+    * 
+    * @param data
+    * @return
+    * @throws XMLStreamException
+    * @throws FactoryConfigurationError
+    * @throws IOException
+    */
+   private List<String> parseNodeNames(byte[] data) throws XMLStreamException, FactoryConfigurationError, IOException
+   {
+      // flag, that notifies when parser is inside <D:displayname></D:displayname> 
+      boolean displayName = false;
+      //Set<String> nodes = new HashSet<String>();
+      List<String> nodes = new ArrayList<String>();
+      InputStream input = new ByteArrayInputStream(data);
+      XMLStreamReader reader = XMLInputFactory.newInstance().createXMLStreamReader(input);
+      QName name = QName.valueOf("{DAV:}href");
+      try
+      {
+         while (reader.hasNext())
+         {
+            int eventCode = reader.next();
+            switch (eventCode)
+            {
+               case StartElement.START_ELEMENT : {
+                  // if {DAV:}displayname opening element 
+                  if (reader.getName().equals(name))
+                  {
+                     displayName = true;
+                  }
+                  break;
+               }
+               case StartElement.CHARACTERS : {
+                  if (displayName)
+                  {
+                     // currently reader is inside <D:displayname>nodeName</D:displayname>
+                     // adding name to list if not empty
+                     String nodeName = reader.getText();
+                     if (nodeName != null && !nodeName.equals(""))
+                     {
+                        nodes.add(nodeName);
+                     }
+                  }
+                  break;
+               }
+               default : {
+                  displayName = false;
+                  break;
+               }
+            }
+         }
+      }
+      finally
+      {
+         reader.close();
+         input.close();
+      }
+      return new ArrayList<String>(nodes);
+   }
 }



More information about the exo-jcr-commits mailing list