Author: bdelacretaz Date: Tue Dec 23 07:42:04 2008 New Revision: 729005 URL: http://svn.apache.org/viewvc?rev=729005&view=rev Log: SLING-795 - do not recurse into synthetic resources when generating a JSON dump
Modified: incubator/sling/trunk/ (props changed) incubator/sling/trunk/launchpad/testing/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/JsonRenderingTest.java incubator/sling/trunk/servlets/get/src/main/java/org/apache/sling/servlets/get/helpers/JsonResourceWriter.java Propchange: incubator/sling/trunk/ ------------------------------------------------------------------------------ --- svn:ignore (original) +++ svn:ignore Tue Dec 23 07:42:04 2008 @@ -10,3 +10,4 @@ .project .classpath .externalToolBuilders +cachedir Modified: incubator/sling/trunk/launchpad/testing/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/JsonRenderingTest.java URL: http://svn.apache.org/viewvc/incubator/sling/trunk/launchpad/testing/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/JsonRenderingTest.java?rev=729005&r1=729004&r2=729005&view=diff ============================================================================== --- incubator/sling/trunk/launchpad/testing/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/JsonRenderingTest.java (original) +++ incubator/sling/trunk/launchpad/testing/src/test/java/org/apache/sling/launchpad/webapp/integrationtest/JsonRenderingTest.java Tue Dec 23 07:42:04 2008 @@ -28,6 +28,7 @@ /** Test creating Nodes and rendering them in JSON */ public class JsonRenderingTest extends HttpTestBase { + private final String testPath = "/" + getClass().getSimpleName(); private String postUrl; private String testText; @@ -45,7 +46,7 @@ // create the test node, under a path that's specific to this class to // allow collisions - postUrl = HTTP_BASE_URL + "/" + getClass().getSimpleName() + "_" + postUrl = HTTP_BASE_URL + testPath + "_" + System.currentTimeMillis() + SlingPostConstants.DEFAULT_CREATE_SUFFIX; final Map<String, String> props = new HashMap<String, String>(); @@ -212,4 +213,16 @@ assertTrue("The .tidy selector should add at least 2 EOL chars to json output (delta=" + delta + ")", delta > min); } + + public void testRootNoRecursion() throws IOException { + final String json = getContent(HTTP_BASE_URL + "/.json", CONTENT_TYPE_JSON); + assertJavascript("rep:root", json, "out.print(data['jcr:primaryType'])"); + assertJavascript("undefined", json, "out.print(typeof data['jcr:system'])"); + } + + public void testRootWithRecursion() throws IOException { + final String json = getContent(HTTP_BASE_URL + "/.1.json", CONTENT_TYPE_JSON); + assertJavascript("rep:root", json, "out.print(data['jcr:primaryType'])"); + assertJavascript("rep:system", json, "out.print(data['jcr:system']['jcr:primaryType'])"); + } } \ No newline at end of file Modified: incubator/sling/trunk/servlets/get/src/main/java/org/apache/sling/servlets/get/helpers/JsonResourceWriter.java URL: http://svn.apache.org/viewvc/incubator/sling/trunk/servlets/get/src/main/java/org/apache/sling/servlets/get/helpers/JsonResourceWriter.java?rev=729005&r1=729004&r2=729005&view=diff ============================================================================== --- incubator/sling/trunk/servlets/get/src/main/java/org/apache/sling/servlets/get/helpers/JsonResourceWriter.java (original) +++ incubator/sling/trunk/servlets/get/src/main/java/org/apache/sling/servlets/get/helpers/JsonResourceWriter.java Tue Dec 23 07:42:04 2008 @@ -132,7 +132,7 @@ protected void dumpSingleResource(Resource n, JSONWriter w, int currentRecursionLevel, int maxRecursionLevels) throws JSONException { - if (recursionLevelActive(currentRecursionLevel, maxRecursionLevels)) { + if (recursionLevelActive(currentRecursionLevel, maxRecursionLevels) && !ResourceUtil.isSyntheticResource(n) ) { w.key(ResourceUtil.getName(n)); dump(n, w, currentRecursionLevel + 1, maxRecursionLevels); }