From 05b400dc6af5cfc35e1bf84134814bf4cdc1f235 Mon Sep 17 00:00:00 2001 From: Ali Ince Date: Wed, 8 May 2019 16:28:28 +0100 Subject: [PATCH] Enable neo4j scheme --- neo4j/driver.go | 7 ++++--- neo4j/driver_test.go | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 38 insertions(+), 3 deletions(-) diff --git a/neo4j/driver.go b/neo4j/driver.go index 8a1a46b2..81ce9a9a 100644 --- a/neo4j/driver.go +++ b/neo4j/driver.go @@ -52,8 +52,9 @@ type Driver interface { // In order to connect to a single instance database, you need to pass a URI with scheme 'bolt' // driver, err = NewDriver("bolt://db.server:7687", BasicAuth(username, password)) // -// In order to connect to a causal cluster database, you need to pass a URI with scheme 'bolt+routing' and its host -// part set to be one of the core cluster members. +// In order to connect to a causal cluster database, you need to pass a URI with scheme 'bolt+routing' or 'neo4j' +// and its host part set to be one of the core cluster members. Please note that 'bolt+routing' scheme will be +// removed with 2.0 series of drivers. // driver, err = NewDriver("bolt+routing://core.db.server:7687", BasicAuth(username, password)) // // You can override default configuration options by providing a configuration function(s) @@ -66,7 +67,7 @@ func NewDriver(target string, auth AuthToken, configurers ...func(*Config)) (Dri return nil, err } - if parsed.Scheme != "bolt" && parsed.Scheme != "bolt+routing" { + if parsed.Scheme != "bolt" && parsed.Scheme != "bolt+routing" && parsed.Scheme != "neo4j" { return nil, newDriverError("url scheme %s is not supported", parsed.Scheme) } diff --git a/neo4j/driver_test.go b/neo4j/driver_test.go index c5e02273..ec2e3705 100644 --- a/neo4j/driver_test.go +++ b/neo4j/driver_test.go @@ -20,6 +20,7 @@ package neo4j import ( + . "github.com/neo4j/neo4j-go-driver/neo4j/utils/test" . "github.com/onsi/ginkgo" . "github.com/onsi/ginkgo/extensions/table" . "github.com/onsi/gomega" @@ -27,6 +28,39 @@ import ( var _ = Describe("Driver", func() { + Context("URI", func() { + It("should support bolt:// scheme", func() { + driver, err := NewDriver("bolt://localhost:7687", NoAuth()) + + Expect(err).To(BeNil()) + Expect(driver).NotTo(BeNil()) + Expect(driver.Target().Scheme).To(BeIdenticalTo("bolt")) + }) + + It("should support bolt+routing:// scheme", func() { + driver, err := NewDriver("bolt+routing://localhost:7687", NoAuth()) + + Expect(err).To(BeNil()) + Expect(driver).NotTo(BeNil()) + Expect(driver.Target().Scheme).To(BeIdenticalTo("bolt+routing")) + }) + + It("should support neo4j:// scheme", func() { + driver, err := NewDriver("neo4j://localhost:7687", NoAuth()) + + Expect(err).To(BeNil()) + Expect(driver).NotTo(BeNil()) + Expect(driver.Target().Scheme).To(BeIdenticalTo("neo4j")) + }) + + It("should error anotherscheme:// scheme", func() { + driver, err := NewDriver("anotherscheme://localhost:7687", NoAuth()) + + Expect(driver).To(BeNil()) + Expect(err).To(BeGenericError(ContainSubstring("url scheme anotherscheme is not supported"))) + }) + }) + When("constructed with bolt://localhost:7687", func() { driver, err := NewDriver("bolt://localhost:7687", NoAuth())