Project

General

Profile

バグ #1302

依存関係の足りないプラグインがある

Added by あひる 家鴨 10 months ago. Updated 10 months ago.

Status:
終了
Priority:
通常
Target version:
プラグイン名:
intent, twitter
ブランチ:
topic/1302-tarinai-dependencies
クラッシュする:
Yes

Description

developブランチにて、以下のプラグインでそれぞれ依存関係が足りなく、起動時にこける問題があります。
  • intent プラグイン
    intent プラグインは uitranslator に依存しているが書かれていないため、下記エラーで落ちる
     1: from /home/mikutter/mikutter/core/plugin/intent/intent.rb:63:in `block in <top (required)>'
    /usr/local/bundle/gems/pluggaloid-1.1.1/lib/pluggaloid/plugin.rb:257:in `method_missing': undefined method `_' for #<Plugin:0x00005650b8984bf8> (NoMethodError)
    
  • twitter プラグイン
     Photo プラグインに依存しているが、依存関係に書かれていないため、下記エラーで落ちる
     1: from /home/mikutter/mikutter/core/plugin/twitter/model/world.rb:53:in `to_hash'
    /home/mikutter/mikutter/core/plugin/twitter/model/user.rb:84:in `icon': undefined method `generate' for nil:NilClass (NoMethodError)
    

それぞれ mikutter.yml を修正すれば問題ないですが、これはそれぞれチケット分けた方がいいですかね(それがわかればブランチにコミットしてプッシュします)


再現手順

https://github.com/Na0ki/docker_mikutter/tree/master
このコンテナを起動してmikutterを起動すると再現する

Associated revisions

Revision a737816b (diff)
Added by あひる 家鴨 10 months ago

intent プラグインの足りない依存関係を追加 refs #1302

依存関係に uitranslator を追加

Revision cc640064 (diff)
Added by あひる 家鴨 10 months ago

twitter プラグインの足りない依存関係を追加 refs #1302

依存関係に photo を追加

Revision 656834f3 (diff)
Added by toshi_a 初音 10 months ago

Revert "twitter プラグインの足りない依存関係を追加 refs #1302"

This reverts commit cc6400644ff61d9c1d0449bb27f9e8379f2ce9a5.

Revision 3947035e (diff)
Added by toshi_a 初音 10 months ago

[gui] Photoプラグインがロードされていることを前提としてしまっていた refs #1302

Revision bd1efb73 (diff)
Added by toshi_a 初音 10 months ago

[twitter] photoプラグインがないとクラッシュする refs #1302

Revision e1201e6d (diff)
Added by toshi_a 初音 10 months ago

[twitter] ユーザアイコンの画像がない場合にnilではなくnotfoundの画像を返す refs #1302

Revision 2dd7abb5 (diff)
Added by toshi_a 初音 10 months ago

依存関係を修正 refs #1302

skin: photoへの依存を削除(不要だった)
twitter: skinプラグインに依存させる

Revision dc8141bf (diff)
Added by あひる 家鴨 10 months ago

intent プラグインの足りない依存関係を追加 refs #1302

依存関係に uitranslator を追加

Revision 2cce8d99 (diff)
Added by あひる 家鴨 10 months ago

twitter プラグインの足りない依存関係を追加 refs #1302

依存関係に photo を追加

Revision 9b82fe2f (diff)
Added by toshi_a 初音 10 months ago

Revert "twitter プラグインの足りない依存関係を追加 refs #1302"

This reverts commit cc6400644ff61d9c1d0449bb27f9e8379f2ce9a5.

Revision 0a573d4b (diff)
Added by toshi_a 初音 10 months ago

[gui] Photoプラグインがロードされていることを前提としてしまっていた refs #1302

Revision 36e8a626 (diff)
Added by toshi_a 初音 10 months ago

[twitter] photoプラグインがないとクラッシュする refs #1302

Revision 73fc7a2f (diff)
Added by toshi_a 初音 10 months ago

[twitter] ユーザアイコンの画像がない場合にnilではなくnotfoundの画像を返す refs #1302

Revision 707e6d04 (diff)
Added by toshi_a 初音 10 months ago

依存関係を修正 refs #1302

skin: photoへの依存を削除(不要だった)
twitter: skinプラグインに依存させる

History

#2

Updated by cob odo 10 months ago

photo_filterの使用箇所を調べた限りでは、必ずnilチェックをしていたようなので、こちらは依存関係に書いていなくても問題ない(無ければ無いでよいように書いてある)ように思います。

#3

Updated by あひる 家鴨 10 months ago

  • Status changed from 分類待ち to toshi_aの判断待ち

ひとまず自分の指摘した二箇所に関してコミットを分けてブランチにプッシュしてみました。
topic/1302-tarinai-dependencies ブランチです。

#4

Updated by cob odo 10 months ago

twitterプラグインに関しては、単に.generate(...)&.generate(...)にして、nilだったらnilのままにしておくという手もあるかと思います。特に画像を扱う必要のない環境でも、プラグイン自体は同じように使えたほうが便利そうです。

#5

Updated by あひる 家鴨 10 months ago

それもそうですね。
.generate(...) に関しては &.generate(...) にします。
その場合、photo は gui 系のプラグインが依存していればいいんですかね。

#6

Updated by cob odo 10 months ago

  1. GUI必要&画像必要:通常の環境
  2. GUI必要&画像不要:?
  3. GUI不要&画像必要:画像DL botのような運用?
  4. GUI不要&画像不要:あひる焼くな等のテキストベースbot?

2は必要性が謎ですね……あるとしたら極度に回線が細い環境でしょうか。例えば長期にわたって海上にいる漁船やタンカー、あるいは原子力潜水艦等で、衛星回線経由で見ている、とか?

guiやshortcutkeyはphotoに依存してしまってもいいような気がしますね。

#7

Updated by toshi_a 初音 10 months ago

  • Status changed from toshi_aの判断待ち to 実装待ち

twitterプラグインに関しては、単に.generate(...)を&.generate(...)にして、nilだったらnilのままにしておくという手もあるかと思います。特に画像を扱う必要のない環境でも、プラグイン自体は同じように使えたほうが便利そうです。

そう思います。TwitterプラグインがPhotoに依存していないのは意図的なものです。 cc640064 は必要ないと思います。

それもそうですね。
.generate(...) に関しては &.generate(...) にします。
その場合、photo は gui 系のプラグインが依存していればいいんですかね。

guiもphotoに依存する必要はありません。GUIはPhoto Modelを利用するだけで生成しないからです。

ただ、 source:core/plugin/gui/tablike.rb@2d0864a0#L81 はPhotoがないとクラッシュするように見えるので、修正が必要ですね。

shortcutkeyもphotoとは関係がないので依存すべきではないですが、現状のユースケースでは考えなくて良さそうです。

#8

Updated by toshi_a 初音 10 months ago

guiプラグインの修正はコミットしました( 3947035e )。

twitterプラグインはPhoto Variantを使っているため Plugin::Photo::Photo.generate を使ってしまってますね。どうしたものか

#9

Updated by あひる 家鴨 10 months ago

&.generate 以外に何か別の方法を模索した方がいい感じですか?

#10

Updated by toshi_a 初音 10 months ago

  • Status changed from 実装待ち to レビュー待ち
  • Assignee set to あひる 家鴨
  • ブランチ set to topic/1302-tarinai-dependencies

多分動くと思うからpushしました!

#11

Updated by あひる 家鴨 10 months ago

  • Status changed from レビュー待ち to マージ待ち

最新のブランチであひる焼くながdockerコンテナで多分動いたと思うからマージしようぜ。

#12

Updated by toshi_a 初音 10 months ago

merged.
@ahiru develop基準になっていたためcherry-pickしました。masterにpushしたぶんでうまく動いてるか確認して大丈夫そうだったらcloseしてください(雑)

#13

Updated by あひる 家鴨 10 months ago

  • Status changed from マージ待ち to 終了

多分動いたから閉じる
ありがとう

Also available in: Atom PDF