droid-monitor 0.3.3 → 0.3.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +17 -0
- data/lib/droid/monitor/gfxinfo.rb +10 -10
- data/lib/droid/monitor/version.rb +1 -1
- data/test/gfxinfo_test.rb +77 -10
- metadata +4 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 5611592ffc80febfd87890a8d54f77368eea89bb
|
4
|
+
data.tar.gz: ea52f55d1b8ead6c96f160952216a13f0cc12410
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 6daaeb84ee4c4d29a6d549ad9b07a3bd92d0eac0480d741df496666f6e99c4b644f7e2d662da11559820c5c003fe937b3fb08d23273afa3d7d71bc530f431821
|
7
|
+
data.tar.gz: 022a281a8914f39f7d471c45b3b5323defe78e7d84afab1f555dfcef338616abbe1dfcf28f70c1ae626425bd51602d6e30fcc138e9235039d98d4dedd922d612
|
data/.travis.yml
ADDED
@@ -21,15 +21,15 @@ module Droid
|
|
21
21
|
end
|
22
22
|
|
23
23
|
def dump_gfxinfo_usage(dump_data)
|
24
|
-
|
25
|
-
|
24
|
+
view_dump = dump_data.scan(/^.*views,.*kB of display lists.*$/).map(&:strip).first
|
25
|
+
view_memory_dump2 = dump_data.scan(/^.*bytes,.*MB.*$/).map(&:strip).first
|
26
26
|
|
27
|
-
return [] if
|
27
|
+
return [] if view_dump.nil? || view_memory_dump2.nil?
|
28
28
|
|
29
|
-
|
30
|
-
|
29
|
+
v_dump = view_dump.split(/\s/).reject(&:empty?)
|
30
|
+
v_mem_dump = view_memory_dump2.split(/\s/).reject(&:empty?)
|
31
31
|
|
32
|
-
|
32
|
+
v_mem_dump + v_dump
|
33
33
|
rescue StandardError => e
|
34
34
|
puts e
|
35
35
|
[]
|
@@ -64,10 +64,10 @@ module Droid
|
|
64
64
|
}
|
65
65
|
else
|
66
66
|
{
|
67
|
-
view: dump_gfxinfo_array[
|
68
|
-
display_lists_kb: dump_gfxinfo_array[
|
69
|
-
frames_rendered: dump_gfxinfo_array[
|
70
|
-
total_memory: (dump_gfxinfo_array[
|
67
|
+
view: dump_gfxinfo_array[4].to_i,
|
68
|
+
display_lists_kb: dump_gfxinfo_array[6].to_f.round(2),
|
69
|
+
frames_rendered: dump_gfxinfo_array[11].to_i || 0,
|
70
|
+
total_memory: (dump_gfxinfo_array[0].to_f / 1024).round(2),
|
71
71
|
time: dump_gfxinfo_array.last,
|
72
72
|
}
|
73
73
|
end
|
data/test/gfxinfo_test.rb
CHANGED
@@ -91,6 +91,69 @@ Total Views: 41
|
|
91
91
|
Total DisplayList: 1.36 kB
|
92
92
|
EOS
|
93
93
|
|
94
|
+
SAMPLE_GFXINFO_6 = <<-EOS
|
95
|
+
Applications Graphics Acceleration Info:
|
96
|
+
Uptime: 9658130 Realtime: 9658130
|
97
|
+
|
98
|
+
** Graphics info for pid 9702 [com.android.chrome] **
|
99
|
+
|
100
|
+
Stats since: 9656484850794ns
|
101
|
+
Total frames rendered: 3
|
102
|
+
Janky frames: 2 (66.67%)
|
103
|
+
90th percentile: 101ms
|
104
|
+
95th percentile: 101ms
|
105
|
+
99th percentile: 101ms
|
106
|
+
Number Missed Vsync: 2
|
107
|
+
Number High input latency: 0
|
108
|
+
Number Slow UI thread: 2
|
109
|
+
Number Slow bitmap uploads: 0
|
110
|
+
Number Slow issue draw commands: 1
|
111
|
+
|
112
|
+
Caches:
|
113
|
+
Current memory usage / total memory usage (bytes):
|
114
|
+
TextureCache 878276 / 75497472
|
115
|
+
LayerCache 0 / 50331648 (numLayers = 0)
|
116
|
+
Layers total 0 (numLayers = 0)
|
117
|
+
RenderBufferCache 0 / 8388608
|
118
|
+
GradientCache 0 / 1048576
|
119
|
+
PathCache 0 / 33554432
|
120
|
+
TessellationCache 0 / 1048576
|
121
|
+
TextDropShadowCache 0 / 6291456
|
122
|
+
PatchCache 0 / 131072
|
123
|
+
FontRenderer 0 A8 1048576 / 1048576
|
124
|
+
FontRenderer 0 RGBA 0 / 0
|
125
|
+
FontRenderer 0 total 1048576 / 1048576
|
126
|
+
Other:
|
127
|
+
FboCache 0 / 0
|
128
|
+
Total memory usage:
|
129
|
+
1926852 bytes, 1.84 MB
|
130
|
+
|
131
|
+
Profile data in ms:
|
132
|
+
|
133
|
+
com.android.chrome/org.chromium.chrome.browser.firstrun.FirstRunActivityStaging/android.view.ViewRootImpl@6b40547 (visibility=0)
|
134
|
+
Stats since: 9656484850794ns
|
135
|
+
Total frames rendered: 3
|
136
|
+
Janky frames: 2 (66.67%)
|
137
|
+
90th percentile: 101ms
|
138
|
+
95th percentile: 101ms
|
139
|
+
99th percentile: 101ms
|
140
|
+
Number Missed Vsync: 2
|
141
|
+
Number High input latency: 0
|
142
|
+
Number Slow UI thread: 2
|
143
|
+
Number Slow bitmap uploads: 0
|
144
|
+
Number Slow issue draw commands: 1
|
145
|
+
|
146
|
+
View hierarchy:
|
147
|
+
|
148
|
+
com.android.chrome/org.chromium.chrome.browser.firstrun.FirstRunActivityStaging/android.view.ViewRootImpl@6b40547
|
149
|
+
21 views, 31.36 kB of display lists
|
150
|
+
|
151
|
+
|
152
|
+
Total ViewRootImpl: 1
|
153
|
+
Total Views: 21
|
154
|
+
Total DisplayList: 31.36 kB
|
155
|
+
EOS
|
156
|
+
|
94
157
|
class GfxinfoTest < Test::Unit::TestCase
|
95
158
|
|
96
159
|
def setup
|
@@ -112,10 +175,16 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
112
175
|
end
|
113
176
|
|
114
177
|
def test_dump_gfxinfo_usage
|
115
|
-
expected = %w(41 views, 1.36 kB of display lists, 191 frames rendered
|
178
|
+
expected = %w(654464 bytes, 0.62 MB 41 views, 1.36 kB of display lists, 191 frames rendered)
|
179
|
+
|
116
180
|
assert_equal(expected, @gfx.dump_gfxinfo_usage(SAMPLE_GFXINFO))
|
117
181
|
end
|
118
182
|
|
183
|
+
def test_dump_gfxinfo_usage_for_API23
|
184
|
+
expected = %w(1926852 bytes, 1.84 MB 21 views, 31.36 kB of display lists)
|
185
|
+
assert_equal(expected, @gfx.dump_gfxinfo_usage(SAMPLE_GFXINFO_6))
|
186
|
+
end
|
187
|
+
|
119
188
|
def test_push_current_time
|
120
189
|
assert_equal(@gfx.merge_current_time({}).length, 1)
|
121
190
|
end
|
@@ -130,7 +199,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
130
199
|
end
|
131
200
|
|
132
201
|
def test_transfer_from_hash_correct_to_json
|
133
|
-
dummy_array = %w(465 views, 38.00 kB of display lists,
|
202
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
134
203
|
|
135
204
|
@gfx.store_gfxinfo_usage(dummy_array)
|
136
205
|
expected_json = "[{\"view\":465,\"display_lists_kb\":38.0,\"frames_rendered\":354," +
|
@@ -139,7 +208,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
139
208
|
end
|
140
209
|
|
141
210
|
def test_convert_to_google_data_api_format_gfx_one
|
142
|
-
dummy_array = %w(465 views, 38.00 kB of display lists, 354 frames rendered
|
211
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
143
212
|
|
144
213
|
@gfx.store_gfxinfo_usage(dummy_array)
|
145
214
|
expected_json = "{\"cols\":[{\"label\":\"time\",\"type\":\"string\"},{\"label\":\"view\",\"type\":\"number\"}," +
|
@@ -149,7 +218,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
149
218
|
end
|
150
219
|
|
151
220
|
def test_convert_to_google_data_api_format_mem_one
|
152
|
-
dummy_array = %w(465 views, 38.00 kB of display lists, 354 frames rendered
|
221
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
153
222
|
|
154
223
|
@gfx.store_gfxinfo_usage(dummy_array)
|
155
224
|
expected_json = "{\"cols\":[{\"label\":\"time\",\"type\":\"string\"}," +
|
@@ -159,7 +228,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
159
228
|
end
|
160
229
|
|
161
230
|
def test_convert_to_google_data_api_format_frame_one
|
162
|
-
dummy_array = %w(465 views, 38.00 kB of display lists, 354 frames rendered
|
231
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
163
232
|
|
164
233
|
@gfx.store_gfxinfo_usage(dummy_array)
|
165
234
|
expected_json = "{\"cols\":[{\"label\":\"time\",\"type\":\"string\"}," +
|
@@ -169,7 +238,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
169
238
|
end
|
170
239
|
|
171
240
|
def test_convert_to_google_data_api_format_gfx_many
|
172
|
-
dummy_array = %w(465 views, 38.00 kB of display lists, 354 frames rendered
|
241
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
173
242
|
|
174
243
|
@gfx.store_gfxinfo_usage(dummy_array)
|
175
244
|
@gfx.store_gfxinfo_usage(dummy_array)
|
@@ -181,7 +250,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
181
250
|
end
|
182
251
|
|
183
252
|
def test_convert_to_google_data_api_format_mem_many
|
184
|
-
dummy_array = %w(465 views, 38.00 kB of display lists, 354 frames rendered
|
253
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
185
254
|
|
186
255
|
@gfx.store_gfxinfo_usage(dummy_array)
|
187
256
|
@gfx.store_gfxinfo_usage(dummy_array)
|
@@ -192,7 +261,7 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
192
261
|
end
|
193
262
|
|
194
263
|
def test_convert_to_google_data_api_format_frame_many
|
195
|
-
dummy_array = %w(465 views, 38.00 kB of display lists, 354 frames rendered
|
264
|
+
dummy_array = %w(5781894 bytes, 5.51 MB 465 views, 38.00 kB of display lists, 354 frames rendered 13:43:32.556)
|
196
265
|
|
197
266
|
@gfx.store_gfxinfo_usage(dummy_array)
|
198
267
|
@gfx.store_gfxinfo_usage(dummy_array)
|
@@ -201,6 +270,4 @@ class GfxinfoTest < Test::Unit::TestCase
|
|
201
270
|
"{\"v\":354}]},{\"c\":[{\"v\":\"#{@gfx.gfxinfo_usage[1][:time]}\"},{\"v\":354}]}]}"
|
202
271
|
assert_equal(@gfx.export_as_google_api_format_frame(@gfx.gfxinfo_usage), expected_json)
|
203
272
|
end
|
204
|
-
|
205
|
-
|
206
273
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: droid-monitor
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Kazuaki MATSUO
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2016-01-10 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: faml
|
@@ -89,6 +89,7 @@ extensions: []
|
|
89
89
|
extra_rdoc_files: []
|
90
90
|
files:
|
91
91
|
- ".gitignore"
|
92
|
+
- ".travis.yml"
|
92
93
|
- Gemfile
|
93
94
|
- LICENSE.txt
|
94
95
|
- README.md
|
@@ -145,7 +146,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
145
146
|
version: '0'
|
146
147
|
requirements: []
|
147
148
|
rubyforge_project:
|
148
|
-
rubygems_version: 2.
|
149
|
+
rubygems_version: 2.5.1
|
149
150
|
signing_key:
|
150
151
|
specification_version: 4
|
151
152
|
summary: Monitoring Android cpu or memory usage and create their simple graph with
|