Python Django中使用selenium的通道测试引发错误消息

Python Django中使用selenium的通道测试引发错误消息,python,django,websocket,selenium-chromedriver,django-channels,Python,Django,Websocket,Selenium Chromedriver,Django Channels,我将跟随Django尝试频道。我正在使用Windows10Home、Django2.1.4和Python3.7.1 本教程的目标是构建一个聊天应用程序 下载chromeDriver并将其添加到路径中后,我在提示符下运行以下命令: py manage.py test chat.tests 将返回此错误消息: EETraceback (most recent call last): File "<string>", line 1, in <module> File

我将跟随Django尝试频道。我正在使用Windows10Home、Django2.1.4和Python3.7.1

本教程的目标是构建一个聊天应用程序

下载chromeDriver并将其添加到路径中后,我在提示符下运行以下命令:

py manage.py test chat.tests
将返回此错误消息:

EETraceback (most recent call last):
  File "<string>", line 1, in <module>
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py", line 105, in spawn_main
    exitcode = _main(fd)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py", line 115, in _main
    self = reduction.pickle.load(from_parent)
EOFError: Ran out of input
Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py", line 105, in spawn_main
    exitcode = _main(fd)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py", line 115, in _main
    self = reduction.pickle.load(from_parent)
EOFError: Ran out of input

======================================================================
ERROR: test_when_chat_message_posted_then_not_seen_by_anyone_in_different_room (chat.tests.ChatTests)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\test\testcases.py", line 202, in __call__
    self._pre_setup()
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\channels\testing\live.py", line 52, in _pre_setup
    self._server_process.start()
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\process.py", line 112, in start
    self._popen = self._Popen(self)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\context.py", line 223, in _Popen
    return _default_context.get_context().Process._Popen(process_obj)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\context.py", line 322, in _Popen
    return Popen(process_obj)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\popen_spawn_win32.py", line 65, in __init__
    reduction.dump(process_obj, to_child)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\reduction.py", line 61, in dump
    ForkingPickler(file, protocol).dump(obj)
AttributeError: Can't pickle local object 'DaphneProcess.__init__.<locals>.<lambda>'

======================================================================
ERROR: test_when_chat_message_posted_then_seen_by_everyone_in_same_room (chat.tests.ChatTests)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\test\testcases.py", line 202, in __call__
    self._pre_setup()
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\channels\testing\live.py", line 52, in _pre_setup
    self._server_process.start()
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\process.py", line 112, in start
    self._popen = self._Popen(self)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\context.py", line 223, in _Popen
    return _default_context.get_context().Process._Popen(process_obj)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\context.py", line 322, in _Popen
    return Popen(process_obj)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\popen_spawn_win32.py", line 65, in __init__
    reduction.dump(process_obj, to_child)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\reduction.py", line 61, in dump
    ForkingPickler(file, protocol).dump(obj)
AttributeError: Can't pickle local object 'DaphneProcess.__init__.<locals>.<lambda>'

----------------------------------------------------------------------
Ran 0 tests in 4.689s

FAILED (errors=2)
Destroying test database for alias 'default'...
EETraceback(最近一次呼叫最后一次):
文件“”,第1行,在
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\spawn.py”,第105行,在spawn\u main中
出口代码=_主(fd)
文件“c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py”,第115行,在主目录中
self=reduce.pickle.load(从父级)
EOFError:输入不足
回溯(最近一次呼叫最后一次):
文件“”,第1行,在
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\spawn.py”,第105行,在spawn\u main中
出口代码=_主(fd)
文件“c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py”,第115行,在主目录中
self=reduce.pickle.load(从父级)
EOFError:输入不足
======================================================================
错误:当聊天时测试消息发布后,其他房间中的任何人都看不到(chat.tests.ChatTests)
----------------------------------------------------------------------
回溯(最近一次呼叫最后一次):
文件“C:\Users\kevin\Envs\myproject\lib\site packages\django\test\testcases.py”,第202行,在调用中__
self._pre_setup()
文件“C:\Users\kevin\Envs\myproject\lib\site packages\channels\testing\live.py”,第52行,在\u pre\u设置中
self.\u server\u process.start()
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\process.py”,第112行,在开始处
self.\u popen=self.\u popen(self)
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\context.py”,第223行,在
返回_default_context.get_context().Process._Popen(Process_obj)
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\context.py”,第322行,在
返回Popen(过程对象)
文件“c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\popen\u spawn\u win32.py”,第65行,在\uuu init中__
减少.转储(进程对象,到子进程)
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\reduce.py”,第61行,位于转储文件中
ForkingPickler(文件、协议).dump(obj)
AttributeError:无法pickle本地对象“DaphneProcess.\uu init\uu..”
======================================================================
错误:当聊天时测试消息发布后,每个人在同一个房间看到(chat.tests.chattsts)
----------------------------------------------------------------------
回溯(最近一次呼叫最后一次):
文件“C:\Users\kevin\Envs\myproject\lib\site packages\django\test\testcases.py”,第202行,在调用中__
self._pre_setup()
文件“C:\Users\kevin\Envs\myproject\lib\site packages\channels\testing\live.py”,第52行,在\u pre\u设置中
self.\u server\u process.start()
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\process.py”,第112行,在开始处
self.\u popen=self.\u popen(self)
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\context.py”,第223行,在
返回_default_context.get_context().Process._Popen(Process_obj)
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\context.py”,第322行,在
返回Popen(过程对象)
文件“c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\popen\u spawn\u win32.py”,第65行,在\uuu init中__
减少.转储(进程对象,到子进程)
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\reduce.py”,第61行,位于转储文件中
ForkingPickler(文件、协议).dump(obj)
AttributeError:无法pickle本地对象“DaphneProcess.\uu init\uu..”
----------------------------------------------------------------------
在4.689秒内运行了0个测试
失败(错误=2)
正在销毁别名“default”的测试数据库。。。
同样的问题()提供了一个解决方案,但它对我不起作用

当我修改文件reduce.py以将导入pickle替换为导入dill as pickle时,我收到以下新消息错误:

DevTools listening on ws://127.0.0.1:25037/devtools/browser/b4c722e4-c7f2-49fb-939b-7372e9688eea
C:\Users\kevin\Envs\myproject\lib\site-packages\daphne\server.py:13: UserWarning: Something has already installed a non-asyncio Twisted reactor. Attempting to uninstall it; you can fix this warning by importing daphne.server early in your codebase or finding the package that imports Twisted and importing it later on.
  UserWarning,
Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py", line 105, in spawn_main
    exitcode = _main(fd)
  File "c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py", line 115, in _main
    self = reduction.pickle.load(from_parent)
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\dill\_dill.py", line 304, in load
    obj = pik.load()
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\dill\_dill.py", line 465, in find_class
    return StockUnpickler.find_class(self, module, name)
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\channels\auth.py", line 12, in <module>
    from django.contrib.auth.models import AnonymousUser
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\contrib\auth\models.py", line 2, in <module>
    from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\contrib\auth\base_user.py", line 47, in <module>
    class AbstractBaseUser(models.Model):
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\db\models\base.py", line 87, in __new__
    app_config = apps.get_containing_app_config(module)
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\apps\registry.py", line 249, in get_containing_app_config
    self.check_apps_ready()
  File "C:\Users\kevin\Envs\myproject\lib\site-packages\django\apps\registry.py", line 132, in check_apps_ready
    raise AppRegistryNotReady("Apps aren't loaded yet.")
django.core.exceptions.AppRegistryNotReady: Apps aren't loaded yet.
DevTools在ws://127.0.0.1:25037/DevTools/browser/b4c722e4-c7f2-49fb-939b-7372e9688eea上侦听
C:\Users\kevin\Envs\myproject\lib\site packages\daphne\server.py:13:UserWarning:Something已经安装了非异步Twisted reactor。试图卸载它;您可以通过在代码库的早期导入daphne.server或查找导入Twisted的包并稍后导入来修复此警告。
用户警告,
回溯(最近一次呼叫最后一次):
文件“”,第1行,在
文件“c:\users\kevin\appdata\local\programs\python37-32\Lib\multiprocessing\spawn.py”,第105行,在spawn\u main中
出口代码=_主(fd)
文件“c:\users\kevin\appdata\local\programs\python\python37-32\Lib\multiprocessing\spawn.py”,第115行,在主目录中
self=reduce.pickle.load(从父级)
文件“C:\Users\kevin\Envs\myproject\lib\site packages\dill\\u dill.py”,第304行,已加载
obj=pik.load()
文件“C:\Users\kevin\Envs\myproject\lib\site packages\dill\\u dill.py”,第465行,在find\u类中
返回StockUnpickler.find_类(self、module、name)
文件“C:\Users\kevin\Envs\myproject\lib\site packages\channels\auth.py”,第12行,在
从django.contrib.auth.models导入匿名用户
文件“C:\Users\kevin\Envs\myproject\lib\site packages\django\contrib\auth\models.py”,第2行,在
从django.contrib.auth.base_user导入AbstractBaseUser、BaseUserManager
文件“C:\Users\kevin\Envs\myproject\lib\site packages\django\contrib\auth\base\u user.py”,第47行,在
类AbstractBaseUser(models.Model):
文件“C:\Users\kevin