在django中测试交错的长时间运行请求

时间:2011-05-21 00:59:30

标签: django multithreading unit-testing

我正在尝试为可能需要很长时间处理的django请求编写测试,因此可能会与其他请求交错。我的计划是发出一个长期运行的请求,并将断言注入可能暂停的地方。

但是在我的单元测试中尝试使用线程似乎效果不好:

class ThreadTest(test.TestCase):
    def thread_test(self):
        def printer():
            print models.Daemon.objects.count()

        d = models.Daemon(url='http://lockss.notadomain:8088')
        d.save()
        printer()
        t = threading.Thread(target=printer)
        t.start()
        t.join()

printer()调用的工作方式与我第一次的预期相同,但是当从Thread调用时无法找到该表:

1
Exception in thread Thread-1:
Traceback (most recent call last):
  File "/usr/lib/python2.6/threading.py", line 532, in __bootstrap_inner
    self.run()
  File "/usr/lib/python2.6/threading.py", line 484, in run
    self.__target(*self.__args, **self.__kwargs)
  File "/home/bhayes/lockss-code/hare/lockss-django/autest/tests.py", line 247, in printer
    print models.Daemon.objects.count()
  File "/usr/lib/pymodules/python2.6/django/db/models/manager.py", line 120, in count
    return self.get_query_set().count()
  File "/usr/lib/pymodules/python2.6/django/db/models/query.py", line 326, in count
    return self.query.get_count(using=self.db)
  File "/usr/lib/pymodules/python2.6/django/db/models/sql/query.py", line 394, in get_count
    number = obj.get_aggregation(using=using)[None]
  File "/usr/lib/pymodules/python2.6/django/db/models/sql/query.py", line 366, in get_aggregation
    result = query.get_compiler(using).execute_sql(SINGLE)
  File "/usr/lib/pymodules/python2.6/django/db/models/sql/compiler.py", line 727, in execute_sql
    cursor.execute(sql, params)
  File "/usr/lib/pymodules/python2.6/django/db/backends/sqlite3/base.py", line 200, in execute
    return Database.Cursor.execute(self, query, params)
DatabaseError: no such table: autest_daemon

我想了解发生了什么。另外,我想知道是否有更好的策略来测试并行请求。

2 个答案:

答案 0 :(得分:1)

你不能在Django的内存数据库(在本例中为sqlite3)中使用线程,请参阅此bug。您的测试可能适用于PostgreSQL或MySQL。

答案 1 :(得分:1)

正如罗布所说,当问到这个问题时,SQLite无法做到这一点。但是,从Django 1.8开始(见https://docs.djangoproject.com/en/1.8/topics/testing/overview/):

  

如果使用带有Python 3.4+和SQLite 3.7.13+的SQLite内存数据库,将启用共享缓存,因此您可以编写能够在线程之间共享数据库的测试。

因此,如果你有升级选项,它应该可以工作。