Hi Josh,

I'm just wiring up a bunch of code that implements REST paging, and then I'll 
codify these tests and sort it out.

Jim

On 18 Jun 2011, at 01:17, Josh Adell wrote:

> Jim,
> The best I can do as far as a failing test is this series of curl
> calls.  I create 2 nodes, then connect them with a relationship that
> has a property called "distance".  When I ask for paths without
> specifying the algorithm, I get back the path with the relationship.
> When I specify the algorithm as "dijkstra" with a cost property of
> "distance", I get back a 400 Bad Request with a stack trace.
> 
> Now interestingly, if I create the relationship with a distance of
> 2.0, it works.  Unfortunately, PHP's json_encode method turns a double
> 2.0 into an integer 2.
> 
> My original thought was to make the DoubleEvaluator class cast the
> Integer cost property value to a basic double before wrapping it in a
> Double object.
> 
> Here is the series of commands:
> 
> ===== SHELL
> 
> $ curl -i -HAccept:application/json -HContent-Type:application/json -X
> POST -d '{"name":"A"}' http://localhost:7474/db/data/node
> HTTP/1.1 201 Created
> Content-Length: 996
> Location: http://localhost:7474/db/data/node/73
> Content-Encoding: UTF-8
> Content-Type: application/json
> Access-Control-Allow-Origin: *
> Server: Jetty(6.1.25)
> 
> {
>  "outgoing_relationships" :
> "http://localhost:7474/db/data/node/73/relationships/out";,
>  "data" : {
>    "name" : "A"
>  },
>  "traverse" : "http://localhost:7474/db/data/node/73/traverse/{returnType}";,
>  "all_typed_relationships" :
> "http://localhost:7474/db/data/node/73/relationships/all/{-list|&|types}",
>  "property" : "http://localhost:7474/db/data/node/73/properties/{key}";,
>  "self" : "http://localhost:7474/db/data/node/73";,
>  "properties" : "http://localhost:7474/db/data/node/73/properties";,
>  "outgoing_typed_relationships" :
> "http://localhost:7474/db/data/node/73/relationships/out/{-list|&|types}",
>  "incoming_relationships" :
> "http://localhost:7474/db/data/node/73/relationships/in";,
>  "extensions" : {
>  },
>  "create_relationship" : 
> "http://localhost:7474/db/data/node/73/relationships";,
>  "all_relationships" :
> "http://localhost:7474/db/data/node/73/relationships/all";,
>  "incoming_typed_relationships" :
> "http://localhost:7474/db/data/node/73/relationships/in/{-list|&|types}"
> }
> 
> $ curl -i -HAccept:application/json -HContent-Type:application/json -X
> POST -d '{"name":"B"}' http://localhost:7474/db/data/node
> HTTP/1.1 201 Created
> Content-Length: 996
> Location: http://localhost:7474/db/data/node/74
> Content-Encoding: UTF-8
> Content-Type: application/json
> Access-Control-Allow-Origin: *
> Server: Jetty(6.1.25)
> 
> {
>  "outgoing_relationships" :
> "http://localhost:7474/db/data/node/74/relationships/out";,
>  "data" : {
>    "name" : "B"
>  },
>  "traverse" : "http://localhost:7474/db/data/node/74/traverse/{returnType}";,
>  "all_typed_relationships" :
> "http://localhost:7474/db/data/node/74/relationships/all/{-list|&|types}",
>  "property" : "http://localhost:7474/db/data/node/74/properties/{key}";,
>  "self" : "http://localhost:7474/db/data/node/74";,
>  "properties" : "http://localhost:7474/db/data/node/74/properties";,
>  "outgoing_typed_relationships" :
> "http://localhost:7474/db/data/node/74/relationships/out/{-list|&|types}",
>  "incoming_relationships" :
> "http://localhost:7474/db/data/node/74/relationships/in";,
>  "extensions" : {
>  },
>  "create_relationship" : 
> "http://localhost:7474/db/data/node/74/relationships";,
>  "all_relationships" :
> "http://localhost:7474/db/data/node/74/relationships/all";,
>  "incoming_typed_relationships" :
> "http://localhost:7474/db/data/node/74/relationships/in/{-list|&|types}"
> }
> 
> $ curl -i -HAccept:application/json -HContent-Type:application/json -X
> POST -d 
> '{"to":"http://localhost:7474/db/data/node/74","type":"GO","data":{"name":"AB","distance":2}}'
> http://localhost:7474/db/data/node/73/relationships
> HTTP/1.1 201 Created
> Content-Length: 421
> Location: http://localhost:7474/db/data/relationship/64
> Content-Encoding: UTF-8
> Content-Type: application/json
> Access-Control-Allow-Origin: *
> Server: Jetty(6.1.25)
> 
> {
>  "start" : "http://localhost:7474/db/data/node/73";,
>  "data" : {
>    "distance" : 2,
>    "name" : "AB"
>  },
>  "self" : "http://localhost:7474/db/data/relationship/64";,
>  "property" : 
> "http://localhost:7474/db/data/relationship/64/properties/{key}";,
>  "properties" : "http://localhost:7474/db/data/relationship/64/properties";,
>  "type" : "GO",
>  "extensions" : {
>  },
>  "end" : "http://localhost:7474/db/data/node/74";
> }
> 
> #####  This succeeds
> $ curl -i -HAccept:application/json -HContent-Type:application/json -X
> POST -d '{"to":"http://localhost:7474/db/data/node/74","type":"GO"}'
> http://localhost:7474/db/data/node/73/paths
> HTTP/1.1 200 OK
> Content-Length: 297
> Content-Encoding: UTF-8
> Content-Type: application/json
> Access-Control-Allow-Origin: *
> Server: Jetty(6.1.25)
> 
> [ {
>  "start" : "http://localhost:7474/db/data/node/73";,
>  "nodes" : [ "http://localhost:7474/db/data/node/73";,
> "http://localhost:7474/db/data/node/74"; ],
>  "length" : 1,
>  "relationships" : [ "http://localhost:7474/db/data/relationship/64"; ],
>  "end" : "http://localhost:7474/db/data/node/74";
> } ]
> 
> 
> ##### This fails
> $ curl -i -HAccept:application/json -HContent-Type:application/json -X
> POST -d 
> '{"to":"http://localhost:7474/db/data/node/74","type":"GO","algorithm":"dijkstra","cost
> property":"distance"}' http://localhost:7474/db/data/node/73/paths
> HTTP/1.1 400 Bad Request
> Content-Length: 4579
> Content-Encoding: UTF-8
> Content-Type: application/json
> Access-Control-Allow-Origin: *
> Server: Jetty(6.1.25)
> 
> {
>  "message" : "java.lang.Integer cannot be cast to java.lang.Double",
>  "exception" : "java.lang.ClassCastException: java.lang.Integer
> cannot be cast to java.lang.Double",
>  "stacktrace" : [
> "org.neo4j.graphalgo.impl.util.DoubleEvaluator.getCost(DoubleEvaluator.java:38)",
> "org.neo4j.graphalgo.impl.util.DoubleEvaluator.getCost(DoubleEvaluator.java:26)",
> "org.neo4j.graphalgo.impl.path.Dijkstra$SelectorFactory.calculateValue(Dijkstra.java:100)",
> "org.neo4j.graphalgo.impl.path.Dijkstra$SelectorFactory.calculateValue(Dijkstra.java:88)",
> "org.neo4j.graphalgo.impl.util.BestFirstSelectorFactory$BestFirstSelector.next(BestFirstSelectorFactory.java:66)",
> "org.neo4j.kernel.impl.traversal.TraverserImpl$TraverserIterator.fetchNextOrNull(TraverserImpl.java:127)",
> "org.neo4j.kernel.impl.traversal.TraverserImpl$TraverserIterator.fetchNextOrNull(TraverserImpl.java:94)",
> "org.neo4j.helpers.collection.PrefetchingIterator.hasNext(PrefetchingIterator.java:55)",
> "org.neo4j.graphalgo.impl.util.StopAfterWeightIterator.fetchNextOrNull(StopAfterWeightIterator.java:45)",
> "org.neo4j.graphalgo.impl.util.StopAfterWeightIterator.fetchNextOrNull(StopAfterWeightIterator.java:29)",
> "org.neo4j.helpers.collection.PrefetchingIterator.hasNext(PrefetchingIterator.java:55)",
> "org.neo4j.helpers.collection.IteratorWrapper.hasNext(IteratorWrapper.java:42)",
> "org.neo4j.server.rest.repr.ListRepresentation.serialize(ListRepresentation.java:58)",
> "org.neo4j.server.rest.repr.ListRepresentation.serialize(ListRepresentation.java:51)",
> "org.neo4j.server.rest.repr.OutputFormat.format(OutputFormat.java:118)",
> "org.neo4j.server.rest.repr.OutputFormat.response(OutputFormat.java:95)",
> "org.neo4j.server.rest.repr.OutputFormat.ok(OutputFormat.java:48)",
> "org.neo4j.server.rest.web.RestfulGraphDatabase.allPaths(RestfulGraphDatabase.java:987)",
> "sun.reflect.GeneratedMethodAccessor153.invoke(Unknown Source)",
> "sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)",
> "java.lang.reflect.Method.invoke(Method.java:597)",
> "com.sun.jersey.server.impl.model.method.dispatch.AbstractResourceMethodDispatchProvider$ResponseOutInvoker._dispatch(AbstractResourceMethodDispatchProvider.java:184)",
> "com.sun.jersey.server.impl.model.method.dispatch.ResourceJavaMethodDispatcher.dispatch(ResourceJavaMethodDispatcher.java:67)",
> "com.sun.jersey.server.impl.uri.rules.HttpMethodRule.accept(HttpMethodRule.java:276)",
> "com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:133)",
> "com.sun.jersey.server.impl.uri.rules.ResourceClassRule.accept(ResourceClassRule.java:83)",
> "com.sun.jersey.server.impl.uri.rules.RightHandPathRule.accept(RightHandPathRule.java:133)",
> "com.sun.jersey.server.impl.uri.rules.RootResourceClassesRule.accept(RootResourceClassesRule.java:71)",
> "com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1171)",
> "com.sun.jersey.server.impl.application.WebApplicationImpl._handleRequest(WebApplicationImpl.java:1103)",
> "com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1053)",
> "com.sun.jersey.server.impl.application.WebApplicationImpl.handleRequest(WebApplicationImpl.java:1043)",
> "com.sun.jersey.spi.container.servlet.WebComponent.service(WebComponent.java:406)",
> "com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:477)",
> "com.sun.jersey.spi.container.servlet.ServletContainer.service(ServletContainer.java:662)",
> "javax.servlet.http.HttpServlet.service(HttpServlet.java:820)",
> "org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)",
> "org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:390)",
> "org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)",
> "org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:765)",
> "org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114)",
> "org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)",
> "org.mortbay.jetty.Server.handle(Server.java:326)",
> "org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)",
> "org.mortbay.jetty.HttpConnection$RequestHandler.content(HttpConnection.java:943)",
> "org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:756)",
> "org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:218)",
> "org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)",
> "org.mortbay.jetty.bio.SocketConnector$Connection.run(SocketConnector.java:228)",
> "org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)"
> ]
> }
> 
> ===== END SHELL
> 
> Thanks for any help you can provide.
> 
> -- Josh
> _______________________________________________
> Neo4j mailing list
> [email protected]
> https://lists.neo4j.org/mailman/listinfo/user

_______________________________________________
Neo4j mailing list
[email protected]
https://lists.neo4j.org/mailman/listinfo/user

Reply via email to