rabbit-slide-myokoym-sinatrasapporo-20160619 2016.6.19.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.rabbit +1 -0
- data/README.md +24 -0
- data/Rakefile +17 -0
- data/config.yaml +22 -0
- data/introduction-of-webapp-debugging.md +217 -0
- data/pdf/sinatrasapporo-20160619-introduction-of-webapp-debugging.pdf +0 -0
- metadata +78 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: b543a6e2a020f9f57ac8c955c500ed3de84a9ac3
|
4
|
+
data.tar.gz: 6c62254b069a0902c6470264c6334df19c68bde8
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 5bbb9413c90f5dc78669ca153fb1d5a933322f7cdc3e8f87074f3e8b7051f07b5fbe0e08ab8018902fff1ab98a095d0d61bac1696dd62c59be9063718b441f47
|
7
|
+
data.tar.gz: 1b9e6247d54261e164d9c5ba244b4d507914bcffee10cf2c57cab691eadf0c5859304c6e3de7bf9b1c87d4413bf76435e10376ba8ffab8c54df6823d85f26306
|
data/.rabbit
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
introduction-of-webapp-debugging.md
|
data/README.md
ADDED
@@ -0,0 +1,24 @@
|
|
1
|
+
# SPAデバッグ入門
|
2
|
+
|
3
|
+
主にSPAを対象としたWebアプリケーションのデバッグについてFirefoxの開発ツールを例に紹介
|
4
|
+
|
5
|
+
## 作者向け
|
6
|
+
|
7
|
+
### 表示
|
8
|
+
|
9
|
+
rake
|
10
|
+
|
11
|
+
### 公開
|
12
|
+
|
13
|
+
rake publish
|
14
|
+
|
15
|
+
## 閲覧者向け
|
16
|
+
|
17
|
+
### インストール
|
18
|
+
|
19
|
+
gem install rabbit-slide-myokoym-sinatrasapporo-20160619
|
20
|
+
|
21
|
+
### 表示
|
22
|
+
|
23
|
+
rabbit rabbit-slide-myokoym-sinatrasapporo-20160619.gem
|
24
|
+
|
data/Rakefile
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
require "rabbit/task/slide"
|
2
|
+
|
3
|
+
# Edit ./config.yaml to customize meta data
|
4
|
+
|
5
|
+
spec = nil
|
6
|
+
Rabbit::Task::Slide.new do |task|
|
7
|
+
spec = task.spec
|
8
|
+
# spec.files += Dir.glob("doc/**/*.*")
|
9
|
+
# spec.files -= Dir.glob("private/**/*.*")
|
10
|
+
spec.add_runtime_dependency("rabbit-theme-nyankosakana")
|
11
|
+
end
|
12
|
+
|
13
|
+
desc "Tag #{spec.version}"
|
14
|
+
task :tag do
|
15
|
+
sh("git", "tag", "-a", spec.version.to_s, "-m", "Publish #{spec.version}")
|
16
|
+
sh("git", "push", "--tags")
|
17
|
+
end
|
data/config.yaml
ADDED
@@ -0,0 +1,22 @@
|
|
1
|
+
---
|
2
|
+
id: sinatrasapporo-20160619
|
3
|
+
base_name: introduction-of-webapp-debugging
|
4
|
+
tags:
|
5
|
+
- sinatrasapporo
|
6
|
+
- firefox
|
7
|
+
presentation_date: 2016/06/19
|
8
|
+
version: 2016.6.19.0
|
9
|
+
licenses:
|
10
|
+
- CC BY 4.0
|
11
|
+
slideshare_id:
|
12
|
+
speaker_deck_id:
|
13
|
+
ustream_id:
|
14
|
+
vimeo_id:
|
15
|
+
youtube_id:
|
16
|
+
author:
|
17
|
+
markup_language: :md
|
18
|
+
name: Masafumi Yokoyama
|
19
|
+
email: myokoym@gmail.com
|
20
|
+
rubygems_user: myokoym
|
21
|
+
slideshare_user:
|
22
|
+
speaker_deck_user:
|
@@ -0,0 +1,217 @@
|
|
1
|
+
# SPAデバッグ入門
|
2
|
+
|
3
|
+
author
|
4
|
+
: Masafumi Yokoyama
|
5
|
+
|
6
|
+
content-source
|
7
|
+
: 勉強会@Sinatra札幌
|
8
|
+
|
9
|
+
date
|
10
|
+
: 2016-06-19
|
11
|
+
|
12
|
+
allotted-time
|
13
|
+
: 40m
|
14
|
+
|
15
|
+
theme
|
16
|
+
: nyankosakana
|
17
|
+
|
18
|
+
# さいきんのおしごと
|
19
|
+
|
20
|
+
* Firefox
|
21
|
+
* AngularJS
|
22
|
+
* Rails
|
23
|
+
|
24
|
+
# SPAデバッグ入門
|
25
|
+
|
26
|
+
# SPAとは
|
27
|
+
|
28
|
+
* Single Page Application
|
29
|
+
* ページ遷移なし
|
30
|
+
* AjaxやWebSocketなどを使って通信
|
31
|
+
|
32
|
+
# デバッグとは
|
33
|
+
|
34
|
+
* バグを見つける
|
35
|
+
* 直す
|
36
|
+
|
37
|
+
# デバッグとは
|
38
|
+
|
39
|
+
* *バグを見つける*
|
40
|
+
* 直す
|
41
|
+
|
42
|
+
# バグを見つける
|
43
|
+
|
44
|
+
* デバッグツール
|
45
|
+
* 事例
|
46
|
+
|
47
|
+
# バグを見つける
|
48
|
+
|
49
|
+
* *デバッグツール*
|
50
|
+
* 事例
|
51
|
+
|
52
|
+
# デバッグツール
|
53
|
+
|
54
|
+
* Firefox/Google Chrome標準添付
|
55
|
+
* F12で出てくるやつ
|
56
|
+
* 標準添付のツールが充実してきたので、Live HTTP HeadersやHttpFox、Findbugsなどは不要になってきている
|
57
|
+
|
58
|
+
# デバッグツール
|
59
|
+
|
60
|
+
Firefoxの開発ツールを例にいくつか紹介
|
61
|
+
|
62
|
+
# 開発ツール
|
63
|
+
|
64
|
+
* インスペクタ
|
65
|
+
* Webコンソール
|
66
|
+
* ネットワークモニタ
|
67
|
+
|
68
|
+
# 開発ツール
|
69
|
+
|
70
|
+
* *インスペクタ*
|
71
|
+
* Webコンソール
|
72
|
+
* ネットワークモニタ
|
73
|
+
|
74
|
+
# インスペクタ
|
75
|
+
|
76
|
+
* 要素を調査
|
77
|
+
* DOMを調べる
|
78
|
+
* 要素(element)があるか
|
79
|
+
* 属性(attribute)があるか
|
80
|
+
|
81
|
+
{::note} https://developer.mozilla.org/ja/docs/Tools/Page_Inspector {:/note}
|
82
|
+
|
83
|
+
# 要素
|
84
|
+
|
85
|
+
```html
|
86
|
+
<a href="..."></a>
|
87
|
+
```
|
88
|
+
|
89
|
+
# 属性
|
90
|
+
|
91
|
+
```html
|
92
|
+
href="..."
|
93
|
+
```
|
94
|
+
|
95
|
+
# 要素を調査
|
96
|
+
|
97
|
+
デモ
|
98
|
+
|
99
|
+
# 開発ツール
|
100
|
+
|
101
|
+
* ~~インスペクタ~~
|
102
|
+
* *Webコンソール*
|
103
|
+
* ネットワークモニタ
|
104
|
+
|
105
|
+
# Webコンソール
|
106
|
+
|
107
|
+
* JavaScriptなどのログを記録
|
108
|
+
* console.log
|
109
|
+
* JavaScriptのコードを実行してWebページと対話
|
110
|
+
|
111
|
+
{::note} https://developer.mozilla.org/ja/docs/Tools/Web_Console {:/note}
|
112
|
+
|
113
|
+
# Webコンソール
|
114
|
+
|
115
|
+
デモ
|
116
|
+
|
117
|
+
# 開発ツール
|
118
|
+
|
119
|
+
* ~~インスペクタ~~
|
120
|
+
* ~~Webコンソール~~
|
121
|
+
* *ネットワークモニタ*
|
122
|
+
|
123
|
+
# ネットワークモニタ
|
124
|
+
|
125
|
+
* ネットワークリクエストの詳細を表示
|
126
|
+
* HTTPステータス
|
127
|
+
* リクエスト/レスポンス
|
128
|
+
|
129
|
+
{::note} https://developer.mozilla.org/ja/docs/Tools/Network_Monitor {:/note}
|
130
|
+
|
131
|
+
# ネットワークモニタ
|
132
|
+
|
133
|
+
デモ
|
134
|
+
|
135
|
+
# バグを見つける
|
136
|
+
|
137
|
+
* ~~デバッグツール~~
|
138
|
+
* *事例*
|
139
|
+
|
140
|
+
# 事例
|
141
|
+
|
142
|
+
* かいはつしゃはそうしんボタンをおした
|
143
|
+
* しかしなにもおこらなかった
|
144
|
+
|
145
|
+
# :-O
|
146
|
+
|
147
|
+
# 切り分ける
|
148
|
+
|
149
|
+
* どこでエラーになっているか
|
150
|
+
* クライアント
|
151
|
+
* サーバー
|
152
|
+
* ネットワーク
|
153
|
+
|
154
|
+
# そうび
|
155
|
+
|
156
|
+
* ネットワークモニタ
|
157
|
+
* Webコンソール
|
158
|
+
* サーバーのログ
|
159
|
+
|
160
|
+
# かいはつしゃはネットワークモニタをつかった
|
161
|
+
|
162
|
+
# かいはつしゃはネットワークモニタをつかった
|
163
|
+
|
164
|
+
* リクエストは未送信だった
|
165
|
+
* エラーが返ってきていた
|
166
|
+
* 送信したまま返ってきていなかった
|
167
|
+
|
168
|
+
# かいはつしゃはネットワークモニタをつかった
|
169
|
+
|
170
|
+
* *リクエストは未送信だった*
|
171
|
+
* エラーが返ってきていた
|
172
|
+
* 送信したまま返ってきていなかった
|
173
|
+
|
174
|
+
# リクエストは未送信だった
|
175
|
+
|
176
|
+
* クライアントでエラーが起きている
|
177
|
+
* Webコンソールを使って調査
|
178
|
+
|
179
|
+
# かいはつしゃはWebコンソールをつかった
|
180
|
+
|
181
|
+
* JavaScriptにログを仕込む
|
182
|
+
* Webコンソールにログが出る
|
183
|
+
|
184
|
+
# かいはつしゃはネットワークモニタをつかった
|
185
|
+
|
186
|
+
* ~~リクエストは未送信だった~~
|
187
|
+
* *エラーが返ってきていた*
|
188
|
+
* 送信したまま返ってきていなかった
|
189
|
+
|
190
|
+
# エラーが返ってきていた
|
191
|
+
|
192
|
+
* ステータスコードを見る
|
193
|
+
|
194
|
+
# ステータスコードを見る
|
195
|
+
|
196
|
+
* 400番台ならクライアントが悪そう
|
197
|
+
* リクエストパラメータを確認
|
198
|
+
* サーバーのログを見る
|
199
|
+
* 500番台ならサーバーが悪そう
|
200
|
+
* サーバーのログを見る
|
201
|
+
|
202
|
+
# かいはつしゃはネットワークモニタをつかった
|
203
|
+
|
204
|
+
* ~~リクエストは未送信だった~~
|
205
|
+
* ~~エラーが返ってきていた~~
|
206
|
+
* *送信したまま返ってきていなかった*
|
207
|
+
|
208
|
+
# 送信したまま返ってきていなかった
|
209
|
+
|
210
|
+
* ネットワーク不調の可能性
|
211
|
+
* WiFi有効になってる?
|
212
|
+
* ping通る?
|
213
|
+
|
214
|
+
# まとめ
|
215
|
+
|
216
|
+
* 標準ツールが充実
|
217
|
+
* クライアントかサーバーかネットワークか切り分けよ
|
Binary file
|
metadata
ADDED
@@ -0,0 +1,78 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: rabbit-slide-myokoym-sinatrasapporo-20160619
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 2016.6.19.0
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Masafumi Yokoyama
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2016-06-18 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: rabbit
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - ">="
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: 2.0.2
|
20
|
+
type: :runtime
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - ">="
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: 2.0.2
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: rabbit-theme-nyankosakana
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - ">="
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '0'
|
34
|
+
type: :runtime
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - ">="
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: '0'
|
41
|
+
description: 主にSPAを対象としたWebアプリケーションのデバッグについてFirefoxの開発ツールを例に紹介
|
42
|
+
email:
|
43
|
+
- myokoym@gmail.com
|
44
|
+
executables: []
|
45
|
+
extensions: []
|
46
|
+
extra_rdoc_files: []
|
47
|
+
files:
|
48
|
+
- ".rabbit"
|
49
|
+
- README.md
|
50
|
+
- Rakefile
|
51
|
+
- config.yaml
|
52
|
+
- introduction-of-webapp-debugging.md
|
53
|
+
- pdf/sinatrasapporo-20160619-introduction-of-webapp-debugging.pdf
|
54
|
+
homepage: http://slide.rabbit-shocker.org/authors/myokoym/sinatrasapporo-20160619/
|
55
|
+
licenses:
|
56
|
+
- CC BY 4.0
|
57
|
+
metadata: {}
|
58
|
+
post_install_message:
|
59
|
+
rdoc_options: []
|
60
|
+
require_paths:
|
61
|
+
- lib
|
62
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
63
|
+
requirements:
|
64
|
+
- - ">="
|
65
|
+
- !ruby/object:Gem::Version
|
66
|
+
version: '0'
|
67
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
68
|
+
requirements:
|
69
|
+
- - ">="
|
70
|
+
- !ruby/object:Gem::Version
|
71
|
+
version: '0'
|
72
|
+
requirements: []
|
73
|
+
rubyforge_project:
|
74
|
+
rubygems_version: 2.5.1
|
75
|
+
signing_key:
|
76
|
+
specification_version: 4
|
77
|
+
summary: SPAデバッグ入門
|
78
|
+
test_files: []
|