vizi_translator 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (73) hide show
  1. data/Rakefile +44 -0
  2. data/build_gem1.bat +1 -0
  3. data/build_gem2.bat +1 -0
  4. data/build_gem3.bat +1 -0
  5. data/build_gem4.bat +1 -0
  6. data/data/index.md +17 -0
  7. data/data/testfile.txt +4 -0
  8. data/doc/Object.html +200 -0
  9. data/doc/ParserTest.html +268 -0
  10. data/doc/README_rdoc.html +128 -0
  11. data/doc/Rakefile.html +148 -0
  12. data/doc/Visit.html +487 -0
  13. data/doc/VisitList.html +385 -0
  14. data/doc/Vizi/LogFormat.html +377 -0
  15. data/doc/Vizi/LogParser.html +551 -0
  16. data/doc/Vizi/Translator.html +302 -0
  17. data/doc/Vizi/UnSupportedLanguage.html +212 -0
  18. data/doc/Vizi/Visit.html +487 -0
  19. data/doc/Vizi/VisitList.html +386 -0
  20. data/doc/Vizi.html +159 -0
  21. data/doc/ViziLogFormat.html +382 -0
  22. data/doc/ViziLogParser.html +551 -0
  23. data/doc/created.rid +4 -0
  24. data/doc/docs/Whois_Documentation.doc +0 -0
  25. data/doc/formats/apache-custom-log.pdf +0 -0
  26. data/doc/formats/apache.rtf +238 -0
  27. data/doc/formats/format-descriptions.xls +0 -0
  28. data/doc/formats/w3c-extended.pdf +0 -0
  29. data/doc/formats/w3c-extended.rtf +135 -0
  30. data/doc/images/brick.png +0 -0
  31. data/doc/images/brick_link.png +0 -0
  32. data/doc/images/bug.png +0 -0
  33. data/doc/images/bullet_black.png +0 -0
  34. data/doc/images/bullet_toggle_minus.png +0 -0
  35. data/doc/images/bullet_toggle_plus.png +0 -0
  36. data/doc/images/date.png +0 -0
  37. data/doc/images/find.png +0 -0
  38. data/doc/images/loadingAnimation.gif +0 -0
  39. data/doc/images/macFFBgHack.png +0 -0
  40. data/doc/images/package.png +0 -0
  41. data/doc/images/page_green.png +0 -0
  42. data/doc/images/page_white_text.png +0 -0
  43. data/doc/images/page_white_width.png +0 -0
  44. data/doc/images/plugin.png +0 -0
  45. data/doc/images/ruby.png +0 -0
  46. data/doc/images/tag_green.png +0 -0
  47. data/doc/images/wrench.png +0 -0
  48. data/doc/images/wrench_orange.png +0 -0
  49. data/doc/images/zoom.png +0 -0
  50. data/doc/index.html +68 -0
  51. data/doc/js/darkfish.js +116 -0
  52. data/doc/js/jquery.js +32 -0
  53. data/doc/js/quicksearch.js +114 -0
  54. data/doc/js/thickbox-compressed.js +10 -0
  55. data/doc/lib/vizi/parser_rb.html +63 -0
  56. data/doc/lib/vizi/vizi_tracker_rb.html +63 -0
  57. data/doc/lib/vizi/vizi_translator.html +104 -0
  58. data/doc/lib/vizi/vizi_translator_rb.html +69 -0
  59. data/doc/lib/vizi_log_parser_rb.html +56 -0
  60. data/doc/lib/vizi_tracker_rb.html +56 -0
  61. data/doc/lib/vizi_translator_rb.html +54 -0
  62. data/doc/rdoc.css +759 -0
  63. data/doc/test/parser_test_rb.html +54 -0
  64. data/doc/test/test_helper_rb.html +56 -0
  65. data/doc/testit_rb.html +63 -0
  66. data/geany_run_script.bat +6 -0
  67. data/lib/vizi/vizi_translator +11 -0
  68. data/lib/vizi/vizi_translator.rb +68 -0
  69. data/lib/vizi_translator.rb +5 -0
  70. data/log/system.log +1 -0
  71. data/testit.rb +51 -0
  72. data/vizi_translator.gemspec +17 -0
  73. metadata +122 -0
data/Rakefile ADDED
@@ -0,0 +1,44 @@
1
+ require 'rubygems'
2
+ require 'rake/gempackagetask'
3
+ require 'rake/rdoctask'
4
+ require 'rake/testtask'
5
+
6
+ spec = Gem::Specification.new do |s|
7
+ s.name = "http-log-parser"
8
+ s.version = "0.0.2"
9
+ s.author = "Torsten Curdt"
10
+ s.email = "tcurdt at vafer.org"
11
+ s.homepage = "http://github.com/tcurdt/http-log-parser"
12
+ s.description = "HTTP log file parser"
13
+ s.summary = "A package for parsing web server logs."
14
+
15
+ s.platform = Gem::Platform::RUBY
16
+ s.has_rdoc = true
17
+ s.extra_rdoc_files = ["README.rdoc"]
18
+
19
+ s.require_path = "lib"
20
+ s.files = %w(README.rdoc Rakefile) + Dir.glob("lib/**/*")
21
+ end
22
+
23
+ Rake::GemPackageTask.new(spec) do |pkg|
24
+ pkg.need_tar = true
25
+ end
26
+
27
+ Rake::RDocTask.new(:rdoc) do |rdoc|
28
+ rdoc.rdoc_dir = 'rdoc'
29
+ rdoc.title = 'HttpLogParser'
30
+ rdoc.options << '--line-numbers' << '--inline-source'
31
+ rdoc.rdoc_files.include('README')
32
+ rdoc.rdoc_files.include('lib/**/*.rb')
33
+ end
34
+
35
+ Rake::TestTask.new do |t|
36
+ t.libs << 'test'
37
+ t.test_files = FileList["test/**/*_test.rb"]
38
+ t.verbose = true
39
+ end
40
+
41
+ task :default => "pkg/#{spec.name}-#{spec.version}.gem" do
42
+ puts "generated latest version"
43
+ end
44
+
data/build_gem1.bat ADDED
@@ -0,0 +1 @@
1
+ gem uninstall vizi_translator
data/build_gem2.bat ADDED
@@ -0,0 +1 @@
1
+ gem build vizi_translator.gemspec
data/build_gem3.bat ADDED
@@ -0,0 +1 @@
1
+ gem install -l vizi_translator-0.1.0.gem
data/build_gem4.bat ADDED
@@ -0,0 +1 @@
1
+ rake rdoc
data/data/index.md ADDED
@@ -0,0 +1,17 @@
1
+ ![Visitor tracking](/images/visitors.jpg)
2
+ # Welcome to our new website
3
+ If you are a returning visit to our site, you will see many changes.
4
+
5
+ The first change you will see is a new layout that is a result of the move to Ramaze language.
6
+
7
+ If you are not familiar with Ramaze, you can find more information at [Ramaze web site](http://ramaze.net).
8
+
9
+ Another change that you will discover is the use of Google docs spreadsheets to store the results of the weekly production analysis.
10
+
11
+ The Google spreadsheets provide more capabilities including visitor mapping and additional pivot analysis.
12
+
13
+ Here is a sample map that is available with the Google tool.
14
+
15
+ ![Sample world map](/images/world_map.jpg)
16
+
17
+ ...
data/data/testfile.txt ADDED
@@ -0,0 +1,4 @@
1
+ 79.142.69.69
2
+ 66.119.167.210
3
+ 219.91.245.192
4
+ 2001:4860:b002::68
data/doc/Object.html ADDED
@@ -0,0 +1,200 @@
1
+ <?xml version="1.0" encoding="IBM437"?>
2
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
3
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
4
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
5
+ <head>
6
+ <meta content="text/html; charset=IBM437" http-equiv="Content-Type" />
7
+
8
+ <title>Class: Object</title>
9
+
10
+ <link rel="stylesheet" href="./rdoc.css" type="text/css" media="screen" />
11
+
12
+ <script src="./js/jquery.js" type="text/javascript" charset="utf-8"></script>
13
+ <script src="./js/thickbox-compressed.js" type="text/javascript" charset="utf-8"></script>
14
+ <script src="./js/quicksearch.js" type="text/javascript" charset="utf-8"></script>
15
+ <script src="./js/darkfish.js" type="text/javascript" charset="utf-8"></script>
16
+
17
+ </head>
18
+ <body id="top" class="class">
19
+
20
+ <div id="metadata">
21
+ <div id="home-metadata">
22
+ <div id="home-section" class="section">
23
+ <h3 class="section-header">
24
+ <a href="./index.html">Home</a>
25
+ <a href="./index.html#classes">Classes</a>
26
+ <a href="./index.html#methods">Methods</a>
27
+ </h3>
28
+ </div>
29
+ </div>
30
+
31
+ <div id="file-metadata">
32
+ <div id="file-list-section" class="section">
33
+ <h3 class="section-header">In Files</h3>
34
+ <div class="section-body">
35
+ <ul>
36
+
37
+ <li><a href="./testit_rb.html?TB_iframe=true&amp;height=550&amp;width=785"
38
+ class="thickbox" title="testit.rb">testit.rb</a></li>
39
+
40
+ </ul>
41
+ </div>
42
+ </div>
43
+
44
+
45
+ </div>
46
+
47
+ <div id="class-metadata">
48
+
49
+ <!-- Parent Class -->
50
+ <div id="parent-class-section" class="section">
51
+ <h3 class="section-header">Parent</h3>
52
+
53
+ <p class="link"></p>
54
+
55
+ </div>
56
+
57
+
58
+
59
+
60
+
61
+
62
+
63
+ <!-- Method Quickref -->
64
+ <div id="method-list-section" class="section">
65
+ <h3 class="section-header">Methods</h3>
66
+ <ul class="link-list">
67
+
68
+ <li><a href="#method-i-find_visit_in_list">#find_visit_in_list</a></li>
69
+
70
+ </ul>
71
+ </div>
72
+
73
+
74
+
75
+ </div>
76
+
77
+ <div id="project-metadata">
78
+
79
+
80
+ <div id="fileindex-section" class="section project-section">
81
+ <h3 class="section-header">Files</h3>
82
+ <ul>
83
+
84
+ <li class="file"><a href="./README_rdoc.html">README.rdoc</a></li>
85
+
86
+ <li class="file"><a href="./Rakefile.html">Rakefile</a></li>
87
+
88
+ </ul>
89
+ </div>
90
+
91
+
92
+ <div id="classindex-section" class="section project-section">
93
+ <h3 class="section-header">Class/Module Index
94
+ <span class="search-toggle"><img src="./images/find.png"
95
+ height="16" width="16" alt="[+]"
96
+ title="show/hide quicksearch" /></span></h3>
97
+ <form action="#" method="get" accept-charset="utf-8" class="initially-hidden">
98
+ <fieldset>
99
+ <legend>Quicksearch</legend>
100
+ <input type="text" name="quicksearch" value=""
101
+ class="quicksearch-field" />
102
+ </fieldset>
103
+ </form>
104
+
105
+ <ul class="link-list">
106
+
107
+ <li><a href="./Vizi.html">Vizi</a></li>
108
+
109
+ <li><a href="./Vizi/LogFormat.html">Vizi::LogFormat</a></li>
110
+
111
+ <li><a href="./Vizi/LogParser.html">Vizi::LogParser</a></li>
112
+
113
+ <li><a href="./Vizi/Visit.html">Vizi::Visit</a></li>
114
+
115
+ <li><a href="./Vizi/VisitList.html">Vizi::VisitList</a></li>
116
+
117
+ <li><a href="./Object.html">Object</a></li>
118
+
119
+ <li><a href="./ParserTest.html">ParserTest</a></li>
120
+
121
+ </ul>
122
+ <div id="no-class-search-results" style="display: none;">No matching classes.</div>
123
+ </div>
124
+
125
+
126
+ </div>
127
+ </div>
128
+
129
+ <div id="documentation">
130
+ <h1 class="class">Object</h1>
131
+
132
+ <div id="description" class="description">
133
+
134
+ </div><!-- description -->
135
+
136
+
137
+ <div id="5Buntitled-5D" class="documentation-section">
138
+
139
+
140
+
141
+
142
+
143
+
144
+
145
+
146
+ <!-- Methods -->
147
+
148
+ <div id="public-instance-method-details" class="method-section section">
149
+ <h3 class="section-header">Public Instance Methods</h3>
150
+
151
+
152
+ <div id="find_visit_in_list-method" class="method-detail ">
153
+ <a name="method-i-find_visit_in_list"></a>
154
+
155
+
156
+ <div class="method-heading">
157
+ <span class="method-name">find_visit_in_list</span><span
158
+ class="method-args">(ip)</span>
159
+ <span class="method-click-advice">click to toggle source</span>
160
+ </div>
161
+
162
+
163
+ <div class="method-description">
164
+
165
+
166
+
167
+
168
+
169
+ <div class="method-source-code" id="find_visit_in_list-source">
170
+ <pre>
171
+ <span class="ruby-comment"># File testit.rb, line 18</span>
172
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">find_visit_in_list</span>(<span class="ruby-identifier">ip</span>)
173
+ <span class="ruby-ivar">@visits</span>.<span class="ruby-identifier">detect</span> { <span class="ruby-operator">|</span><span class="ruby-identifier">visit</span><span class="ruby-operator">|</span> <span class="ruby-identifier">visit</span>.<span class="ruby-identifier">ip</span> = <span class="ruby-identifier">ip</span> }
174
+ <span class="ruby-keyword">end</span></pre>
175
+ </div><!-- find_visit_in_list-source -->
176
+
177
+ </div>
178
+
179
+
180
+
181
+
182
+ </div><!-- find_visit_in_list-method -->
183
+
184
+
185
+ </div><!-- public-instance-method-details -->
186
+
187
+ </div><!-- 5Buntitled-5D -->
188
+
189
+
190
+ </div><!-- documentation -->
191
+
192
+ <div id="validator-badges">
193
+ <p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
194
+ <p><small>Generated with the <a href="http://deveiate.org/projects/Darkfish-Rdoc/">Darkfish
195
+ Rdoc Generator</a> 2</small>.</p>
196
+ </div>
197
+
198
+ </body>
199
+ </html>
200
+
@@ -0,0 +1,268 @@
1
+ <?xml version="1.0" encoding="IBM437"?>
2
+ <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
3
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
4
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
5
+ <head>
6
+ <meta content="text/html; charset=IBM437" http-equiv="Content-Type" />
7
+
8
+ <title>Class: ParserTest</title>
9
+
10
+ <link rel="stylesheet" href="./rdoc.css" type="text/css" media="screen" />
11
+
12
+ <script src="./js/jquery.js" type="text/javascript" charset="utf-8"></script>
13
+ <script src="./js/thickbox-compressed.js" type="text/javascript" charset="utf-8"></script>
14
+ <script src="./js/quicksearch.js" type="text/javascript" charset="utf-8"></script>
15
+ <script src="./js/darkfish.js" type="text/javascript" charset="utf-8"></script>
16
+
17
+ </head>
18
+ <body id="top" class="class">
19
+
20
+ <div id="metadata">
21
+ <div id="home-metadata">
22
+ <div id="home-section" class="section">
23
+ <h3 class="section-header">
24
+ <a href="./index.html">Home</a>
25
+ <a href="./index.html#classes">Classes</a>
26
+ <a href="./index.html#methods">Methods</a>
27
+ </h3>
28
+ </div>
29
+ </div>
30
+
31
+ <div id="file-metadata">
32
+ <div id="file-list-section" class="section">
33
+ <h3 class="section-header">In Files</h3>
34
+ <div class="section-body">
35
+ <ul>
36
+
37
+ <li><a href="./test/parser_test_rb.html?TB_iframe=true&amp;height=550&amp;width=785"
38
+ class="thickbox" title="test/parser_test.rb">test/parser_test.rb</a></li>
39
+
40
+ </ul>
41
+ </div>
42
+ </div>
43
+
44
+
45
+ </div>
46
+
47
+ <div id="class-metadata">
48
+
49
+ <!-- Parent Class -->
50
+ <div id="parent-class-section" class="section">
51
+ <h3 class="section-header">Parent</h3>
52
+
53
+ <p class="link">Test::Unit::TestCase</p>
54
+
55
+ </div>
56
+
57
+
58
+
59
+
60
+
61
+
62
+
63
+ <!-- Method Quickref -->
64
+ <div id="method-list-section" class="section">
65
+ <h3 class="section-header">Methods</h3>
66
+ <ul class="link-list">
67
+
68
+ <li><a href="#method-i-test_parser_creation">#test_parser_creation</a></li>
69
+
70
+ <li><a href="#method-i-test_simple_parsing">#test_simple_parsing</a></li>
71
+
72
+ </ul>
73
+ </div>
74
+
75
+
76
+
77
+ </div>
78
+
79
+ <div id="project-metadata">
80
+
81
+
82
+ <div id="fileindex-section" class="section project-section">
83
+ <h3 class="section-header">Files</h3>
84
+ <ul>
85
+
86
+ <li class="file"><a href="./README_rdoc.html">README.rdoc</a></li>
87
+
88
+ <li class="file"><a href="./Rakefile.html">Rakefile</a></li>
89
+
90
+ </ul>
91
+ </div>
92
+
93
+
94
+ <div id="classindex-section" class="section project-section">
95
+ <h3 class="section-header">Class/Module Index
96
+ <span class="search-toggle"><img src="./images/find.png"
97
+ height="16" width="16" alt="[+]"
98
+ title="show/hide quicksearch" /></span></h3>
99
+ <form action="#" method="get" accept-charset="utf-8" class="initially-hidden">
100
+ <fieldset>
101
+ <legend>Quicksearch</legend>
102
+ <input type="text" name="quicksearch" value=""
103
+ class="quicksearch-field" />
104
+ </fieldset>
105
+ </form>
106
+
107
+ <ul class="link-list">
108
+
109
+ <li><a href="./Vizi.html">Vizi</a></li>
110
+
111
+ <li><a href="./Vizi/LogFormat.html">Vizi::LogFormat</a></li>
112
+
113
+ <li><a href="./Vizi/LogParser.html">Vizi::LogParser</a></li>
114
+
115
+ <li><a href="./Vizi/Visit.html">Vizi::Visit</a></li>
116
+
117
+ <li><a href="./Vizi/VisitList.html">Vizi::VisitList</a></li>
118
+
119
+ <li><a href="./Object.html">Object</a></li>
120
+
121
+ <li><a href="./ParserTest.html">ParserTest</a></li>
122
+
123
+ </ul>
124
+ <div id="no-class-search-results" style="display: none;">No matching classes.</div>
125
+ </div>
126
+
127
+
128
+ </div>
129
+ </div>
130
+
131
+ <div id="documentation">
132
+ <h1 class="class">ParserTest</h1>
133
+
134
+ <div id="description" class="description">
135
+
136
+ </div><!-- description -->
137
+
138
+
139
+ <div id="5Buntitled-5D" class="documentation-section">
140
+
141
+
142
+
143
+
144
+
145
+
146
+
147
+
148
+ <!-- Methods -->
149
+
150
+ <div id="public-instance-method-details" class="method-section section">
151
+ <h3 class="section-header">Public Instance Methods</h3>
152
+
153
+
154
+ <div id="test_parser_creation-method" class="method-detail ">
155
+ <a name="method-i-test_parser_creation"></a>
156
+
157
+
158
+ <div class="method-heading">
159
+ <span class="method-name">test_parser_creation</span><span
160
+ class="method-args">()</span>
161
+ <span class="method-click-advice">click to toggle source</span>
162
+ </div>
163
+
164
+
165
+ <div class="method-description">
166
+
167
+
168
+
169
+
170
+
171
+ <div class="method-source-code" id="test_parser_creation-source">
172
+ <pre>
173
+ <span class="ruby-comment"># File test/parser_test.rb, line 7</span>
174
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">test_parser_creation</span>
175
+
176
+ <span class="ruby-identifier">parser</span> = <span class="ruby-constant">HttpLogParser</span>.<span class="ruby-identifier">new</span>
177
+ <span class="ruby-identifier">assert_not_nil</span> <span class="ruby-identifier">parser</span>
178
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-value">5</span>, <span class="ruby-identifier">parser</span>.<span class="ruby-identifier">formats</span>.<span class="ruby-identifier">size</span>
179
+
180
+ <span class="ruby-identifier">parser</span> = <span class="ruby-constant">HttpLogParser</span>.<span class="ruby-identifier">new</span>(<span class="ruby-string">'%h %l %u %t \&quot;%r\&quot; %&gt;s %b'</span>)
181
+ <span class="ruby-identifier">assert_not_nil</span> <span class="ruby-identifier">parser</span>
182
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-value">1</span>, <span class="ruby-identifier">parser</span>.<span class="ruby-identifier">formats</span>.<span class="ruby-identifier">size</span>
183
+
184
+ <span class="ruby-identifier">parser</span> = <span class="ruby-constant">HttpLogParser</span>.<span class="ruby-identifier">new</span>({
185
+ <span class="ruby-value">:common</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-string">'%h %l %u %t \&quot;%r\&quot; %&gt;s %b'</span>,
186
+ <span class="ruby-value">:common_with_virtual</span> =<span class="ruby-operator">&gt;</span> <span class="ruby-string">'%v %h %l %u %t \&quot;%r\&quot; %&gt;s %b'</span>,
187
+ })
188
+ <span class="ruby-identifier">assert_not_nil</span> <span class="ruby-identifier">parser</span>
189
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-value">2</span>, <span class="ruby-identifier">parser</span>.<span class="ruby-identifier">formats</span>.<span class="ruby-identifier">size</span>
190
+
191
+ <span class="ruby-keyword">end</span></pre>
192
+ </div><!-- test_parser_creation-source -->
193
+
194
+ </div>
195
+
196
+
197
+
198
+
199
+ </div><!-- test_parser_creation-method -->
200
+
201
+
202
+ <div id="test_simple_parsing-method" class="method-detail ">
203
+ <a name="method-i-test_simple_parsing"></a>
204
+
205
+
206
+ <div class="method-heading">
207
+ <span class="method-name">test_simple_parsing</span><span
208
+ class="method-args">()</span>
209
+ <span class="method-click-advice">click to toggle source</span>
210
+ </div>
211
+
212
+
213
+ <div class="method-description">
214
+
215
+
216
+
217
+
218
+
219
+ <div class="method-source-code" id="test_simple_parsing-source">
220
+ <pre>
221
+ <span class="ruby-comment"># File test/parser_test.rb, line 26</span>
222
+ <span class="ruby-keyword">def</span> <span class="ruby-identifier">test_simple_parsing</span>
223
+
224
+ <span class="ruby-identifier">parser</span> = <span class="ruby-constant">HttpLogParser</span>.<span class="ruby-identifier">new</span>
225
+ <span class="ruby-identifier">assert_not_nil</span> <span class="ruby-identifier">parser</span>
226
+
227
+ <span class="ruby-identifier">parsed</span> = <span class="ruby-identifier">parser</span>.<span class="ruby-identifier">parse_line</span>(<span class="ruby-string">'111.222.333.444 - - [21/Apr/2010:01:02:03 +0000] &quot;GET /some/url?some=parameter HTTP/1.1&quot; 302 123 &quot;http://somewhere.com&quot; &quot;Browser (Version 1.0)&quot;'</span>)
228
+
229
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'111.222.333.444'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:ip</span>]
230
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'111.222.333.444'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:domain</span>]
231
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'-'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:auth</span>]
232
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'-'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:username</span>]
233
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'21/Apr/2010:01:02:03 +0000'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:datetime</span>]
234
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'GET /some/url?some=parameter HTTP/1.1'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:request</span>]
235
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'302'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:status</span>]
236
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'123'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:bytecount</span>]
237
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'http://somewhere.com'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:referer</span>]
238
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-string">'Browser (Version 1.0)'</span>, <span class="ruby-identifier">parsed</span>[<span class="ruby-value">:user_agent</span>]
239
+
240
+ <span class="ruby-identifier">assert_equal</span> <span class="ruby-value">11</span>, <span class="ruby-identifier">parsed</span>.<span class="ruby-identifier">size</span>
241
+
242
+ <span class="ruby-keyword">end</span></pre>
243
+ </div><!-- test_simple_parsing-source -->
244
+
245
+ </div>
246
+
247
+
248
+
249
+
250
+ </div><!-- test_simple_parsing-method -->
251
+
252
+
253
+ </div><!-- public-instance-method-details -->
254
+
255
+ </div><!-- 5Buntitled-5D -->
256
+
257
+
258
+ </div><!-- documentation -->
259
+
260
+ <div id="validator-badges">
261
+ <p><small><a href="http://validator.w3.org/check/referer">[Validate]</a></small></p>
262
+ <p><small>Generated with the <a href="http://deveiate.org/projects/Darkfish-Rdoc/">Darkfish
263
+ Rdoc Generator</a> 2</small>.</p>
264
+ </div>
265
+
266
+ </body>
267
+ </html>
268
+