70 lines
2.2 KiB
Python
70 lines
2.2 KiB
Python
|
#!/usr/bin/env python3
|
||
|
# -*- coding: utf-8 -*-
|
||
|
|
||
|
# Copyright 2021 Memgraph Ltd.
|
||
|
#
|
||
|
# Use of this software is governed by the Business Source License
|
||
|
# included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
||
|
# License, and you may not use this file except in compliance with the Business Source License.
|
||
|
#
|
||
|
# As of the Change Date specified in that file, in accordance with
|
||
|
# the Business Source License, use of this software will be governed
|
||
|
# by the Apache License, Version 2.0, included in the file
|
||
|
# licenses/APL.txt.
|
||
|
|
||
|
from neo4j import GraphDatabase, basic_auth
|
||
|
from neo4j.exceptions import ClientError, TransientError
|
||
|
|
||
|
|
||
|
def tx_error(tx, name, name2):
|
||
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name).value()
|
||
|
print(a[0])
|
||
|
tx.run("CREATE (").consume()
|
||
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name2).value()
|
||
|
print(a[0])
|
||
|
|
||
|
|
||
|
def tx_good(tx, name, name2):
|
||
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name).value()
|
||
|
print(a[0])
|
||
|
a = tx.run("CREATE (a:Person {name: $name}) RETURN a", name=name2).value()
|
||
|
print(a[0])
|
||
|
|
||
|
|
||
|
def tx_too_long(tx):
|
||
|
tx.run("MATCH (a), (b), (c), (d), (e), (f) RETURN COUNT(*) AS cnt")
|
||
|
|
||
|
|
||
|
with GraphDatabase.driver("bolt://localhost:7687", auth=None, encrypted=False) as driver:
|
||
|
|
||
|
def add_person(f, name, name2):
|
||
|
with driver.session() as session:
|
||
|
session.write_transaction(f, name, name2)
|
||
|
|
||
|
# Wrong query.
|
||
|
try:
|
||
|
add_person(tx_error, "mirko", "slavko")
|
||
|
except ClientError:
|
||
|
pass
|
||
|
# Correct query.
|
||
|
add_person(tx_good, "mirka", "slavka")
|
||
|
|
||
|
# Setup for next query.
|
||
|
with driver.session() as session:
|
||
|
session.run("UNWIND range(1, 100000) AS x CREATE ()").consume()
|
||
|
|
||
|
# Query that will run for a very long time, transient error expected.
|
||
|
timed_out = False
|
||
|
try:
|
||
|
with driver.session() as session:
|
||
|
session.run("MATCH (a), (b), (c), (d), (e), (f) RETURN COUNT(*) AS cnt").consume()
|
||
|
except TransientError:
|
||
|
timed_out = True
|
||
|
|
||
|
if timed_out:
|
||
|
print("The query timed out as was expected.")
|
||
|
else:
|
||
|
raise Exception("The query should have timed out, but it didn't!")
|
||
|
|
||
|
print("All ok!")
|