pytorch/caffe2/python/db_test.py
Andrew Tulloch 1e4b4fb4c4 Fix db_test under tsan
Summary:
It looks like there's some locking going on here, and so if
the Cursor outlives the DB (or vice-versa), we'll either deadlock or
unlock an unlocked mutex.

Reviewed By: dzhulgakov

Differential Revision: D4224727

fbshipit-source-id: 886401a9f2824f3168fb0b2fd4df6046369e5590
2016-11-29 15:18:37 -08:00

42 lines
1.1 KiB
Python

from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals
from caffe2.python import workspace
import os
import tempfile
import unittest
class TestDB(unittest.TestCase):
def setUp(self):
handle, self.file_name = tempfile.mkstemp()
os.close(handle)
self.data = [("key{}".format(i), "value{}".format(i))
for i in range(1, 10)]
def testSimple(self):
db = workspace.C.create_db(
"minidb", self.file_name, workspace.C.Mode.write)
for key, value in self.data:
transaction = db.new_transaction()
transaction.put(key, value)
del transaction
del db # should close DB
db = workspace.C.create_db(
"minidb", self.file_name, workspace.C.Mode.read)
cursor = db.new_cursor()
data = []
while cursor.valid():
data.append((cursor.key(), cursor.value()))
cursor.next()
del cursor
db.close() # test explicit db closer
self.assertEqual(data, self.data)