[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] [torflow/master 44/92] FixedTarget HTTP initialization fix
Author: John M. Schanck <john@xxxxxxxxxxx>
Date: Fri, 30 Jul 2010 20:44:34 -0400
Subject: FixedTarget HTTP initialization fix
Commit: 9c72e99da68fb53bdeb7a51cb5bc3eca13cc38ba
---
NetworkScanners/ExitAuthority/soat.py | 34 ++++++++++++++------------------
1 files changed, 15 insertions(+), 19 deletions(-)
diff --git a/NetworkScanners/ExitAuthority/soat.py b/NetworkScanners/ExitAuthority/soat.py
index 7f30267..0551626 100755
--- a/NetworkScanners/ExitAuthority/soat.py
+++ b/NetworkScanners/ExitAuthority/soat.py
@@ -877,7 +877,7 @@ class BaseHTTPTest(Test):
def _reset(self):
self.httpcode_fails = {}
self.httpcode_fails_per_exit = {}
- self.targets_by_type = dict.fromkeys(self.scan_filetypes, [])
+ self.targets_by_type = {}
Test._reset(self)
def depickle_upgrade(self):
@@ -948,6 +948,16 @@ class BaseHTTPTest(Test):
else:
return TEST_SUCCESS
+ def add_target(self, target, type=None):
+ # HTTP Tests keep an additional dictionary of targets keyed by filetype
+ if type is None:
+ split = target.rsplit('.',1)
+ if len(split) > 1:
+ type = split[-1]
+ if type in self.scan_filetypes:
+ self.targets.append(target)
+ self.targets_by_type.setdefault(type, []).append(target)
+
def remove_target(self, target, reason="None"):
# Remove from targets list and targets by type dictionary
if target in self.targets:
@@ -1895,9 +1905,6 @@ class FixedTargetTest:
def __init__(self, targets):
self.fixed_targets = targets
- def add_target(self, target):
- pass
-
def refill_targets(self):
pass
@@ -2065,8 +2072,8 @@ class SearchBasedHTTPTest(SearchBasedTest, BaseHTTPTest):
BaseHTTPTest.rewind(self)
def refill_targets(self):
- for ftype in self.targets_by_type:
- if len(self.targets_by_type[ftype]) < self.fetch_targets:
+ for ftype in self.scan_filetypes:
+ if not ftype in self.targets_by_type or len(self.targets_by_type[ftype]) < self.fetch_targets:
plog("NOTICE", self.proto+" scanner short on "+ftype+" targets. Adding more")
# :-\ - This swapping out result_filetypes thing is a hack.
tmp = self.result_filetypes
@@ -2074,26 +2081,15 @@ class SearchBasedHTTPTest(SearchBasedTest, BaseHTTPTest):
map(self.add_target, self.get_search_urls())
self.result_filetypes = tmp
- #XXX: add_target has a confusing lineage, is it more properly part of
- # Test->BaseHTTPTest->SearchBasedHTTPTest or SearchBasedTest->SearchBasedHTTPTest?
- def add_target(self, target, type=None):
- if type is None:
- split = target.rsplit('.',1)
- if len(split) > 1:
- type = split[-1]
- if type in self.scan_filetypes:
- self.targets.append(target)
- self.targets_by_type[type].append(target)
-
def get_targets(self):
raw_urls = self.get_search_urls()
new = {}
for url in raw_urls:
split = url.rsplit('.',1) # Try to get filetype
- if len(split) > 1 and split[-1] in self.targets_by_type:
+ if len(split) > 1 and split[-1] in self.scan_filetypes:
new.setdefault(split[-1],[]).append(url)
for k,v in new.items():
- self.targets_by_type[k].extend(v)
+ self.targets_by_type.setdefault(k, []).extend(v)
return raw_urls
HTTPTest = SearchBasedHTTPTest # For resuming from old HTTPTest.*.test files
--
1.7.1