gpt4 book ai didi

ruby-on-rails - 抑制 Rails 模式加载

转载 作者:行者123 更新时间:2023-12-03 11:12:52 26 4
gpt4 key购买 nike

我写了一个multi-tenancy gem用于 Rails。

当我创建一个新租户时,我加载了 schema.rb 文件。这工作正常,除了每次我这样做时,我都会收到大量日志消息:

-- create_table("users", {:force=>true})
NOTICE: CREATE TABLE will create implicit sequence "users_id_seq" for serial column "users.id"
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "users_pkey" for table "users"
-> 0.0102s
-- add_index("users", ["email"], {:name=>"index_users_on_email", :unique=>true})
-> 0.0035s
-- add_index("users", ["reset_password_token"], {:name=>"index_users_on_reset_password_token", :unique=>true})
-> 0.0040s

等等等等...加载schema.rb 文件的所有典型。我的问题是在测试期间看到这个很烦人。我真的不想看到这个,它混淆了我的测试输出,让我更难调试和验证测试等...

有谁知道我可以将此输出静音的方法吗?我在我的 gem 中尝试了以下内容:

Rails.logger.silence{ load("#{Rails.root}/db/seeds.rb") }

但这并没有改变任何事情。有谁知道配置选项或其他一些方法可以使模式加载的输出静音?

最佳答案

经过一些挖掘,这是我学到的东西。

您可以通过执行以下操作使日志静音:

silence_stream(STDOUT) do
load "#{Rails.root}/db/schema.rb"
end

silence_stream是一个内核方法,所以你应该能够调用它,它会杀死 STDOUT,这是输出被记录到的地方。所以以上对我有用。

如果您使用的是 Spork,这将不起作用

因此对于 Spork,您通常会在每次运行时将 schema.rb 加载到内存中。不幸的是,Spork 甚至在 silence_stream 包装器之前就获得了输出,并将输出推送通过。我在阅读 a Ruby Inside article 时发现了这一点这解释了这一点。这篇文章令人困惑,因为他将代码留在那里,尽管它对 Spork 没有任何作用。

关于ruby-on-rails - 抑制 Rails 模式加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7364164/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com