This is your first challenge of this course. Your challenge here is to modify the code to create a new instance of the Driver that can be used across the application.
As we discussed in the About the Driver lesson, it is best practice to create a single instance of the driver in our application per Neo4j cluster or DBMS.
Inside api/neo4j.py
, you will see an init_driver()
function.
Open api/neo4j.py
def init_driver(uri, username, password):
# TODO: Create an instance of the driver here
current_app.driver = None
return None
This function should use the uri
, username
and password
parameters supplied to create an instance of the Neo4j Python Driver.
The driver instance should then be assigned to the current_app
variable to ensure that it is available throughout the application.
The get_driver()
function also included in neo4j.py
will provide access to the driver variable set in the init_driver()
above.
def get_driver():
return current_app.driver
Challenge: Implement the init_driver function.
Your first challenge is to modify the init_driver()
function in api/neo4j.py
to create an instance of the driver and assign it to the driver
variable declared above.
To do this, we will need to:
-
Install the
neo4j
dependency using pip. -
Import the
GraphDatabase
object fromneo4j
intoneo4j.py
. -
Create the driver instance with the
uri
,username
andpassword
parameters passed to the function and use theverify_connectivity()
method to assert that the credentials are correct.
Open api/neo4j.py
1. Install the neo4j
Dependency
First, you will need to install the neo4j
dependency.
Run the following command in your terminal session:
pip install neo4j
2. Importing the Dependency
To include the Driver dependency in our module, you will add an import
command to the top of the file.
Copy and paste the following code at the top of api/neo4j.py
.
# Import the neo4j dependency
from neo4j import GraphDatabase
3. Creating the Driver Instance
Create the driver instance by calling the GraphDatabase.driver()
function.
The first argument will be the uri
passed as the first parameter to the function.
The function will also require a named auth
argument with the tuple: (username, password)
Replace the init_driver
placeholder function with the following code:
def init_driver(uri, username, password):
# Create an instance of the driver
current_app.driver = GraphDatabase.driver(uri, auth=(username, password))
# Verify Connectivity
current_app.driver.verify_connectivity()
return current_app.driver
The function calls the verify_connectivity()
function on the driver instance to verify that the connection details are correct before returning the newly created driver instance.
If the connection cannot be made for any reason, an Exception will be thrown. If this occurs, your application will be unable to communicate with Neo4j. Manual investigation will be required to diagnose the issue.
If the connection has been successfully verified, the function will return an instance of the driver.
Testing
To test that this functionality has been correctly implemented, run the following code in a new terminal session:
pytest tests/01_connect_to_neo4j__test.py
The test file is located at tests/01_connect_to_neo4j__test.py
.
Are you stuck? Click here for help
If you get stuck, you can see a working solution by checking out the 01-connect-to-neo4j
branch by running:
git checkout 01-connect-to-neo4j
You may have to commit or stash your changes before checking out this branch. You can also click here to expand the Support pane.
Check Your Understanding
How many tests are collected and run by the pytest command?
-
❏ 1
-
❏ 2
-
❏ 3
-
✓ 4
Hint
You can run the tests/01_connect_to_neo4j__test.py
test by running the following command:
pytest tests/{test-filename}.py
Solution
There are 4 tests in the test suite.
Lesson Summary
You have implemented the code to create a new driver instance with environment variables read from the .env
file.
The test also verifies that the driver can connect to the DBMS before the application starts.
The Neoflix API will now be able to read data from and write data to your Neo4j Sandbox instance.
In the next module we will look at how to use the driver to query the DBMS.