hn 0.0.1 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/Rakefile +1 -1
- data/hn.gemspec +1 -0
- data/lib/hn/models/entry.rb +1 -1
- data/lib/hn/parsers/entry_parser.rb +8 -3
- data/lib/hn/version.rb +1 -1
- data/spec/hn/parsers/entry_parser_spec.rb +11 -5
- data/spec/spec_helper.rb +7 -4
- metadata +25 -14
data/Rakefile
CHANGED
data/hn.gemspec
CHANGED
data/lib/hn/models/entry.rb
CHANGED
@@ -4,15 +4,19 @@ require "open-uri"
|
|
4
4
|
module HackerNews
|
5
5
|
class EntryParser
|
6
6
|
def homepage
|
7
|
-
parse_entries
|
7
|
+
parse_entries site_name
|
8
8
|
end
|
9
9
|
|
10
10
|
def newest
|
11
|
-
parse_entries
|
11
|
+
parse_entries "#{site_name}newest"
|
12
12
|
end
|
13
13
|
|
14
14
|
private
|
15
15
|
|
16
|
+
def site_name
|
17
|
+
'http://news.ycombinator.com/'
|
18
|
+
end
|
19
|
+
|
16
20
|
def parse_entries(url)
|
17
21
|
# doc = Nokogiri::HTML(open('spec/fixtures/home.html'))
|
18
22
|
doc = Nokogiri::HTML(open(url))
|
@@ -23,9 +27,10 @@ module HackerNews
|
|
23
27
|
Entry.new do |entry|
|
24
28
|
entry.title = trs[i*3].at_css('td.title a').text
|
25
29
|
entry.link = trs[i*3].at_css('td.title a')['href']
|
30
|
+
entry.link = site_name + entry.link unless entry.link =~ /^http/
|
26
31
|
entry.site = trs[i*3].at_css('td.title span.comhead').text.match(/\((.+)\)/)[1] rescue nil
|
27
32
|
entry.points = trs[i*3+1].at_css('td.subtext span').text.to_i rescue 0
|
28
|
-
entry.
|
33
|
+
entry.username = trs[i*3+1].at_css('td.subtext a').text
|
29
34
|
entry.time_string = trs[i*3+1].at_css('td.subtext a').next.text.sub('|', '').strip
|
30
35
|
entry.num_comments = trs[i*3+1].css('td.subtext a')[1].text.to_i
|
31
36
|
entry.id = trs[i*3+1].css('td.subtext a')[1]['href'].match(/\d+/)[0].to_i
|
data/lib/hn/version.rb
CHANGED
@@ -1,6 +1,9 @@
|
|
1
1
|
require "spec_helper"
|
2
2
|
require "chronic"
|
3
3
|
|
4
|
+
FakeWeb.register_uri :get, 'http://news.ycombinator.com/', :body => fixture('home.html')
|
5
|
+
FakeWeb.register_uri :get, 'http://news.ycombinator.com/newest', :body => fixture('newest.html')
|
6
|
+
|
4
7
|
module HackerNews
|
5
8
|
describe EntryParser do
|
6
9
|
subject { EntryParser.new }
|
@@ -9,13 +12,12 @@ module HackerNews
|
|
9
12
|
|
10
13
|
context "homepage" do
|
11
14
|
it "should parse them right" do
|
12
|
-
parser.stub(:open).and_return(open('spec/fixtures/home.html'))
|
13
15
|
entries = parser.homepage
|
14
16
|
entries.count.should == 30
|
15
17
|
entries.first.should be_an Entry
|
16
18
|
entries.each do |entry|
|
17
19
|
entry.id.should > 4000000
|
18
|
-
entry.
|
20
|
+
entry.username.should =~ /\w+/
|
19
21
|
entry.link.should =~ /^http/ unless entry.site.nil?
|
20
22
|
entry.title.should_not be_empty
|
21
23
|
entry.num_comments.should > 0
|
@@ -28,14 +30,18 @@ module HackerNews
|
|
28
30
|
|
29
31
|
context "newest" do
|
30
32
|
it "should parse them right" do
|
31
|
-
parser.stub(:open).and_return(open('spec/fixtures/newest.html'))
|
32
33
|
entries = parser.newest
|
33
34
|
entries.count.should == 30
|
34
35
|
entries.first.should be_an Entry
|
35
36
|
entries.each do |entry|
|
36
37
|
entry.id.should > 4000000
|
37
|
-
entry.
|
38
|
-
entry.link.should =~ /^http/
|
38
|
+
entry.username.should =~ /\w+/
|
39
|
+
entry.link.should =~ /^http/
|
40
|
+
|
41
|
+
if entry.site.nil? # ASK HN
|
42
|
+
entry.id.should == entry.link.match(/^http:\/\/news\.ycombinator\.com\/item\?id=(\d+)$/)[1].to_i
|
43
|
+
end
|
44
|
+
|
39
45
|
entry.title.should_not be_empty
|
40
46
|
entry.num_comments.should >= 0
|
41
47
|
entry.site.should_not =~ /^http/
|
data/spec/spec_helper.rb
CHANGED
@@ -3,9 +3,12 @@ SimpleCov.start do
|
|
3
3
|
add_filter 'spec'
|
4
4
|
end
|
5
5
|
|
6
|
-
require "open-uri"
|
7
6
|
require 'hn'
|
8
7
|
|
9
|
-
|
10
|
-
|
11
|
-
|
8
|
+
require "fakeweb"
|
9
|
+
FakeWeb.allow_net_connect = false
|
10
|
+
|
11
|
+
require "open-uri"
|
12
|
+
def fixture(fixture_name)
|
13
|
+
open("spec/fixtures/#{fixture_name}") { |p| p.read }
|
14
|
+
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: hn
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.2
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -9,11 +9,11 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2012-05-
|
12
|
+
date: 2012-05-29 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: rspec
|
16
|
-
requirement: &
|
16
|
+
requirement: &70126472762360 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ! '>='
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0'
|
22
22
|
type: :development
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *70126472762360
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: rake
|
27
|
-
requirement: &
|
27
|
+
requirement: &70126472761940 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ! '>='
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '0'
|
33
33
|
type: :development
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *70126472761940
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: simplecov
|
38
|
-
requirement: &
|
38
|
+
requirement: &70126472761520 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ! '>='
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: '0'
|
44
44
|
type: :development
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *70126472761520
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: chronic
|
49
|
-
requirement: &
|
49
|
+
requirement: &70126472761100 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ! '>='
|
@@ -54,10 +54,21 @@ dependencies:
|
|
54
54
|
version: '0'
|
55
55
|
type: :development
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *70126472761100
|
58
|
+
- !ruby/object:Gem::Dependency
|
59
|
+
name: fakeweb
|
60
|
+
requirement: &70126472760680 !ruby/object:Gem::Requirement
|
61
|
+
none: false
|
62
|
+
requirements:
|
63
|
+
- - ! '>='
|
64
|
+
- !ruby/object:Gem::Version
|
65
|
+
version: '0'
|
66
|
+
type: :development
|
67
|
+
prerelease: false
|
68
|
+
version_requirements: *70126472760680
|
58
69
|
- !ruby/object:Gem::Dependency
|
59
70
|
name: nokogiri
|
60
|
-
requirement: &
|
71
|
+
requirement: &70126472760260 !ruby/object:Gem::Requirement
|
61
72
|
none: false
|
62
73
|
requirements:
|
63
74
|
- - ! '>='
|
@@ -65,7 +76,7 @@ dependencies:
|
|
65
76
|
version: '0'
|
66
77
|
type: :runtime
|
67
78
|
prerelease: false
|
68
|
-
version_requirements: *
|
79
|
+
version_requirements: *70126472760260
|
69
80
|
description: A tiny gem to fetch Hacker News entries
|
70
81
|
email:
|
71
82
|
- afu@forresty.com
|
@@ -105,7 +116,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
105
116
|
version: '0'
|
106
117
|
segments:
|
107
118
|
- 0
|
108
|
-
hash:
|
119
|
+
hash: 4450533506662142412
|
109
120
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
110
121
|
none: false
|
111
122
|
requirements:
|
@@ -114,7 +125,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
114
125
|
version: '0'
|
115
126
|
segments:
|
116
127
|
- 0
|
117
|
-
hash:
|
128
|
+
hash: 4450533506662142412
|
118
129
|
requirements: []
|
119
130
|
rubyforge_project:
|
120
131
|
rubygems_version: 1.8.11
|