aboutsummaryrefslogtreecommitdiffstats
path: root/python-packages/json_schemas/test/test_json_schemas.py
diff options
context:
space:
mode:
authorF. Eugene Aumson <feuGeneA@users.noreply.github.com>2019-01-09 03:28:32 +0800
committerGitHub <noreply@github.com>2019-01-09 03:28:32 +0800
commit4689f20b86333d74fa0ccd45b23c560a0a0361b5 (patch)
tree9b1810a912a7c866d6be3799b24feea9c9f49d1f /python-packages/json_schemas/test/test_json_schemas.py
parentde927d7207571e99a009320d9a47ae9815c2e198 (diff)
parente62e61bf7145c0a8011e098aa22168416d01a781 (diff)
downloaddexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.tar
dexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.tar.gz
dexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.tar.bz2
dexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.tar.lz
dexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.tar.xz
dexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.tar.zst
dexon-sol-tools-4689f20b86333d74fa0ccd45b23c560a0a0361b5.zip
Move json_schemas to its own package (#1435)
* Move zero_ex.json_schemas to its own package * Support ALL the schemas * Stop installing packages as editable * HACK: cp files because CircleCI isn't * Add example usage to sra_client README * Tweak special case: only strip Schema as suffix * Correct doc titles * Clarify what kind of support ticket was raised. * Correct inconsistencies in JSON schema names In both ref ID's and file names. * Add entry point for validation of JSON strings
Diffstat (limited to 'python-packages/json_schemas/test/test_json_schemas.py')
-rw-r--r--python-packages/json_schemas/test/test_json_schemas.py41
1 files changed, 41 insertions, 0 deletions
diff --git a/python-packages/json_schemas/test/test_json_schemas.py b/python-packages/json_schemas/test/test_json_schemas.py
new file mode 100644
index 000000000..d0e9840b3
--- /dev/null
+++ b/python-packages/json_schemas/test/test_json_schemas.py
@@ -0,0 +1,41 @@
+"""Tests of zero_ex.json_schemas"""
+
+
+from zero_ex.json_schemas import _LOCAL_RESOLVER, assert_valid
+
+
+NULL_ADDRESS = "0x0000000000000000000000000000000000000000"
+
+EMPTY_ORDER = {
+ "makerAddress": NULL_ADDRESS,
+ "takerAddress": NULL_ADDRESS,
+ "senderAddress": NULL_ADDRESS,
+ "feeRecipientAddress": NULL_ADDRESS,
+ "makerAssetData": NULL_ADDRESS,
+ "takerAssetData": NULL_ADDRESS,
+ "salt": "0",
+ "makerFee": "0",
+ "takerFee": "0",
+ "makerAssetAmount": "0",
+ "takerAssetAmount": "0",
+ "expirationTimeSeconds": "0",
+ "exchangeAddress": NULL_ADDRESS,
+}
+
+
+def test_assert_valid_caches_resources():
+ """Test that the JSON ref resolver in `assert_valid()` caches resources
+
+ In order to test the cache we much access the private class of
+ `json_schemas` and reset the LRU cache on `_LocalRefResolver`.
+ For this to happen, we need to disable errror `W0212`
+ on _LOCAL_RESOLVER
+ """
+ _LOCAL_RESOLVER._remote_cache.cache_clear() # pylint: disable=W0212
+
+ assert_valid(EMPTY_ORDER, "/orderSchema")
+ cache_info = (
+ _LOCAL_RESOLVER._remote_cache.cache_info() # pylint: disable=W0212
+ )
+ assert cache_info.currsize == 4
+ assert cache_info.hits == 10