有趣的问题我得到了。我有一个使用arc-ecto处理文件上传的测试。在上传器模块中,我重写了storage_dir
功能。我在那里进行数据库调用,以获取我上传的东西的父记录的ID。在实践中很有效。
虽然测试很吓人。我猜它与文件保存是异步任务这一事实有关。因此,在保存文件之前完成测试。数据库连接已关闭,上传器错误消失。这是错误:
15:33:10.457 [error] Postgrex.Protocol (#PID<0.325.0>) disconnected: ** (DBConnection.ConnectionError) owner #PID<0.535.0> exited while client #PID<0.538.0> is still running with: shutdown
15:33:10.645 [error] Postgrex.Protocol (#PID<0.331.0>) disconnected: ** (DBConnection.ConnectionError) owner #PID<0.596.0> exited while client #PID<0.599.0> is still running with: shutdown
15:33:10.674 [error] Task #PID<0.599.0> started from #PID<0.598.0> terminating
** (DBConnection.ConnectionError) tcp recv: closed
(ecto) lib/ecto/adapters/postgres/connection.ex:115: Ecto.Adapters.Postgres.Connection.execute/4
(ecto) lib/ecto/adapters/sql.ex:243: Ecto.Adapters.SQL.sql_call/6
(ecto) lib/ecto/adapters/sql.ex:441: Ecto.Adapters.SQL.execute_or_reset/7
(ecto) lib/ecto/repo/queryable.ex:130: Ecto.Repo.Queryable.execute/5
(ecto) lib/ecto/repo/queryable.ex:35: Ecto.Repo.Queryable.all/4
(ecto) lib/ecto/repo/queryable.ex:68: Ecto.Repo.Queryable.one/4
(pedal_app) lib/pedal_app/web/uploaders/photo_uploader.ex:31: PedalApp.Web.PhotoUploader.storage_dir/2
lib/arc/storage/local.ex:33: Arc.Storage.Local.build_local_path/3
lib/arc/storage/local.ex:27: Arc.Storage.Local.delete/3
(elixir) lib/task/supervised.ex:85: Task.Supervised.do_apply/2
(elixir) lib/task/supervised.ex:36: Task.Supervised.reply/5
(stdlib) proc_lib.erl:247: :proc_lib.init_p_do_apply/3
Function: #Function<0.51838860/0 in Arc.Actions.Delete.async_delete_version/3>
Args: []
这是常见的事吗?在完成所有工作之前,我怎能告诉我的测试不要保释?
编辑:我的解决方法是对所有内容进行预加载,这样我就不会在上传程序中执行db调用。但问题仍然存在。
答案 0 :(得分:0)
您可以禁用将@async false
添加到您的上传定义中的异步处理。
我确定您不希望仅在测试中在开发/生产中禁用它。
我会尝试:
在config/test.exs
上,您可以添加:
config :project_name, arc_async: false
在您的上传者定义中,您可以添加:
@async Application.get_env(:project_name, :arc_async, true)
我没有测试它,所以不确定它是否可以工作,但至少可以尝试一下。