我在Python/ArangoDB后端使用arango-orm(在后台使用python-arango)。我已经建立了一个小的测试util,它使用远程数据库插入测试数据,执行单元测试并再次删除测试数据。
我使用Python for循环插入测试数据。每次迭代,一小段信息都会根据一个泛型对象进行更改,然后我将修改后的泛型对象插入ArangoDB,直到我有10个测试对象。然而,在代码运行之后,我的测试断言告诉我,我的数据库中没有存储10个对象,只有8个(有时是3、7或9个)。看起来pythong-arango
以异步方式运行这些查询,或者ArangoDB
在实际插入数据之前已经用OK进行了回复。有人知道发生了什么吗?当我在插入所有数据后进入睡眠1秒钟时,我的测试运行绿色。这显然不是解决办法
这是我使用的一小段示例代码:
def load_test_data(self) -> None:
# This method is called from the setUp() method.
logging.info("Loading test data...")
for i in range(1, 11):
# insertion with data object (ORM)
user = test_utils.get_default_test_user()
user.id = i
user.username += str(i)
user.name += str(i)
db.add(user)
# insertion with dictionary
project = test_utils.get_default_test_project()
project['id'] = i
project['name'] += str(i)
project['description'] = f"Description for project with the id {i}"
db.insert_document("projects", project)
# TODO: solve this dirty hack
sleep(1)
def test_search_by_user_username(self) -> None:
actual = dao.search("TestUser3")
self.assertEqual(1, len(actual))
self.assertEqual(3, actual[0].id)
然后在单独的模块中创建my db,如下所示:
client = ArangoClient(hosts=f"http://{arango_host}:{arango_port}")
test_db = client.db(arango_db, arango_user, arango_password)
db = Database(test_db)
编辑:
在创建集合时,我没有将sync
属性设置为true
,但是在更改集合并将其设置为true
之后,行为保持完全相同
在与ArangoDB的人取得联系后,我了解到视图的更新速度不如集合快。您给了我一个内部
SEARCH option
,它也在等待同步视图。由于它是一个内部选项,仅用于单元测试,因此他们强烈反对使用它。对我来说,我只把它用于单元测试相关问题 更多 >
编程相关推荐