2018-08-01 16:10:52 +08:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2017-06-20 21:01:11 +08:00
|
|
|
import database
|
|
|
|
import os
|
2018-08-01 16:10:52 +08:00
|
|
|
from behave import given
|
2017-06-20 21:01:11 +08:00
|
|
|
|
|
|
|
|
|
|
|
def clear_graph(context):
|
|
|
|
database.query("MATCH (n) DETACH DELETE n", context)
|
2018-08-01 16:10:52 +08:00
|
|
|
if context.exception is not None:
|
2017-06-20 21:01:11 +08:00
|
|
|
context.exception = None
|
|
|
|
database.query("MATCH (n) DETACH DELETE n", context)
|
|
|
|
|
|
|
|
|
|
|
|
@given('an empty graph')
|
|
|
|
def empty_graph_step(context):
|
|
|
|
clear_graph(context)
|
|
|
|
|
|
|
|
|
|
|
|
@given('any graph')
|
|
|
|
def any_graph_step(context):
|
|
|
|
clear_graph(context)
|
|
|
|
|
|
|
|
|
|
|
|
@given('graph "{name}"')
|
|
|
|
def graph_name(context, name):
|
|
|
|
create_graph(name, context)
|
|
|
|
|
|
|
|
|
|
|
|
def create_graph(name, context):
|
|
|
|
"""
|
|
|
|
Function deletes everything from database and creates a new
|
|
|
|
graph. Graph file name is an argument of function. Function
|
|
|
|
executes queries written in a .cypher file separated by ';'
|
|
|
|
and sets graph properties to beginning values.
|
|
|
|
"""
|
|
|
|
clear_graph(context)
|
2018-11-08 23:51:56 +08:00
|
|
|
path = os.path.join(context.config.test_directory, "graphs",
|
|
|
|
name + ".cypher")
|
2017-06-20 21:01:11 +08:00
|
|
|
|
|
|
|
q_marks = ["'", '"', '`']
|
|
|
|
|
|
|
|
with open(path, 'r') as f:
|
|
|
|
content = f.read().replace('\n', ' ')
|
2017-12-05 23:23:12 +08:00
|
|
|
single_query = ''
|
|
|
|
quote = None
|
2017-06-20 21:01:11 +08:00
|
|
|
i = 0
|
|
|
|
while i < len(content):
|
|
|
|
ch = content[i]
|
2018-08-01 16:10:52 +08:00
|
|
|
if ch == '\\' and i != len(content) - 1 and \
|
|
|
|
content[i + 1] in q_marks:
|
2017-12-05 23:23:12 +08:00
|
|
|
single_query += ch + content[i + 1]
|
2017-06-20 21:01:11 +08:00
|
|
|
i += 2
|
|
|
|
else:
|
2017-12-05 23:23:12 +08:00
|
|
|
single_query += ch
|
|
|
|
if quote == ch:
|
|
|
|
quote = None
|
|
|
|
elif ch in q_marks and quote is None:
|
|
|
|
quote = ch
|
|
|
|
if ch == ';' and quote is None:
|
|
|
|
database.query(single_query, context)
|
|
|
|
single_query = ''
|
2017-06-20 21:01:11 +08:00
|
|
|
i += 1
|
2017-12-05 23:23:12 +08:00
|
|
|
if single_query.strip() != '':
|
|
|
|
database.query(single_query, context)
|