SlideShare a Scribd company logo
Submit Search
Upload
Login
Signup
Redmine4時代のプラグイン開発 redmine.tokyo #13
Report
Sho Douhashi
Follow
Nov. 17, 2017
•
0 likes
•
9,069 views
1
of
73
Redmine4時代のプラグイン開発 redmine.tokyo #13
Nov. 17, 2017
•
0 likes
•
9,069 views
Download Now
Download to read offline
Report
Engineering
Redmine 4.0 に向けたプラグイン開発の話。 at redmine.tokyo 13
Sho Douhashi
Follow
Recommended
RedMica 2.0 (2021-11) 新機能ハイライト
Go Maeda
3.8K views
•
28 slides
unofficial redmine 紹介 RedmineJapan2020
Yuuki Nara
1.7K views
•
25 slides
講演1 redmineの簡易crmとしての活用事例r2
Hidehisa Matsutani
7.8K views
•
29 slides
Redmineコミュニティの活動報告と今後の抱負~Redmineよ、永遠に #RedmineJapan2020
akipii Oga
2.8K views
•
26 slides
数千人が利用する楽天Redmineの過去と未来 - The past and future of Rakuten Redmine that is the...
Dai FUJIHARA
17.3K views
•
62 slides
Redmine issue assign notice plugin の紹介
onozaty
2.2K views
•
13 slides
More Related Content
What's hot
Redmine + Lychee導入のアンチパターン
agileware_jp
2.6K views
•
25 slides
Redmineをプラグインで拡張しよう
Haruyuki Iida
19.7K views
•
60 slides
ある工場の Redmine 2021 ( Redmine of one plant 2021 )
Kohei Nakamura
2.9K views
•
33 slides
自チームのLychee redmine活用例
agileware_jp
7.7K views
•
11 slides
Redmineの9年間の歩みを振り返ってみる
Go Maeda
5.8K views
•
29 slides
数千人が利用する楽天Redmineの過去と未来
Rakuten Group, Inc.
3.4K views
•
62 slides
What's hot
(20)
Redmine + Lychee導入のアンチパターン
agileware_jp
•
2.6K views
Redmineをプラグインで拡張しよう
Haruyuki Iida
•
19.7K views
ある工場の Redmine 2021 ( Redmine of one plant 2021 )
Kohei Nakamura
•
2.9K views
自チームのLychee redmine活用例
agileware_jp
•
7.7K views
Redmineの9年間の歩みを振り返ってみる
Go Maeda
•
5.8K views
数千人が利用する楽天Redmineの過去と未来
Rakuten Group, Inc.
•
3.4K views
はじめる! Redmine (2021年版)
Go Maeda
•
23.1K views
Redmine 4.2 新機能評価ガイド
Go Maeda
•
1.4K views
【15-A-4】事例2本立て!Redmineユーザ達が語る現場定着化への取組みと導入アンチパターン
Developers Summit
•
842 views
Redmine.tokyo21 questionnaire
Jun Naitoh
•
1.9K views
挫折しないRedmine (2022)
Go Maeda
•
1.2K views
Redmineサーバ統合事例
Yuuki Nara
•
7.2K views
View customize plugin for Redmineの紹介 (2019年版)
onozaty
•
10.7K views
導入事例から見る!Lychee Redmineの製品デモ
agileware_jp
•
397 views
Redmineをちょっと便利に! プログラミング無しで使ってみるREST API
Go Maeda
•
31.9K views
Redmineの画面をあなた好みにカスタマイズ - View customize pluginの紹介 - Redmine Japan 2020
onozaty
•
9.7K views
Unofficial Redmine Cookingの紹介
Yuuki Nara
•
5.6K views
WPF on .NET Core 3.0
一希 大田
•
644 views
【Redmine 4.2 を先取り】RedMica 1.1 (2020-05) 新機能ハイライト
Go Maeda
•
10.4K views
Redmine 4.1 / RedMica 1.0ユーザーのための RedMica 1.1 (2020-05)・ 1.2 (2020-11) 新機能ガイド
Go Maeda
•
2K views
Viewers also liked
灰かぶりチケットはシンデレラに成り得るか?
ishikawa_mizuki
9.4K views
•
22 slides
20171117 redminetokyo13
Yukiya Hayashi
5.4K views
•
19 slides
Redmine tokyo #13 LT
Asako Yanuki
6.1K views
•
23 slides
Spring Bootの本当の理解ポイント #jjug
Masatoshi Tada
39.8K views
•
94 slides
Java SE 9の紹介: モジュール・システムを中心に
Taku Miyakawa
145.2K views
•
104 slides
Unofficial Redmine Cooking 闇鍋_デモ環境への発展
Yuuki Nara
4.4K views
•
33 slides
Viewers also liked
(20)
灰かぶりチケットはシンデレラに成り得るか?
ishikawa_mizuki
•
9.4K views
20171117 redminetokyo13
Yukiya Hayashi
•
5.4K views
Redmine tokyo #13 LT
Asako Yanuki
•
6.1K views
Spring Bootの本当の理解ポイント #jjug
Masatoshi Tada
•
39.8K views
Java SE 9の紹介: モジュール・システムを中心に
Taku Miyakawa
•
145.2K views
Unofficial Redmine Cooking 闇鍋_デモ環境への発展
Yuuki Nara
•
4.4K views
Internetトラフィックエンジニアリングの現実
J-Stream Inc.
•
5.1K views
Redmine.tokyo 13 questionnaire
Jun Naitoh
•
3.2K views
ドキュメントを直し続ける話 #kbkz_tech
Michihito Shigemura
•
1.4K views
Redmine.tokyo 第7回勉強会 ディスカッション
Tomohisa Kusukawa
•
5.7K views
Redmine 260 300_new_feature
Jun Naitoh
•
8.7K views
Redmineはキャズムを超える -日経SYSTEMS寄稿の思い-
Makoto SAKAI
•
7.6K views
Redmine.tokyo 07 open_discussion
Jun Naitoh
•
3.9K views
Redmine.tokyo 07 questionnaire
Jun Naitoh
•
5K views
Redmineのスマホアプリ RedminePM
project mode, Inc.
•
9.4K views
Redmine + gitlab: merge base development
smdkk
•
23.5K views
Rbpdf gem library
Jun Naitoh
•
39.5K views
怖くない? オープンソースへの貢献
ishikawa_mizuki
•
2.4K views
【第7回redmine.tokyo勉強会】RedmineのFAQとアンチパターン集~WBS駆動からチケット駆動へ
akipii Oga
•
20.7K views
講演1 Redmine導入のアンチパターン
Hidehisa Matsutani
•
19.9K views
Similar to Redmine4時代のプラグイン開発 redmine.tokyo #13
OSC福岡 20111203
Hiroshi Bunya
2.9K views
•
35 slides
Rubyプログラミング教育に対する取り組みと事例紹介
Yasushi Ishikawa
1.3K views
•
29 slides
Redmineプラグイン導入・開発入門
Minoru Maeda
18.5K views
•
60 slides
iQONの開発手法 at iQONエンジニアセミナー
Imamura Masayuki
4.9K views
•
29 slides
ゼロからのプログラミングRails講座 Codeanywhere版
DIVE INTO CODE Corp.
10.7K views
•
73 slides
アイデアを形にする ③3時間でアプリ公開!ゼロからのプログラミング講座
DIVE INTO CODE Corp.
245 views
•
71 slides
Similar to Redmine4時代のプラグイン開発 redmine.tokyo #13
(20)
OSC福岡 20111203
Hiroshi Bunya
•
2.9K views
Rubyプログラミング教育に対する取り組みと事例紹介
Yasushi Ishikawa
•
1.3K views
Redmineプラグイン導入・開発入門
Minoru Maeda
•
18.5K views
iQONの開発手法 at iQONエンジニアセミナー
Imamura Masayuki
•
4.9K views
ゼロからのプログラミングRails講座 Codeanywhere版
DIVE INTO CODE Corp.
•
10.7K views
アイデアを形にする ③3時間でアプリ公開!ゼロからのプログラミング講座
DIVE INTO CODE Corp.
•
245 views
Hudson × Redmine
Haruyuki Iida
•
4.4K views
Rails api way in aiming
Yasutomo Uemori
•
836 views
チームにRedmineを適用せよ! #RxTstudy
Dai FUJIHARA
•
9.2K views
はじめてがアジャイル
Kenichi Takahashi
•
1.4K views
2015/06/27 Remixing つらくないメディア間連携
Takumi Yoshida
•
533 views
【入門】3時間でアプリ公開!ゼロからのプログラミングRails講座
DIVE INTO CODE Corp.
•
89K views
Android studio で行ってみよう!!
Kazuaki Ueda
•
5.4K views
Redmine admin
Jun Naitoh
•
6.1K views
ドリコムJenkins勉強会資料
Go Sueyoshi (a.k.a sue445)
•
8.4K views
ゲーム会社でのRuby : rails活用事例
Yasutomo Uemori
•
2.4K views
nanapiにおける継続的インテグレーション
晃 遠山
•
11.7K views
Redmineプラグインのテストを書いてくれませんか? #niigatarb
Tatsuya Saito
•
3.5K views
20141220_iOS8マルチデバイス対応(Size Classes編)
Kanako Kobayashi
•
1.8K views
【OSC2011広島】共有アプリで遊ぼう!(日本Red5ユーザー会)
Shinichiro Yoshida
•
678 views
Redmine4時代のプラグイン開発 redmine.tokyo #13
1.
Redmine4時代の プラグイン開発 強いプラグインを開発しよう Agileware Inc. Sho
DOUHASHI
2.
自己紹介
3.
自己紹介 堂端 翔 (
Sho DOUHASHI ) facebook.com/douhashi twitter @douhashi Agileware Inc. CTO プログラミング歴20年弱。最近はインフラ屋さん。AWS大 好き。
4.
Agileware? http://agileware.jp Ruby/Railsを得意とするソフトウェアベンダー。 Redmineプラグイン「LycheeRedmine」シリーズを開発。 https://lychee-redmine.jp/
5.
突然ですが、アンケート
6.
Q1. Redmineバージョンいくつですか?
7.
Q2. Redmineプラグイン使ってますか?
8.
Q3. 独自のプラグインを 開発して使ってますか?
9.
ご協力ありがとうございます!
10.
今日はRedmineの プラグイン開発についてお話します
11.
本日のアジェンダ
12.
本日のアジェンダ 1. RedmineとRailsの関係 2. 強いプラグインの開発方 3.
Redmine 4.x 時代のプラグイン開発 (ダークサイド) 4. Redmine 4.x 時代のプラグイン開発 (ライトサイド) 5. まとめ
13.
本日のアジェンダ 1. RedmineとRailsの関係 2. 強いプラグインの開発方 3.
Redmine 4.x 時代のプラグイン開発 (ダークサイド) 4. Redmine 4.x 時代のプラグイン開発 (ライトサイド) 5. まとめ
14.
RedmineとRailsの関係
15.
の前に、
16.
Railsのリリース傾向の話
17.
Railsの(だいたいの)リリース傾向 ● だいたい、3年スパンでメジャーが上がる ● だいたい、.0系(2.0,
3.0, 4.0)はアップデートを促すための 過渡期リリース ● だいたい、.0系リリースは旧バージョンへのDeplication Warningを出して、その後のリリースで削除してく ● だいたい、.1 とか .2 でドラスティックな機能追加、API 削除が入る
18.
その上で、RedmineとRailsのバージョン の関係をみていきましょう。
19.
RedmineとRailsの関係 ● Redmine 2.0
~ ○ Rails 3.2系 ● Redmine 3.0 ~ ○ Rails 4.2 系
20.
おわかりいただけただろうか...
21.
RedmineとRailsの関係 ● Redmine 2.0
~ ○ Rails 3.2系 ● Redmine 3.0 ~ ○ Rails 4.2 系
22.
ド、ドラスティッ ク... ドラスティック【drastic】 ( 形動 ) 徹底的で激烈なさま。
「政治情勢は-に展開している」 「 -な変 化」
23.
なので、
24.
Redmineプラグインあるある
25.
新バージョンでいきなりデスる
26.
解決策 (びっくりしないために)
27.
次リリースブランチでも動かそう ● 次期リリースバージョンのRedmineで動かしておこう。 ● 毎度動かすのは大変なのでテスト書こう。 ●
特に、Railsのメジャーが上がるときは覚悟しておこう。
28.
その他にも「強い」プラグインを 作る工夫は色々
29.
ということで、次の話題
30.
本日のアジェンダ 1. RedmineとRailsの関係 2. 強いプラグインの開発方 3.
Redmine 4.x 時代のプラグイン開発 (ダークサイド) 4. Redmine 4.x 時代のプラグイン開発 (ライトサイド) 5. まとめ
31.
弊社で実践しているプラグイン開発の仕 方
32.
ルールその1 本体のDBにカラム追加/変更しない
33.
本体のDBにカラム追加/変更しない
34.
本体のDBにカラム追加/変更しない ● 本体DBに直接カラム追加しないことで、Redmine本体へ の侵食を減らす ○ 本体側で同等機能が追加されてもバッティングしない ○
Redmine本体のバージョンアップを妨げない ○ 他のプラグインの動作を妨げない
35.
ルールその2 開発時必要なGemはGemfile.localに書く (= Gemfileは最小限に留める)
36.
プラグインあるある ● たまーに、Gemfileにバージョン指定して書いてあるプラ グインがいる ○ 同じGemを違うバージョン指定でいれようとする =>
bundleできなくてデスる ☠ => コレ、テスト用のGemとかで非常に多い
37.
開発時のみ必要なGemはGemfile.localに書く ● Gemfile.localに書いて、Redmine本体直下へsymlink ● Gemfileには「プラグインに必ず必要なGemのみ」書く ○
これでGemがバッティングする可能性を減らせる ○ それでもたまーにバッティングするので、その時は githubでissueをあげてみましょう
38.
弊社のGemfile.local
39.
ルールその3 テストはRSpecで書く
40.
プラグインあるある ● Redmine標準はMinitestベース ○ テストデータはfixturesで作られてる =>
正直、fixturesでかすぎて覚えてられない。 => setupに必要な情報が多すぎる
41.
テストはRspecで書く ● RSpec、FactoryBotで書く ● 画面系はcapybaraでE2Eテスト ○
controllerのテストは労力に見合わないかも => Factory書くのしんどいけど、一回書けば使い回しできる
42.
他にも細かいTipsはいろいろあります
43.
細かいTips ● Rubocopいれてコードをキレイに保つ ● init.rbにはあんまり処理を実装しない ●
モンキーパッチは最小限に などなど...
44.
語り尽くせないほどあるので、 とっ捕まえて聞いてください...
45.
次の話題
46.
本日のアジェンダ 1. RedmineとRailsの関係 2. 強いプラグインの開発方 3.
Redmine 4.x 時代のプラグイン開発 (ダークサイド) 4. Redmine 4.x 時代のプラグイン開発 (ライトサイド) 5. まとめ
47.
いよいよ、Redmine4.0が見えてきまし た
48.
Redmine 4.0開発状況
49.
Redmine 4.0の目玉はやっぱり
50.
Rails 5.x 対応!
51.
Redmine4.0のRailsバージョンは...
53.
ド、ドラ(ry ドラスティック【drastic】 ( 形動 ) 徹底的で激烈なさま。
「政治情勢は-に展開している」 「 -な変 化」
54.
いろんなプラグインの悲鳴が聞こえる
55.
Rails 5で消えるAPI (影響度の大きそうなもの) 1.
before_filter / after_filter (4.x時点でDeplication) ○ 歴史の古いプラグインはそのままのことが多い 2. alias_method_chain ○ Redmineの標準動作を書き換えるときの常套手段 ○ お世話になってる人多いはず
56.
対策
57.
Rails 5対応 1. before_filter
/ after_filter (4.x時点でDeplication) ○ before_action / after_action を使う 2. alias_method_chain ○ Module#prepend (Ruby 2.0からの標準機能)を使う ○ https://docs.ruby- lang.org/ja/latest/method/Module/i/prepend.html
58.
ただし、一個問題が。
59.
問題: Redmine 3.x系
との共存
60.
課題: Redmine 3.xとの共存 1.
Redmine 3.x は ruby 1.9.3 もサポートしている ○ つまり、ruby 2.0.0 からの Module#prepand が使えな い => コード内にバージョン判別書くのはしんどい... => しばらくbranch分けるとかで様子見か...?
61.
こんな、後ろ向きな話ばかりじゃないよ
62.
本日のアジェンダ 1. RedmineとRailsの関係 2. 強いプラグインの開発方 3.
Redmine 4.x 時代のプラグイン開発 (ダークサイド) 4. Redmine 4.x 時代のプラグイン開発 (ライトサイド) 5. まとめ
63.
Rails 5.1の目玉機能
64.
ActionCable!
65.
ActionCableって? 1. Rails上でWebSocket通信を実現するためのライブラリ 2. ソケット通信のように双方向の通信がリアルタイムで行 えるので、よりインタラクティブなプラグインが作れる
66.
例えば...
67.
Redmine上にチャットシステム導入!
68.
例えば...
69.
チケット更新のリアルタイム通知!
70.
夢が広がりますね!
71.
本日のアジェンダ 1. RedmineとRailsの関係 2. 強いプラグインの開発方 3.
Redmine 4.x 時代のプラグイン開発 (ダークサイド) 4. Redmine 4.x 時代のプラグイン開発 (ライトサイド) 5. まとめ
72.
まとめ 1. Redmineはドラスティックに変わる ○ 強いプラグインの開発が大事 2.
Redmine 4.x でもドラスティックに変わる ○ 旧バージョンとの共存が課題 ○ Rails5のおかげで夢が広がる!
73.
ご清聴ありがとうございました