SlideShare a Scribd company logo
SpringOneを経験してよりよいWebサービスを作るために僕らが取り組むこと
Takahiro Fujii
Thomas Ludwig
1
Introduction
2
Takahiro Fujii(@taka_ft)
Team Maneger
Booking Front Team
Travel Platform Group
Travel Service Development Department
Agenda
3
https://jsug.doorkeeper.jp/events/34341
Spring REST Docsを利用して鮮度の高いDocumentを運用しよう
Takahiro Fujii
4
Topic
Documentation
5
良いドキュメンテーションの仕組み
・良いドキュメンテーションの仕組みとはなにか
・簡単にドキュメントが作れる
・見やすいドキュメントを作成することができる
・ドキュメントを更新するコストが低い
・嘘をつかない(ドキュメントと実装の差分が発生しにくい)
6
良いドキュメンテーションの仕組み
Springを利用している
アプリケーションではどうか?
7
Swagger
8
http://swagger.io/
Swaggerの考慮すべき点
・URI baseのドキュメンテーション
・Documentationのためのコードがロジック側にはいる
・DRYではない
(重複したコードをエンドポイント毎に定義する必要がある)
・Test-Driven Documentationしづらい
・Hypermediaをサポートしていない
・ライブラリのサイズ大きい(約31MB)
※Swaggerは良いツールです
※Sessionの動画でより具体的な点に触れています
9
良いドキュメンテーションの仕組み
・良いドキュメンテーションの仕組みとはなにか
・見やすいデザインが作りやすい
formatを使ってドキュメントを書くことができる
・ドキュメントを作成するために(ロジック側に)実装を必要としない
・ドキュメントが正確だと保証することができる
10
良いドキュメンテーションの仕組み
Springに適した
ドキュメンテーションツール
11
良いドキュメンテーションの仕組み
12
http://asciidoctor.org/
良いドキュメンテーションの仕組み
13
http://docs.spring.io/spring-framework/docs/4.2.x/spring-framework-reference/htmlsingle/#spring-mvc-test-framework
良いドキュメンテーションの仕組み
Springに適した
ドキュメンテーションツール
14
良いドキュメンテーションの仕組み
がAsciiDoctorとSpring MVC Test
を軸に作られました。
15
Spring REST Docs
16
http://projects.spring.io/spring-restdocs/
2015/10/07にでたばっかり!
17
https://github.com/spring-projects/spring-restdocs/releases
こんなものがつくれます(html)
18
こんなものがつくれます(自動生成してくれます)
19
SpringOne’s session
Spring REST DocsはどのようにREST APIのドキュメ
ンテーションを助けてくれるのか
DOCUMENTING RESTFUL APIS
https://2015.event.springone2gx.com/schedule/sessions/documenting_restful_apis.html
Slide
http://www.slideshare.net/SpringCentral/documenting-restful-apis
20
どのようにSpring REST Docsを使うか、
残りの時間でできる限り話します。
21
Spring REST Docs使ってみましょう
Springのサンプル REST apiを
Spring REST Docsを使って、
ドキュメンテーションを作成し
てみます。
※スライドを読み返してくれ
ている方は、右のリンクから
サンプルapiをチェックアウト
して、実際にコードを書きな
がら試してみることをお勧め
します。
22
https://spring.io/guides/gs/rest-service/
イメージ
src/test/javaの下に
*Documentation.javaというクラス
を作成します。
23
spring mvc testのテストコードに、
documentするためのmethodを追
加するようなイメージ
dependency/build設定の追加
24
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-gradle
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-maven
まずは公式ドキュメントに書いてある設定を使ってみてください。
各項目で何をしているかの説明も記載されています。
dependency/build設定の追加(1)
25
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-gradle
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-maven
Dependencyとして追加するのはこれだけ
(そのうちstarterに入りそうな気もします)
dependency/build設定の追加(2)
26
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-gradle
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-maven
*Documentation.javaをunit testの実行対象にします
dependency/build設定の追加(3)
27
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-gradle
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-maven
ドキュメント(.adoc形式)をhtmlに変換するために必要です(他の形式にも変更可能)(後述します)
※公式ドキュメントではpropertiesで
この値をsnippetsDirectoryで定義しています
dependency/build設定の追加(4)
28
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-gradle
http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#getting-started-build-configuration-maven
生成されたdocumentをjarの中に内包したい場合必要(後述します)
static importが多いので
29
IDEでsuggestされるようにしておく(※上の図不完全)
さぁ、実装してみましょう
30
GreetingDocumentation.javaを実装してみましょう
前処理
31
MockMvcのinstanceを作るときに、Documentationのoutputを指定
Actual code(Sample)
32
Build
この3つの.adocファイルがビルド時に生成される(デフォルト)
※ここを変更するとdocumentが
できるディレクトリを分けられます
adocって?
.adocって何?
33
adocって?
http://asciidoctor.org/docs/what-is-asciidoc/
34
adocって?
・.adocはasciidoctorの拡張子
・Markdownのようなマークアップ言語
・HTMLやPDFなどに変換してくれる機能を有している
35
adocって?
36
[source,bash]
----
$ curl 'http://localhost:8080/greeting?name=takahiro' –I
----
[source,http]
----
GET /greeting?name=takahiro HTTP/1.1Host: localhost
----
[source,http]
----
HTTP/1.1 200 OK
Content-Type: application/json;charset=UTF-8
Content-Length: 37
{"id":1,"content":"Hello, takahiro!”}
----
curl-request.adoc
http-request.adoc
http-response.adoc
adocを直接開くとこんな感じです。
adocって?(対応
37
curl-request.adoc
http-request.adoc
http-response.adoc
add-on,plugin
firefox : https://addons.mozilla.org/ja/firefox/addon/asciidoctorjs-live-preview/
chrome : https://chrome.google.com/webstore/detail/asciidoctorjs-live-
previe/iaalpfgpbocpdfblpnhhgllgbdbchmia
sublime : https://github.com/asciidoctor/sublimetext-asciidoc
atom : https://github.com/asciidoctor/atom-asciidoc-preview
対応しているブラウザ/ソフト
で開くとこんな感じに表示されます。
で、これをどうすれば?
38
Spring REST Docsって何してくれるの?
39
http://projects.spring.io/spring-restdocs/
snippet : 切れ端・断片
SpringRESTDocsは
snippets(断片)
を自動生成してくれるもの
40
snippetsの親は自分で用意
41
親adoc
42
src/main/asciidocの下に
*.adocというファイルを作成します。
api-guide.adocの中で、
SpringRESTDocsで生成したsnippets
をincludeすることができます。
親adocは、公式ドキュメントにのっている
sample projectのapi-guide.adocを参考にして
作ってみるのがいいかと思います。
43
https://raw.githubusercontent.com/spring-projects/spring-restdocs/v1.0.0.RELEASE/samples/rest-notes-spring-hateoas/src/docs/asciidoc/api-guide.adoc
https://raw.githubusercontent.com/spring-projects/spring-restdocs/v1.0.0.RELEASE/samples/rest-notes-spring-data-rest/src/main/asciidoc/api-guide.adoc
親adocがある状態でもう一度buildしてみると、、
動きます
44
ついにhtmlが
45
指定した形式に変換されたapi-guide.*が作成されます。
pom.xml
もちろん開くことができます。
46
もう一つ
47
jarに内包させることが可能です。(アプリの中に入れる)
48
jarに内包させることが可能です。
49
pom.xml
Spring MVC Test
おさらい
50
1.SpringRESTDocsが部品(snippets)を作ってくれる(with SpringMVCTest)
2. snippetsをincludeする.adocファイルを作ると、ビルド時に
指定した形式に変換してくれる
SpringRESTDocs
*-request.adoc
*-response.adoc
*Documentation.java
api-guide.adoc
*-request.adoc
*-response.adoc
Asciidoctor
api-guide.html
snippets
targetフォルダ
おさらい
51
targetの中にできるので、
例えばJenkinsとかのbuild
からドキュメントが参照できる
api-guide.html
appname.jar
api-guide.html
アプリの中にドキュメントを組み込み、
アプリ配下にドキュメントページ
を組み込める
SpringRESTDocsの何がいいのか
52
・(望むなら)testと一緒にdocumentが生成される
・testが通ったらdocumentがつくられるという仕組みを提供
・正しくないdocumentが限りなく作りにくい
・Wikiにありがちな、更新されないdocumentを作らせない
・Test Driven Documentation
・(一度使い方を理解すれば)新規のアプリで動かすのが楽
※最初はmockでapiを作っておいてドキュメントを先に用意して提供することも可能
テスト
成功
Create document
start
end
false
true
Testからドキュメントを作ることのメリット
53
この結果はtest codeの中で実際にapiをcallして返ってきた値から作られている。
つまり仕様が変わればDocumentは変わる。
(HelloからGood mornningに変えれば生成されるドキュメントも変わる)
Endpointを変えてテストが失敗されればエラーがでてDocumentは生成されない
※もちろんMVC Testでもっと厳密な試験も可能
かんがえること
・Test CodeとしてのDocumentation.javaの位置付け
(*Documentation.javaに書くテストは何のテストなのか)
Document how to separate REST documenting tests from 'real' Junit tests
https://github.com/spring-projects/spring-restdocs/issues/89
・このドキュメンテーションの位置付け
(SpringRESTDocsでつくられるドキュメントは誰のためのドキュメント?)
(例えばこのドキュメンテーションを外部に出せる状態で常に維持するのか
エンジニアのためのものか)
54
Appendix(Support Hypermedia format)
55
Spring sample project : https://spring.io/guides/gs/rest-hateoas/
Appendix(Parameter Description)
56
requestParameters/requestFields/responseFields
Appendix(Customize template)
57
Reference : http://docs.spring.io/spring-restdocs/docs/1.0.0.RELEASE/reference/html5/#documenting-your-api-customizing-snippets
1.0.1 coming soon.
58
Reference : https://github.com/spring-projects/spring-restdocs/milestones
1.0.1 がもうすぐでそうです : )
Thank you !
59

More Related Content

PPTX
JSUG SpringOnePlatform 2016報告会 Case study2 - feed back - springoneplatform
PPT
Springを使ったwebアプリにリファクタリングしよう
PPTX
ぱぱっと理解するSpring Cloudの基本
PPTX
Spring I/O 2017での拡張のお話
PDF
DevOpsが引き金となるインフラエンジニアの進撃
PDF
Spring Day 2016 springの現在過去未来
PPTX
JAWS DAYS 2015 「DevOpsが普及した今だからこそ 考える DevOpsの次の姿」
PDF
Spring Boot + Doma + AngularJSで作るERP #jjug_ccc #ccc_r12
JSUG SpringOnePlatform 2016報告会 Case study2 - feed back - springoneplatform
Springを使ったwebアプリにリファクタリングしよう
ぱぱっと理解するSpring Cloudの基本
Spring I/O 2017での拡張のお話
DevOpsが引き金となるインフラエンジニアの進撃
Spring Day 2016 springの現在過去未来
JAWS DAYS 2015 「DevOpsが普及した今だからこそ 考える DevOpsの次の姿」
Spring Boot + Doma + AngularJSで作るERP #jjug_ccc #ccc_r12

What's hot (20)

PPTX
5分で出来る!イケてるconfluenceページ
PPTX
ゼロから始めるオープンソース生活
PDF
Arachne Unweaved (JP)
PDF
JiraとConfluenceのTips集
PDF
2013年08月 夏サミ2013-A5「DevOpsってどうなのよ?」
PPTX
スキトラ Spring + mybatis
PDF
チケット管理システム大決戦第二弾
PPTX
JIRA / Confluence の 必須プラグインはこれだ
PPTX
こだわりのkintone
PPTX
kintoneの開発プロセスとプロジェクト管理ツール
PPTX
Spring Fest 2017 「エンタープライズで利用するSpring Boot」#jsug #sf_h1
PPTX
オレ流クラウドデザイン
PPTX
Azure Api Management 俺的マニュアル 2020年3月版
PPTX
DevOpsって何?
PDF
2017spring jjug ccc_f2
PDF
How to develop a huge Single Page Application
PDF
Java web application testing
PDF
Javaエンジニアのためのアーキテクト講座-JJUG CCC 2014 Fall
PPTX
ミクシィ 21卒向け Android研修
PPTX
Confluence &JIRA 導入までの軌跡
5分で出来る!イケてるconfluenceページ
ゼロから始めるオープンソース生活
Arachne Unweaved (JP)
JiraとConfluenceのTips集
2013年08月 夏サミ2013-A5「DevOpsってどうなのよ?」
スキトラ Spring + mybatis
チケット管理システム大決戦第二弾
JIRA / Confluence の 必須プラグインはこれだ
こだわりのkintone
kintoneの開発プロセスとプロジェクト管理ツール
Spring Fest 2017 「エンタープライズで利用するSpring Boot」#jsug #sf_h1
オレ流クラウドデザイン
Azure Api Management 俺的マニュアル 2020年3月版
DevOpsって何?
2017spring jjug ccc_f2
How to develop a huge Single Page Application
Java web application testing
Javaエンジニアのためのアーキテクト講座-JJUG CCC 2014 Fall
ミクシィ 21卒向け Android研修
Confluence &JIRA 導入までの軌跡
Ad

Similar to Spring oneを経験してよりよいwebサービスを作るために僕らが取り組むこと(document編)(SpringRESTDocs) (20)

PDF
Pivotal Trackerでアジャイルなプロジェクト管理
PDF
Joruriシステム概要
PDF
Treasure Agent Monitoring Service (ベータ)
PDF
楽天トラベルとSpring(Spring Day 2016)
PDF
CIサーバを制圧せよ! - プロジェクトメトリクスと自動化技術の活用よる混乱の収拾と「最強」の組織の育成
PDF
20160409_Validating Product Ideas_yukio yoshida_cp04
PDF
アジャイルソフトウェア開発の道具箱
PPTX
Fluentdの監視サービス (Treasure Agent Monitoring Service) by Treasure Data
PDF
Itca yammer提案110615
PDF
Azure Fundamental
PDF
Serverless LT 20201202
PDF
アジャイル開発&TFS導入
PPTX
Microsoft Flow は SharePoint Designer ワークフローの代わりになり得るか!?
PDF
Azure Logic Apps で SharePoint をパワーアップしよう!
PDF
Pivotal Tracker概略
PDF
KPTの理論と実践 公開用 プロジェクトへの「ふりかえりカイゼン」の導入で学んだこと
PDF
はじめてがアジャイル
PDF
W&B Seminar #5(to share).pdf
PDF
ソーシャルワークショップ110610
PPTX
オープンセミナー2014@広島プレゼン
Pivotal Trackerでアジャイルなプロジェクト管理
Joruriシステム概要
Treasure Agent Monitoring Service (ベータ)
楽天トラベルとSpring(Spring Day 2016)
CIサーバを制圧せよ! - プロジェクトメトリクスと自動化技術の活用よる混乱の収拾と「最強」の組織の育成
20160409_Validating Product Ideas_yukio yoshida_cp04
アジャイルソフトウェア開発の道具箱
Fluentdの監視サービス (Treasure Agent Monitoring Service) by Treasure Data
Itca yammer提案110615
Azure Fundamental
Serverless LT 20201202
アジャイル開発&TFS導入
Microsoft Flow は SharePoint Designer ワークフローの代わりになり得るか!?
Azure Logic Apps で SharePoint をパワーアップしよう!
Pivotal Tracker概略
KPTの理論と実践 公開用 プロジェクトへの「ふりかえりカイゼン」の導入で学んだこと
はじめてがアジャイル
W&B Seminar #5(to share).pdf
ソーシャルワークショップ110610
オープンセミナー2014@広島プレゼン
Ad

Spring oneを経験してよりよいwebサービスを作るために僕らが取り組むこと(document編)(SpringRESTDocs)

Editor's Notes

  • #18: https://github.com/spring-projects/spring-restdocs/releases
  • #19: https://github.com/spring-projects/spring-restdocs/releases
  • #20: https://github.com/spring-projects/spring-restdocs/releases
  • #54: https://github.com/spring-projects/spring-restdocs/releases