download_tv 2.4.6 → 2.4.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/download_tv/downloader.rb +1 -1
- data/lib/download_tv/grabbers/kat.rb +9 -1
- data/lib/download_tv/torrent.rb +1 -2
- data/lib/download_tv/version.rb +1 -1
- data/test/torrent_test.rb +5 -4
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 3da65f8f28fbd1c2d76d9166e5e5ed8e13ddf77546e63a43955d88ca60b226da
|
4
|
+
data.tar.gz: 526cc3fffa489f0e4f9b568b196bc0c468958fab56f46e72b0fe1222b515aa62
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 0aa3b30cf80314fe1cc88b83a89b1d548a81fd787b38b3aed26433263de54f09288e05413f0eb64654ad2a4d6acfc4c4ae82e780b37a98a40e59bf33b1857475
|
7
|
+
data.tar.gz: 738b270056911835ac14e073d8067376f43dc2dce4bdaddc7a8c36c38f3eb90ff5adddcd68f387f81d5f71a88aca831684fc086f82b859b90a089e4c2bd41f08
|
@@ -7,13 +7,16 @@ module DownloadTV
|
|
7
7
|
end
|
8
8
|
|
9
9
|
def get_links(s)
|
10
|
+
tries = 0
|
11
|
+
max_tries = 5
|
12
|
+
|
10
13
|
params = {
|
11
14
|
'category': 'TV',
|
12
15
|
'orderby': 'seeds-desc',
|
13
16
|
'search': s
|
14
17
|
}
|
15
18
|
|
16
|
-
data = @agent.post(@url, params).search('
|
19
|
+
data = @agent.post(@url, params).search('tbody tr td[1]')
|
17
20
|
|
18
21
|
names = data.map { |i| i.search('a.torrents_table__torrent_title b').text }
|
19
22
|
links = data.map { |i| i.search('div.torrents_table__actions a[3]').first.attribute('href').text }
|
@@ -21,6 +24,11 @@ module DownloadTV
|
|
21
24
|
raise NoTorrentsError if data.empty?
|
22
25
|
|
23
26
|
names.zip(links)
|
27
|
+
rescue Net::HTTP::Persistent::Error => e
|
28
|
+
raise unless e.message =~ /too many connection resets/
|
29
|
+
raise if tries >= max_tries
|
30
|
+
tries += 1
|
31
|
+
retry
|
24
32
|
end
|
25
33
|
end
|
26
34
|
end
|
data/lib/download_tv/torrent.rb
CHANGED
data/lib/download_tv/version.rb
CHANGED
data/test/torrent_test.rb
CHANGED
@@ -1,17 +1,18 @@
|
|
1
1
|
require 'test_helper'
|
2
2
|
|
3
3
|
describe DownloadTV::Torrent do
|
4
|
+
grabber_names = DownloadTV::Torrent.new(nil).grabbers
|
4
5
|
describe 'when creating the object' do
|
5
6
|
before do
|
6
7
|
@t = DownloadTV::Torrent.new
|
7
8
|
end
|
8
9
|
|
9
10
|
it 'will populate the instances' do
|
10
|
-
@t.g_instances.size.must_equal
|
11
|
+
@t.g_instances.size.must_equal grabber_names.size
|
11
12
|
end
|
12
13
|
|
13
14
|
it 'will start with all tries available' do
|
14
|
-
@t.tries.must_equal
|
15
|
+
@t.tries.must_equal grabber_names.size - 1
|
15
16
|
end
|
16
17
|
|
17
18
|
it 'will call get_links on its grabber' do
|
@@ -24,11 +25,11 @@ describe DownloadTV::Torrent do
|
|
24
25
|
describe 'when giving it a default grabber' do
|
25
26
|
it 'has a default order' do
|
26
27
|
t = DownloadTV::Torrent.new(nil)
|
27
|
-
expected =
|
28
|
+
expected = grabber_names.map { |i| "DownloadTV::#{i}"}
|
28
29
|
t.g_instances.map { |i| i.class.name}.must_equal expected
|
29
30
|
end
|
30
31
|
|
31
|
-
|
32
|
+
grabber_names.each do |g|
|
32
33
|
it 'correctly uses the given grabber first' do
|
33
34
|
t = DownloadTV::Torrent.new(g)
|
34
35
|
t.g_instances.first.class.name.must_equal "DownloadTV::#{g}"
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: download_tv
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.4.
|
4
|
+
version: 2.4.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- guille
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2018-
|
11
|
+
date: 2018-10-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|