edouard-metric_fu 1.1.1 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (56) hide show
  1. data/HISTORY +41 -0
  2. data/TODO +0 -4
  3. data/lib/base/base_template.rb +1 -2
  4. data/lib/base/configuration.rb +5 -33
  5. data/lib/base/generator.rb +7 -0
  6. data/lib/base/graph.rb +5 -3
  7. data/lib/base/report.rb +3 -3
  8. data/lib/generators/churn.rb +0 -1
  9. data/lib/generators/flay.rb +2 -2
  10. data/lib/generators/flog.rb +34 -7
  11. data/lib/generators/rcov.rb +2 -2
  12. data/lib/generators/reek.rb +28 -1
  13. data/lib/generators/roodi.rb +2 -1
  14. data/lib/generators/saikuro.rb +3 -7
  15. data/lib/graphs/engines/bluff.rb +86 -0
  16. data/lib/graphs/engines/gchart.rb +119 -0
  17. data/lib/graphs/flay_grapher.rb +6 -20
  18. data/lib/graphs/flog_grapher.rb +25 -22
  19. data/lib/graphs/grapher.rb +11 -0
  20. data/lib/graphs/rcov_grapher.rb +2 -16
  21. data/lib/graphs/reek_grapher.rb +12 -24
  22. data/lib/graphs/roodi_grapher.rb +6 -20
  23. data/lib/metric_fu.rb +13 -6
  24. data/lib/templates/awesome/awesome_template.rb +7 -0
  25. data/lib/templates/awesome/css/buttons.css +82 -0
  26. data/lib/templates/awesome/{default.css → css/default.css} +16 -0
  27. data/lib/templates/awesome/css/integrity.css +335 -0
  28. data/lib/templates/awesome/css/reset.css +7 -0
  29. data/lib/templates/awesome/flay.html.erb +7 -1
  30. data/lib/templates/awesome/flog.html.erb +8 -1
  31. data/lib/templates/awesome/layout.html.erb +7 -4
  32. data/lib/templates/awesome/rcov.html.erb +7 -1
  33. data/lib/templates/awesome/reek.html.erb +7 -1
  34. data/lib/templates/awesome/roodi.html.erb +7 -1
  35. data/lib/templates/javascripts/bluff-min.js +1 -0
  36. data/lib/templates/javascripts/excanvas.js +35 -0
  37. data/lib/templates/javascripts/js-class.js +1 -0
  38. data/spec/base/configuration_spec.rb +18 -52
  39. data/spec/base/generator_spec.rb +61 -1
  40. data/spec/base/graph_spec.rb +24 -0
  41. data/spec/generators/flog_spec.rb +19 -0
  42. data/spec/generators/reek_spec.rb +66 -0
  43. data/spec/graphs/engines/bluff_spec.rb +15 -0
  44. data/spec/graphs/engines/gchart_spec.rb +14 -0
  45. data/spec/graphs/flay_grapher_spec.rb +37 -0
  46. data/spec/graphs/flog_grapher_spec.rb +40 -10
  47. data/spec/graphs/rcov_grapher_spec.rb +37 -0
  48. data/spec/graphs/reek_grapher_spec.rb +46 -0
  49. data/spec/graphs/roodi_grapher_spec.rb +37 -0
  50. data/spec/resources/saikuro_sfiles/thing.rb_cyclo.html +1 -0
  51. data/spec/resources/yml/20090630.yml +7844 -0
  52. data/spec/spec_helper.rb +1 -23
  53. data/tasks/metric_fu.rake +1 -1
  54. metadata +34 -16
  55. data/vendor/_fonts/monaco.ttf +0 -0
  56. data/vendor/saikuro/saikuro.rb +0 -1214
@@ -73,3 +73,19 @@ table td.score {
73
73
  overflow: auto;
74
74
  font-size: 50%;
75
75
  }
76
+
77
+ .bluff-tooltip {
78
+ background: #fff;
79
+ border: 1px solid #d1edf5;
80
+ padding: 8px 8px 6px;
81
+ }
82
+ .bluff-tooltip .color {
83
+ display: block;
84
+ height: 4px;
85
+ width: 30px;
86
+ margin: 0 0 4px;
87
+ overflow: hidden;
88
+ }
89
+ .bluff-tooltip .data {
90
+ font-weight: bold;
91
+ }
@@ -0,0 +1,335 @@
1
+ html {
2
+ background-color: #e0e0e0; }
3
+
4
+ body {
5
+ font-size: 100%;
6
+ font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
7
+ color: #333333; }
8
+
9
+ a {
10
+ color: #ed1556;
11
+ text-decoration: none; }
12
+ a:hover {
13
+ color: #ffffff;
14
+ background-color: #ed1556; }
15
+
16
+ #header, #content, #footer {
17
+ margin: 0 auto;
18
+ background: #eeeeee;
19
+ padding: 0 2em;
20
+ z-index: 0;
21
+ position: relative;
22
+ font-size: 1em; }
23
+
24
+ #header {
25
+ background: #ffffff; }
26
+ #header h1 {
27
+ font-weight: bold;
28
+ font-size: 1.5em; }
29
+ #header address.watermark {
30
+ position: absolute;
31
+ font-weight: bold;
32
+ right: 3em;
33
+ top: 0;
34
+ font-size: .75em;
35
+ color: #cccccc; }
36
+ #header address.watermark a {
37
+ color: #cccccc;
38
+ font-weight: bold;
39
+ font-size: 2em; }
40
+ #header address.watermark a:hover {
41
+ background: transparent;
42
+ color: #aaaaaa; }
43
+
44
+ #content {
45
+ padding-top: 1em;
46
+ padding-bottom: 2em; }
47
+ #content strong {
48
+ font-weight: bold; }
49
+ #content em {
50
+ font-style: italic; }
51
+ #content h1, #content h2, #content h3, #content h4, #content h5, #content h6 {
52
+ color: #4e4e4e; }
53
+ #content h1 {
54
+ font-size: 2em;
55
+ font-weight: bold;
56
+ margin-bottom: .75em;
57
+ padding: .25em 0;
58
+ line-height: 1.2;
59
+ border-bottom: 1px solid #c0c0c0; }
60
+ #content h2 {
61
+ font-weight: bold;
62
+ font-size: 1.5em;
63
+ margin: 1em 0 .2em; }
64
+ #content h3 {
65
+ font-weight: bold;
66
+ font-size: 1.25em;
67
+ margin: .25em 0; }
68
+ #content h4, #content h5, #content h6 {
69
+ font-weight: bold;
70
+ margin-top: .5em; }
71
+ #content code, #content pre, #content textarea, #content input {
72
+ font-family: Monaco, Deja Vu Sans Mono, Inconsolata, Consolas, monospace; }
73
+ #content form p {
74
+ margin-top: 1em;
75
+ position: relative; }
76
+ #content form p.checkbox label {
77
+ margin-top: 0 !important; }
78
+ #content form input.text, #content form textarea {
79
+ width: 30em;
80
+ padding: .2em .4em;
81
+ color: #4e4e4e; }
82
+ #content form input.text {
83
+ height: 1.4em; }
84
+ #content form label {
85
+ float: left;
86
+ display: block;
87
+ margin-top: .5em;
88
+ width: 8em;
89
+ margin-right: .75em; }
90
+ #content form .with_errors label {
91
+ background: red;
92
+ color: white;
93
+ position: relative;
94
+ top: -.7em; }
95
+ #content form .with_errors.required label {
96
+ position: static;
97
+ margin-right: .25em;
98
+ padding: 0 .2em; }
99
+ #content form .with_errors input, #content form .with_errors textarea {
100
+ border: 2px solid #f22;
101
+ background: #fee;
102
+ color: #222222; }
103
+ #content form .required label {
104
+ float: none;
105
+ display: block;
106
+ width: auto;
107
+ position: relative;
108
+ font-weight: bold;
109
+ margin-top: 1em;
110
+ text-indent: -.65em; }
111
+ #content form .required label:before {
112
+ content: "* ";
113
+ color: #ed1556; }
114
+ #content form .required input.text {
115
+ width: 25.6em;
116
+ font-size: 24px;
117
+ font-weight: bold; }
118
+ #content form .normal {
119
+ margin-top: 2em; }
120
+ #content form h2.notifier label {
121
+ float: none;
122
+ width: auto;
123
+ margin-right: 0; }
124
+ #content form h2.notifier label .warning {
125
+ font-size: .5em;
126
+ font-weight: normal;
127
+ color: #999999; }
128
+ #content form fieldset {
129
+ padding-bottom: 1em;
130
+ margin-left: 1.35em;
131
+ border-bottom: 1px solid #c0c0c0;
132
+ margin-bottom: 1em; }
133
+ #content form fieldset h3 {
134
+ margin-top: 1em;
135
+ margin-bottom: 0; }
136
+ #content form fieldset p.normal {
137
+ margin-top: 1em; }
138
+ #content form fieldset p label {
139
+ width: 6.7em; }
140
+ #content form p.submit {
141
+ margin-top: 2em; }
142
+ #content form p.submit:after {
143
+ display: block;
144
+ clear: both;
145
+ float: none;
146
+ content: ".";
147
+ text-indent: -9999em;
148
+ text-align: left; }
149
+ #content form p.submit.destroy button, #content form p.submit.manual-build button {
150
+ float: none;
151
+ display: inline; }
152
+ #content form p.submit.manual-build button {
153
+ margin-right: 0; }
154
+ #content #build form, #content #last_build form {
155
+ font-size: .75em; }
156
+ #content #build form p.submit, #content #last_build form p.submit {
157
+ margin: 0;
158
+ padding: 0;
159
+ position: absolute;
160
+ right: .5em;
161
+ top: 1.25em; }
162
+ #content .blank_slate p, #content .error p {
163
+ position: relative;
164
+ top: .3em; }
165
+ #content .blank_slate h1, #content .error h1 {
166
+ border-width: 0;
167
+ margin: 0;
168
+ padding: 0; }
169
+ #content .blank_slate h1 button, #content .error h1 button {
170
+ float: none;
171
+ border: 0 none;
172
+ background: transparent;
173
+ display: inline;
174
+ color: #ed1556;
175
+ padding: 0.25em 0;
176
+ margin: 0; }
177
+ #content .blank_slate h1 button:hover, #content .error h1 button:hover {
178
+ background: #ed1556;
179
+ color: #ffffff; }
180
+ #content .error dt {
181
+ margin-top: 1.4em;
182
+ margin-bottom: .3em;
183
+ font-size: 1.75em;
184
+ font-family: Georgia, Times New Roman, serif; }
185
+ #content .error dd {
186
+ line-height: 1.4; }
187
+ #content .error .backtrace {
188
+ margin: 1em 0;
189
+ overflow: scroll;
190
+ height: 30em;
191
+ border: 1px solid #c0c0c0;
192
+ line-height: 1.6; }
193
+ #content #projects {
194
+ margin: 1em 0 2em;
195
+ border-top: 1px solid #c0c0c0; }
196
+ #content #projects li {
197
+ position: relative;
198
+ border-bottom: 1px solid #c0c0c0; }
199
+ #content #projects li.odd {
200
+ background: #e6e6e6; }
201
+ #content #projects li.building {
202
+ background: transparent url(/spinner.gif) no-repeat scroll right; }
203
+ #content #projects li a {
204
+ font-size: 2em;
205
+ padding: .25em;
206
+ line-height: 1.2;
207
+ font-weight: bold;
208
+ display: block; }
209
+ #content #projects li a.success {
210
+ color: #337022; }
211
+ #content #projects li a.failed {
212
+ color: #ff1100; }
213
+ #content #projects li .meta {
214
+ position: absolute;
215
+ right: .6em;
216
+ top: 1.5em;
217
+ font-size: 0.8em;
218
+ color: #999999;
219
+ text-align: right; }
220
+ #content #projects li.building .meta {
221
+ right: 1.6em; }
222
+ #content #projects li.success .meta {
223
+ color: #337022; }
224
+ #content #projects li.failed .meta {
225
+ color: #ff1100; }
226
+ #content #previous_builds li a {
227
+ display: block;
228
+ padding: .25em;
229
+ margin-bottom: .25em;
230
+ border-width: 1px;
231
+ border-style: solid; }
232
+ #content #previous_builds li a strong {
233
+ font-size: 1.3em; }
234
+ #content #previous_builds li a .attribution {
235
+ font-size: .9em; }
236
+ #content #projects li.success a, #content #previous_builds li.success a {
237
+ background-color: #bbf8aa;
238
+ border-color: #99d688;
239
+ color: #337022; }
240
+ #content #projects li.success a .attribution, #content #previous_builds li.success a .attribution {
241
+ color: #77b466; }
242
+ #content #projects li.success a:hover, #content #previous_builds li.success a:hover {
243
+ background-color: #ddffcc; }
244
+ #content #projects li.failed a, #content #previous_builds li.failed a {
245
+ background-color: #ffbbaa;
246
+ border-color: #dd9988;
247
+ color: #ff1100; }
248
+ #content #projects li.failed a .attribution, #content #previous_builds li.failed a .attribution {
249
+ color: #bb7766; }
250
+ #content #projects li.failed a:hover, #content #previous_builds li.failed a:hover {
251
+ background-color: #ffddcc; }
252
+ #content #build, #content #last_build {
253
+ position: relative; }
254
+ #content #build h1, #content #build blockquote, #content #last_build h1, #content #last_build blockquote {
255
+ border-width: 0 1px;
256
+ border-style: solid; }
257
+ #content #build h1, #content #last_build h1 {
258
+ border-top-width: 1px; }
259
+ #content #build blockquote, #content #last_build blockquote {
260
+ bottom-bottom-width: 1px;
261
+ line-height: 1.4; }
262
+ #content #build.success h1, #content #build.success blockquote, #content #last_build.success h1, #content #last_build.success blockquote {
263
+ background-color: #bbf8aa;
264
+ border-color: #99d688 #ccffbb #ccffbb #99d688; }
265
+ #content #build.success h1, #content #last_build.success h1 {
266
+ color: #337022; }
267
+ #content #build.success .meta, #content #last_build.success .meta {
268
+ color: #77b466; }
269
+ #content #build.failed h1, #content #build.failed blockquote, #content #last_build.failed h1, #content #last_build.failed blockquote {
270
+ background-color: #ffbbaa;
271
+ border-color: #dd9988 #ffccbb #ffccbb #dd9988; }
272
+ #content #build.failed h1, #content #last_build.failed h1 {
273
+ color: #ff1100; }
274
+ #content #build.failed .meta, #content #last_build.failed .meta {
275
+ color: #bb7766; }
276
+ #content #build h1, #content #last_build h1 {
277
+ margin-top: .5em;
278
+ margin-bottom: 0;
279
+ padding: .25em;
280
+ color: #337022; }
281
+ #content #build blockquote, #content #last_build blockquote {
282
+ padding: .75em;
283
+ margin-bottom: 2em; }
284
+ #content #build blockquote .meta, #content #last_build blockquote .meta {
285
+ margin-top: 1em;
286
+ display: block;
287
+ font-size: .9em; }
288
+ #content #build pre.output, #content #last_build pre.output {
289
+ background: #111;
290
+ color: #fff;
291
+ padding: .5em;
292
+ overflow: auto;
293
+ max-height: 50em;
294
+ font-size: .825em; }
295
+ #content #build pre.output .color30, #content #last_build pre.output .color30 {
296
+ color: #333; }
297
+ #content #build pre.output .color31, #content #last_build pre.output .color31 {
298
+ color: #e33; }
299
+ #content #build pre.output .color32, #content #last_build pre.output .color32 {
300
+ color: #3e3; }
301
+ #content #build pre.output .color33, #content #last_build pre.output .color33 {
302
+ color: #ee3; }
303
+ #content #build pre.output .color34, #content #last_build pre.output .color34 {
304
+ color: #33e; }
305
+ #content #build pre.output .color35, #content #last_build pre.output .color35 {
306
+ color: #e3e; }
307
+ #content #build pre.output .color36, #content #last_build pre.output .color36 {
308
+ color: #3ee; }
309
+ #content #build pre.output .color37, #content #last_build pre.output .color37 {
310
+ color: #fff; }
311
+ #content #push_path {
312
+ display: block;
313
+ margin-top: 1em;
314
+ margin-left: 2em; }
315
+
316
+ a.success {
317
+ color: #bbf8aa; }
318
+ a.success:hover {
319
+ background-color: #bbf8aa;
320
+ color: white; }
321
+ a.failed {
322
+ color: #ffbbaa; }
323
+ a.failed:hover {
324
+ background-color: #ffbbaa;
325
+ color: white; }
326
+
327
+ #footer {
328
+ padding: 1.5em 2.5em;
329
+ border-top: 1px solid #ccc;
330
+ font-size: .8em;
331
+ color: #666;
332
+ text-align: right; }
333
+ #footer strong {
334
+ font-weight: bold; }
335
+
@@ -0,0 +1,7 @@
1
+ /*
2
+ Copyright (c) 2008, Yahoo! Inc. All rights reserved.
3
+ Code licensed under the BSD License:
4
+ http://developer.yahoo.net/yui/license.txt
5
+ version: 2.5.2
6
+ */
7
+ html{color:#000;background:#FFF;}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0;}table{border-collapse:collapse;border-spacing:0;}fieldset,img{border:0;}address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}li{list-style:none;}caption,th{text-align:left;}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}q:before,q:after{content:'';}abbr,acronym {border:0;font-variant:normal;}sup {vertical-align:text-top;}sub {vertical-align:text-bottom;}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}input,textarea,select{*font-size:100%;}legend{color:#000;}
@@ -2,7 +2,13 @@
2
2
 
3
3
  <p><a href='http://ruby.sadi.st/Flay.html'>Flay</a> analyzes ruby code for structural similarities.</p>
4
4
 
5
- <img src="flay.png?<%= Time.now %>">
5
+ <% graph_name = 'flay' %>
6
+ <% if MetricFu.configuration.graph_engine == :gchart %>
7
+ <img src="<%= graph_name %>.png?<%= Time.now.to_i %>" />
8
+ <% else %>
9
+ <canvas id="graph"></canvas>
10
+ <script language="javascript" src="<%= graph_name %>.js?<%= Time.now.to_i %>" type="text/javascript"></script>
11
+ <% end %>
6
12
 
7
13
  <h4>Total Score (lower is better): <%= @flay[:total_score] %></h4>
8
14
 
@@ -1,7 +1,13 @@
1
1
  <h3>Flog Results</h3>
2
2
  <p><a href='http://ruby.sadi.st/Flog.html'>Flog</a> measures code complexity.</p>
3
3
 
4
- <img src="flog.png?<%= Time.now %>">
4
+ <% graph_name = 'flog' %>
5
+ <% if MetricFu.configuration.graph_engine == :gchart %>
6
+ <img src="<%= graph_name %>.png?<%= Time.now.to_i %>" />
7
+ <% else %>
8
+ <canvas id="graph"></canvas>
9
+ <script language="javascript" src="<%= graph_name %>.js?<%= Time.now.to_i %>" type="text/javascript"></script>
10
+ <% end %>
5
11
 
6
12
  <h2>Total Flog score for all methods: <%= @flog[:total]%></h2>
7
13
  <h2>Average Flog score for all methods: <%= @flog[:average]%></h2>
@@ -29,6 +35,7 @@
29
35
  <h2 id="<%= page[:path].gsub(/[^a-z]+/, '_') %>"><%= link_to_filename page[:path] %></h2>
30
36
  <% page[:scanned_methods].each do |sm| %>
31
37
  <p><%= sm[:name] %></p>
38
+ <p>Total Score: <%=sm[:score]%></p>
32
39
  <table>
33
40
  <tr>
34
41
  <th>Score</th>
@@ -4,13 +4,16 @@
4
4
  <meta content='text/html; charset=utf-8' http-equiv='Content-Type' />
5
5
  <meta content='en' http-equiv='Content-Language' />
6
6
  <title>metrics</title>
7
- <link href='/reset.css' rel='stylesheet' type='text/css' />
8
- <link href='/buttons.css' rel='stylesheet' type='text/css' />
9
- <link href='/integrity.css' rel='stylesheet' type='text/css' />
10
7
  <style>
11
- <%= inline_css("default.css") %>
8
+ <%= inline_css("css/reset.css") %>
9
+ <%= inline_css("css/buttons.css") %>
10
+ <%= inline_css("css/integrity.css") %>
11
+ <%= inline_css("css/default.css") %>
12
12
  </style>
13
13
  <link REL="SHORTCUT ICON" HREF="/favicon.ico">
14
+ <script language="javascript" src="js-class.js" type="text/javascript"></script>
15
+ <script language="javascript" src="bluff-min.js" type="text/javascript"></script>
16
+ <script language="javascript" src="excanvas.js" type="text/javascript"></script>
14
17
  </head>
15
18
  <body>
16
19
  <div id='header'>
@@ -2,7 +2,13 @@
2
2
 
3
3
  <p>C0 code coverage information.</p>
4
4
 
5
- <img src="rcov.png?<%= Time.now %>">
5
+ <% graph_name = 'rcov' %>
6
+ <% if MetricFu.configuration.graph_engine == :gchart %>
7
+ <img src="<%= graph_name %>.png?<%= Time.now.to_i %>" />
8
+ <% else %>
9
+ <canvas id="graph"></canvas>
10
+ <script language="javascript" src="<%= graph_name %>.js?<%= Time.now.to_i %>" type="text/javascript"></script>
11
+ <% end %>
6
12
 
7
13
  <p>Total Coverage: <%= @rcov.delete(:global_percent_run) %>% </p>
8
14
  <table>
@@ -2,7 +2,13 @@
2
2
 
3
3
  <p><a href="http://reek.rubyforge.org/">Reek</a> detects common code smells in ruby code.</p>
4
4
 
5
- <img src="reek.png?<%= Time.now %>">
5
+ <% graph_name = 'reek' %>
6
+ <% if MetricFu.configuration.graph_engine == :gchart %>
7
+ <img src="<%= graph_name %>.png?<%= Time.now.to_i %>" />
8
+ <% else %>
9
+ <canvas id="graph"></canvas>
10
+ <script language="javascript" src="<%= graph_name %>.js?<%= Time.now.to_i %>" type="text/javascript"></script>
11
+ <% end %>
6
12
 
7
13
  <table>
8
14
  <tr>