0

我正在尝试为 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。结果相同。

所以我的问题是:

  1. 为什么 ohai(8.3,在 Ruby 2.2.1 下运行)认为这是 6 版插件?我看不到任何让它看起来不是版本 7 的东西。

  2. 我怎样才能得到这个工作?

谢谢

4

1 回答 1

2

自我注意:下次你这样做时,不要尝试从插件所在的目录进行测试并添加“。” 到你的 plugin_path。移动到不同的目录并添加插件的绝对路径解决了这个问题。

我打算留下这个,以防其他人发生这种情况。

于 2015-05-20T16:15:03.843 回答