Skip to content

Commit

Permalink
Additional brother elements validation on advanceBlockchain request p…
Browse files Browse the repository at this point in the history
…ayload (#173)

- Added validation
- Added and updated tests
  • Loading branch information
amendelzon authored Apr 5, 2024
1 parent aea9013 commit f884685
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 15 deletions.
5 changes: 3 additions & 2 deletions middleware/comm/protocol.py
Original file line number Diff line number Diff line change
Expand Up @@ -203,9 +203,10 @@ def _validate_advance_blockchain(self, request):
"different in length to Blocks field")
return self.ERROR_CODE_INVALID_BROTHERS

# Validate brother elements are lists of strings
# Validate brother elements are lists of nonempty hex strings
if not all(type(item) == list for item in request["brothers"]) or \
not all(type(item) == str for brother_list in request["brothers"]
not all(type(item) == str and is_nonempty_hex_string(item)
for brother_list in request["brothers"]
for item in brother_list):
self.logger.info("Some of the brother list elements are not strings")
return self.ERROR_CODE_INVALID_BROTHERS
Expand Down
28 changes: 24 additions & 4 deletions middleware/tests/comm/test_protocol.py
Original file line number Diff line number Diff line change
Expand Up @@ -1086,7 +1086,7 @@ def test_advance_blockchain_brothers_presence(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["ok", "another-ok", "yet-another-ok"],
"brothers": [["b11", "b12"], ["b21", 123], ["b31", "b32", "b33"]],
"brothers": [["bb11", "bb12"], ["bb21", 123], ["bb31", "bb32", "bb33"]],
}),
{"errorcode": -205},
)
Expand All @@ -1096,7 +1096,7 @@ def test_advance_blockchain_brothers_presence(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["ok", "another-ok", "yet-another-ok"],
"brothers": [["b11", "b12"], ["b21"]],
"brothers": [["bb11", "bb12"], ["bb21"]],
}),
{"errorcode": -205},
)
Expand All @@ -1106,7 +1106,27 @@ def test_advance_blockchain_brothers_presence(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["ok", "another-ok", "yet-another-ok"],
"brothers": [["b11", "b12"], ["b21"], ["b31", "b32", "b33"], []],
"brothers": [["bb11", "bb12"], ["bb21"], ["bb31", "bb32", "bb33"], []],
}),
{"errorcode": -205},
)

self.assertEqual(
self.protocol.handle_request({
"version": 4,
"command": "advanceBlockchain",
"blocks": ["ok"],
"brothers": [[""]],
}),
{"errorcode": -205},
)

self.assertEqual(
self.protocol.handle_request({
"version": 4,
"command": "advanceBlockchain",
"blocks": ["ok", "another-ok", "yet-another-ok"],
"brothers": [["bb11", "bb12"], ["bb21"], ["bb31", "bb32", "not-hex"]],
}),
{"errorcode": -205},
)
Expand All @@ -1117,7 +1137,7 @@ def test_advance_blockchain_notimplemented(self):
"command": "advanceBlockchain",
"version": 4,
"blocks": ["fist-block", "second-block"],
"brothers": [["b11", "b12"], ["b21", "b22", "b23"]],
"brothers": [["bb11", "bb12"], ["bb21", "bb22", "bb23"]],
})

def test_reset_advance_blockchain_notimplemented(self):
Expand Down
18 changes: 9 additions & 9 deletions middleware/tests/ledger/test_protocol.py
Original file line number Diff line number Diff line change
Expand Up @@ -1211,14 +1211,14 @@ def test_advance_blockchain_mapping(self, _, response, expected_code):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["aabbcc", "ddeeff"],
"brothers": [["b11"], ["b21", "b22"]],
"brothers": [["bb11"], ["bb21", "bb22"]],
}),
)

self.assertEqual(
[call(
["aabbcc", "ddeeff"],
[["b11"], ["b21", "b22"]],
[["bb11"], ["bb21", "bb22"]],
)],
self.dongle.advance_blockchain.call_args_list,
)
Expand All @@ -1233,14 +1233,14 @@ def test_advance_blockchain_timeout(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["aabbcc", "ddeeff"],
"brothers": [["b11", "b12", "b13"], ["b21", "b22"]],
"brothers": [["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
}),
)

self.assertEqual(
[call(
["aabbcc", "ddeeff"],
[["b11", "b12", "b13"], ["b21", "b22"]],
[["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
)],
self.dongle.advance_blockchain.call_args_list,
)
Expand All @@ -1255,14 +1255,14 @@ def test_advance_blockchain_commerror_reconnection(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["aabbcc", "ddeeff"],
"brothers": [["b11", "b12", "b13"], ["b21", "b22"]],
"brothers": [["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
}),
)

self.assertEqual(
[call(
["aabbcc", "ddeeff"],
[["b11", "b12", "b13"], ["b21", "b22"]],
[["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
)],
self.dongle.advance_blockchain.call_args_list,
)
Expand All @@ -1277,7 +1277,7 @@ def test_advance_blockchain_commerror_reconnection(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["aabbcc", "ddeeff"],
"brothers": [["b11", "b12", "b13"], ["b21", "b22"]],
"brothers": [["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
}),
)

Expand All @@ -1292,14 +1292,14 @@ def test_advance_blockchain_exception(self):
"version": 4,
"command": "advanceBlockchain",
"blocks": ["aabbcc", "ddeeff"],
"brothers": [["b11", "b12", "b13"], ["b21", "b22"]],
"brothers": [["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
}),
)

self.assertEqual(
[call(
["aabbcc", "ddeeff"],
[["b11", "b12", "b13"], ["b21", "b22"]],
[["bb11", "bb12", "bb13"], ["bb21", "bb22"]],
)],
self.dongle.advance_blockchain.call_args_list,
)
Expand Down

0 comments on commit f884685

Please sign in to comment.