forked from steemit/steem
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
WIP: Testing application for performing RPC API tests for SPS API plu…
…gin.
- Loading branch information
1 parent
0897d5c
commit b5be70f
Showing
1 changed file
with
104 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,104 @@ | ||
#!/usr/bin/python3 | ||
|
||
import requests | ||
import json | ||
import logging | ||
import sys | ||
import uuid | ||
|
||
LOG_LEVEL = logging.INFO | ||
LOG_FORMAT = "%(asctime)-15s - %(name)s - %(levelname)s - %(message)s" | ||
MAIN_LOG_PATH = "./sps_rpc_api_test.log" | ||
|
||
MODULE_NAME = "SPS API Tester" | ||
logger = logging.getLogger(MODULE_NAME) | ||
logger.setLevel(LOG_LEVEL) | ||
|
||
ch = logging.StreamHandler(sys.stdout) | ||
ch.setLevel(LOG_LEVEL) | ||
ch.setFormatter(logging.Formatter(LOG_FORMAT)) | ||
|
||
fh = logging.FileHandler(MAIN_LOG_PATH) | ||
fh.setLevel(LOG_LEVEL) | ||
fh.setFormatter(logging.Formatter(LOG_FORMAT)) | ||
|
||
if not logger.hasHandlers(): | ||
logger.addHandler(ch) | ||
logger.addHandler(fh) | ||
|
||
def get_random_id(): | ||
return str(uuid.uuid4()) | ||
|
||
def list_voter_proposals(voter, order_by, order_direction, active): | ||
payload = { | ||
"jsonrpc" : "2.0", | ||
"id" : get_random_id(), | ||
"method" : "sps_api.list_voter_proposals", | ||
"params" : { | ||
"voter" : voter, | ||
"order_by" : order_by, | ||
"order_direction" : order_direction, | ||
"active" : active | ||
} | ||
} | ||
ret = json.dumps(payload) | ||
logger.info("New payload: {}".format(ret)) | ||
return ret | ||
|
||
def find_proposal(id): | ||
payload = { | ||
"jsonrpc" : "2.0", | ||
"id" : get_random_id(), | ||
"method" : "sps_api.find_proposal", | ||
"params" : { | ||
"id" : "{}".format(id) | ||
} | ||
} | ||
ret = json.dumps(payload) | ||
logger.info("New payload: {}".format(ret)) | ||
return ret | ||
|
||
def list_proposals(order_by, order_direction, active): | ||
payload = { | ||
"jsonrpc" : "2.0", | ||
"id" : get_random_id(), | ||
"method" : "sps_api.list_proposals", | ||
"params" : { | ||
"order_by" : order_by, | ||
"order_direction" : order_direction, | ||
"active" : active | ||
} | ||
} | ||
ret = json.dumps(payload) | ||
logger.info("New payload: {}".format(ret)) | ||
return ret | ||
|
||
def run_test(test_name, expected_result, url, payload): | ||
logger.info("Running test: {}".format(test_name)) | ||
try: | ||
response = requests.request("POST", url, data = payload) | ||
logger.info("Response: {}".format(response.json())) | ||
except Exception as ex: | ||
logger.error("Exception during processing request: {0}".format(ex)) | ||
|
||
if __name__ == '__main__': | ||
logger.info("Performing SPS RPC API plugin tests") | ||
import argparse | ||
parser = argparse.ArgumentParser() | ||
parser.add_argument("--node-ip", help = "IP address of steem node", default = "http://127.0.0.1", dest = "node_ip") | ||
parser.add_argument("--node-port", help = "Steem node port", default = 8751, dest = "node_port") | ||
|
||
args = parser.parse_args() | ||
|
||
url = "{0}:{1}".format(args.node_ip, args.node_port) | ||
logger.info("Using node at: {}".format(url)) | ||
|
||
payload = find_proposal(1234) | ||
run_test("Basic find_proposal test", None, url, payload) | ||
|
||
payload = list_proposals("creator", "direction_ascending", 1) | ||
run_test("Basic list_proposals test", None, url, payload) | ||
|
||
payload = list_voter_proposals("blocktrades", "creator", "direction_ascending", 1) | ||
run_test("Basic list_voter_proposals test", None, url, payload) | ||
|