我正在尝试为 ohai 编写一个插件。这似乎是一个非常简单的任务:
Ohai.plugin(:Uname) do
provides 'uname'
depends 'kernel'
collect_data do
uname Mash.new
uname[:message] = `uname -a`
end
end
对我来说,这看起来像是 Opscode、O'Reilly 和其他人提供的在线示例。但是当我尝试测试它时会发生以下情况:
% irb -rohai
irb(main):001:0> Ohai::Config[:plugin_path] << "."
=> ["/home/ll0359/.rbenv/versions/2.2.1/lib/ruby/gems/2.2.0/gems/ohai-8.3.0/lib/ohai/plugins", "."]
irb(main):002:0> o = Ohai::System.new
=> #<Ohai::System:0x007fed82e43078 @plugin_path="", @data={}, @provides_map=#<Ohai::ProvidesMap:0x007fed82e42fd8 @map={}>, @v6_dependency_solver={}, @d82e42f38 @controller=#<Ohai::System:0x007fed82e43078 ...>, @v6_plugin_classes=[], @v7_plugin_classes=[]>, @runner=#<Ohai::Runner:0x007fed82e42ec0 @prp:0x007fed82e42fd8 @map={}>, @safe_run=true>>
irb(main):003:0> o.all_plugins
这就是乐趣开始的地方。我一遍又一遍地得到这个输出:
[2015-05-20T03:13:09+00:00] WARN: Plugin Definition Error: <./ohai_uname.rb>: collect_data already defined on platform default
[2015-05-20T03:13:09+00:00] WARN: [DEPRECATION] Plugin at ./test_ohai.rb is a version 6 plugin. Version 6 plugins will not be supported in future releases....
your plugin to version 7 plugin syntax. For more information visit here: docs.chef.io/ohai_custom.html
(我第二行的文字被我的屏幕剪掉了,但你明白了)
我试过在有和没有'depends'行的情况下运行这段代码。结果相同。
我试过在有和没有 Mash 行的情况下运行这段代码,用 'uname uname -a
' 代替分配行。结果相同。
我试过在有和没有传递“:linux”作为collect_data的参数的情况下运行。唯一的区别是我收到一个关于 collect_data(:linux) 已经被定义而不是 :default 的警告。
我尝试将插件重命名为一个随机的 8 个字符标识符,以防万一它被称为:Uname。结果相同。
我尝试将“uname”(大写和小写)作为参数传递给 o.all_plugins。结果相同。
所以我的问题是:
为什么 ohai(8.3,在 Ruby 2.2.1 下运行)认为这是 6 版插件?我看不到任何让它看起来不是版本 7 的东西。
我怎样才能得到这个工作?
谢谢