util.secscan.fake: add test for unexpected status
This commit is contained in:
parent
46087d5e64
commit
1d2640e012
2 changed files with 36 additions and 1 deletions
|
@ -33,6 +33,7 @@ class FakeSecurityScanner(object):
|
|||
self.fail_layer_id = None
|
||||
self.internal_error_layer_id = None
|
||||
self.error_layer_id = None
|
||||
self.unexpected_status_layer_id = None
|
||||
|
||||
def set_ok_layer_id(self, ok_layer_id):
|
||||
""" Sets a layer ID that, if encountered when the analyze call is made, causes a 200
|
||||
|
@ -58,6 +59,12 @@ class FakeSecurityScanner(object):
|
|||
"""
|
||||
self.error_layer_id = error_layer_id
|
||||
|
||||
def set_unexpected_status_layer_id(self, layer_id):
|
||||
""" Sets a layer ID that, if encountered when the analyze call is made, causes an HTTP 600
|
||||
to be raised. This is useful in testing the robustness of the to unknown status codes.
|
||||
"""
|
||||
self.unexpected_status_layer_id = layer_id
|
||||
|
||||
def has_layer(self, layer_id):
|
||||
""" Returns true if the layer with the given ID has been analyzed. """
|
||||
return layer_id in self.layers
|
||||
|
@ -252,6 +259,13 @@ class FakeSecurityScanner(object):
|
|||
'content': json.dumps({'Error': {'Message': 'Some sort of error'}}),
|
||||
}
|
||||
|
||||
if layer['Name'] == self.unexpected_status_layer_id:
|
||||
return {
|
||||
'status_code': 600,
|
||||
'content': json.dumps({'Error': {'Message': 'Some sort of error'}}),
|
||||
}
|
||||
|
||||
|
||||
parent_id = layer.get('ParentName', None)
|
||||
parent_layer = None
|
||||
|
||||
|
|
Reference in a new issue