From 383e5a101dfb52e19d652200e5b31d4441660684 Mon Sep 17 00:00:00 2001 From: Viktor Stanchev Date: Thu, 3 Sep 2015 23:00:40 -0700 Subject: [PATCH] test torrent command parser --- pirate/pirate.py | 72 +++++++++++++++++++++++--------------------- pirate/print.py | 2 -- pirate/torrent.py | 2 -- tests/test_pirate.py | 19 ++++++++++++ 4 files changed, 57 insertions(+), 38 deletions(-) diff --git a/pirate/pirate.py b/pirate/pirate.py index ab3fba8..b740b00 100755 --- a/pirate/pirate.py +++ b/pirate/pirate.py @@ -66,6 +66,43 @@ def parse_cmd(cmd, url): return ret_no_quotes +def parse_torrent_command(l): + # Very permissive handling + # Check for any occurances or d, f, p, t, m, or q + cmd_code_match = re.search(r'([hdfpmtq])', l, + flags=re.IGNORECASE) + if cmd_code_match: + code = cmd_code_match.group(0).lower() + else: + code = None + + # Clean up command codes + # Substitute multiple consecutive spaces/commas for single + # comma remove anything that isn't an integer or comma. + # Turn into list + l = re.sub(r'^[hdfp, ]*|[hdfp, ]*$', '', l) + l = re.sub('[ ,]+', ',', l) + l = re.sub('[^0-9,-]', '', l) + parsed_input = l.split(',') + + # expand ranges + choices = [] + # loop will generate a list of lists + for elem in parsed_input: + left, sep, right = elem.partition('-') + if right: + choices.append(list(range(int(left), int(right) + 1))) + elif left != '': + choices.append([int(left)]) + + # flatten list + choices = sum(choices, []) + # the current code stores the choices as strings + # instead of ints. not sure if necessary + choices = [elem for elem in choices] + return code, choices + + def main(): config = load_config() @@ -235,40 +272,7 @@ def main(): return try: - # Very permissive handling - # Check for any occurances or d, f, p, t, m, or q - cmd_code_match = re.search(r'([hdfpmtq])', l, - flags=re.IGNORECASE) - if cmd_code_match: - code = cmd_code_match.group(0).lower() - else: - code = None - - # Clean up command codes - # Substitute multiple consecutive spaces/commas for single - # comma remove anything that isn't an integer or comma. - # Turn into list - l = re.sub(r'^[hdfp, ]*|[hdfp, ]*$', '', l) - l = re.sub('[ ,]+', ',', l) - l = re.sub('[^0-9,-]', '', l) - parsed_input = l.split(',') - - # expand ranges - choices = [] - # loop will generate a list of lists - for elem in parsed_input: - left, sep, right = elem.partition('-') - if right: - choices.append(list(range(int(left), int(right) + 1))) - elif left != '': - choices.append([int(left)]) - - # flatten list - choices = sum(choices, []) - # the current code stores the choices as strings - # instead of ints. not sure if necessary - choices = [str(elem) for elem in choices] - + code, choices = parse_torrent_command(l) # Act on option, if supplied print('') if code == 'h': diff --git a/pirate/print.py b/pirate/print.py index 7e19ba3..04d3a7e 100644 --- a/pirate/print.py +++ b/pirate/print.py @@ -83,7 +83,6 @@ def search_results(results, local=None): def descriptions(chosen_links, results, site): for link in chosen_links: - link = int(link) path = '/torrent/%s/' % results[link]['id'] req = request.Request(site + path, headers=pirate.data.default_headers) req.add_header('Accept-encoding', 'gzip') @@ -108,7 +107,6 @@ def descriptions(chosen_links, results, site): def file_lists(chosen_links, results, site): for link in chosen_links: - link = int(link) path = '/ajax_details_filelist.php' query = '?id=' + results[link]['id'] req = request.Request(site + path + query, diff --git a/pirate/torrent.py b/pirate/torrent.py index c0f2ff4..3c0aa16 100644 --- a/pirate/torrent.py +++ b/pirate/torrent.py @@ -163,7 +163,6 @@ def get_torrent(info_hash): def save_torrents(chosen_links, results, folder): for link in chosen_links: - link = int(link) magnet = results[link]['magnet'] name = re.search(r'dn=([^\&]*)', magnet) torrent_name = parse.unquote(name.group(1)).replace('+', ' ') @@ -181,7 +180,6 @@ def save_torrents(chosen_links, results, folder): def save_magnets(chosen_links, mags, folder): for link in chosen_links: - link = int(link) magnet = results[link]['magnet'] name = re.search(r'dn=([^\&]*)', magnet) torrent_name = parse.unquote(name.group(1)).replace('+', ' ') diff --git a/tests/test_pirate.py b/tests/test_pirate.py index dff36af..a11f696 100755 --- a/tests/test_pirate.py +++ b/tests/test_pirate.py @@ -17,5 +17,24 @@ class TestPirate(unittest.TestCase): for test in tests: self.assertEqual(pirate.pirate.parse_cmd(*test[0]), test[1]) + def test_parse_torrent_command(self): + tests = [ + [['h'], ('h', [])], + [['q'], ('q', [])], + [['d1'], ('d', [1])], + [['f1'], ('f', [1])], + [['p1'], ('p', [1])], + [['t1'], ('t', [1])], + [['m1'], ('m', [1])], + [['d 23'], ('d', [23])], + [['d 23,1'], ('d', [23, 1])], + [['d 23, 1'], ('d', [23, 1])], + [['1d'], ('d', [1])], + [['1 ... d'], ('d', [1])], + [['1-3 d'], ('d', [1,2,3])], + ] + for test in tests: + self.assertEqual(pirate.pirate.parse_torrent_command(*test[0]), test[1]) + if __name__ == '__main__': unittest.main()