mirror of
https://git.hush.is/hush/hush3.git
synced 2025-09-20 00:03:33 -04:00
Merge pull request #1020 from tonymorony/FSM
added tests for oracles data publishing
This commit is contained in:
commit
83d4ca0697
@ -115,13 +115,163 @@ class CryptoconditionsOraclesTest(BitcoinTestFramework):
|
|||||||
too_long_description = generate_random_string(4100)
|
too_long_description = generate_random_string(4100)
|
||||||
result = rpc.oraclescreate("Test", too_long_description, "s")
|
result = rpc.oraclescreate("Test", too_long_description, "s")
|
||||||
assert_error(result)
|
assert_error(result)
|
||||||
# # valid creating oracles of different types
|
# valid creating oracles of different types
|
||||||
# # using such naming to re-use it for data publishing / reading (e.g. oracle_s for s type)
|
# using such naming to re-use it for data publishing / reading (e.g. oracle_s for s type)
|
||||||
# valid_formats = ["s", "S", "d", "D", "c", "C", "t", "T", "i", "I", "l", "L", "h", "Ihh"]
|
valid_formats = ["s", "S", "d", "D", "c", "C", "t", "T", "i", "I", "l", "L", "h", "Ihh"]
|
||||||
# for f in valid_formats:
|
for f in valid_formats:
|
||||||
# result = rpc.oraclescreate("Test", "Test", f)
|
result = rpc.oraclescreate("Test", "Test", f)
|
||||||
# assert_success(result)
|
assert_success(result)
|
||||||
# globals()["oracle_{}".format(f)] = self.send_and_mine(result['hex'], rpc)
|
globals()["oracle_{}".format(f)] = self.send_and_mine(result['hex'], rpc)
|
||||||
|
|
||||||
|
# trying to register with negative datafee
|
||||||
|
for f in valid_formats:
|
||||||
|
result = rpc.oraclesregister(globals()["oracle_{}".format(f)], "-100")
|
||||||
|
assert_error(result)
|
||||||
|
|
||||||
|
# trying to register with zero datafee
|
||||||
|
for f in valid_formats:
|
||||||
|
result = rpc.oraclesregister(globals()["oracle_{}".format(f)], "0")
|
||||||
|
assert_error(result)
|
||||||
|
|
||||||
|
# trying to register with datafee less than txfee
|
||||||
|
for f in valid_formats:
|
||||||
|
result = rpc.oraclesregister(globals()["oracle_{}".format(f)], "500")
|
||||||
|
assert_error(result)
|
||||||
|
|
||||||
|
# trying to register valid
|
||||||
|
for f in valid_formats:
|
||||||
|
result = rpc.oraclesregister(globals()["oracle_{}".format(f)], "10000")
|
||||||
|
assert_success(result)
|
||||||
|
register_txid = self.send_and_mine(result["hex"], rpc)
|
||||||
|
assert register_txid, "got txid"
|
||||||
|
|
||||||
|
# TODO: for most of the non valid oraclesregister and oraclessubscribe transactions generating and broadcasting now
|
||||||
|
# so trying only valid oraclessubscribe atm
|
||||||
|
for f in valid_formats:
|
||||||
|
result = rpc.oraclessubscribe(globals()["oracle_{}".format(f)], self.pubkey, "1")
|
||||||
|
assert_success(result)
|
||||||
|
subscribe_txid = self.send_and_mine(result["hex"], rpc)
|
||||||
|
assert register_txid, "got txid"
|
||||||
|
|
||||||
|
# now lets publish and read valid data for each oracle type
|
||||||
|
|
||||||
|
# s type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("s")], "05416e746f6e")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_s = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("s")], oraclesdata_s, "1")
|
||||||
|
assert_equal("[u'Anton']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# S type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("S")], "000161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_S = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("S")], oraclesdata_S, "1")
|
||||||
|
assert_equal("[u'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# d type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("d")], "0101")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_d = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("d")], oraclesdata_d, "1")
|
||||||
|
# TODO: working not correct now!
|
||||||
|
#assert_equal("[u'01']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# D type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("D")], "0101")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_D = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("D")], oraclesdata_D, "1")
|
||||||
|
# TODO: working not correct now!
|
||||||
|
#assert_equal("[u'01']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# c type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("c")], "ff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_c = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("c")], oraclesdata_c, "1")
|
||||||
|
assert_equal("[u'-1']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# C type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("C")], "ff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_C = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("C")], oraclesdata_C, "1")
|
||||||
|
assert_equal("[u'255']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# t type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("t")], "ffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_t = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("t")], oraclesdata_t, "1")
|
||||||
|
assert_equal("[u'-1']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# T type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("T")], "ffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_T = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("T")], oraclesdata_T, "1")
|
||||||
|
assert_equal("[u'65535']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# i type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("i")], "ffffffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_i = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("i")], oraclesdata_i, "1")
|
||||||
|
assert_equal("[u'-1']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# I type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("I")], "ffffffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_I = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("I")], oraclesdata_I, "1")
|
||||||
|
assert_equal("[u'4294967295']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# l type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("l")], "00000000ffffffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_l = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("l")], oraclesdata_l, "1")
|
||||||
|
# TODO: working not correct now!
|
||||||
|
#assert_equal("[u'-4294967296']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# L type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("L")], "00000000ffffffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_L = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("L")], oraclesdata_L, "1")
|
||||||
|
assert_equal("[u'18446744069414584320']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# h type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("h")], "00000000ffffffff00000000ffffffff00000000ffffffff00000000ffffffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_h = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("h")], oraclesdata_h, "1")
|
||||||
|
assert_equal("[u'ffffffff00000000ffffffff00000000ffffffff00000000ffffffff00000000']", str(result["samples"][0]), "Data match")
|
||||||
|
|
||||||
|
# Ihh type
|
||||||
|
result = rpc.oraclesdata(globals()["oracle_{}".format("Ihh")], "00000000ffffffff00000000ffffffff00000000ffffffff00000000ffffffff")
|
||||||
|
assert_success(result)
|
||||||
|
# baton
|
||||||
|
oraclesdata_Ihh = self.send_and_mine(result["hex"], rpc)
|
||||||
|
result = rpc.oraclessamples(globals()["oracle_{}".format("Ihh")], oraclesdata_Ihh, "1")
|
||||||
|
assert_equal("[u'0']", str(result["samples"][0]), "Data match")
|
||||||
|
assert_equal("[u'00000000ffffffff00000000ffffffff00000000ffffffff00000000ffffffff']", str(result["samples"][1]), "Data match")
|
||||||
|
assert_equal("[u'00000000ffffffff00000000ffffffff00000000ffffffff00000000ffffffff']", str(result["samples"][2]), "Data match")
|
||||||
|
|
||||||
|
|
||||||
def run_test(self):
|
def run_test(self):
|
||||||
print("Mining blocks...")
|
print("Mining blocks...")
|
||||||
@ -138,5 +288,6 @@ class CryptoconditionsOraclesTest(BitcoinTestFramework):
|
|||||||
rpc1.importprivkey(self.privkey1)
|
rpc1.importprivkey(self.privkey1)
|
||||||
self.run_oracles_tests()
|
self.run_oracles_tests()
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
CryptoconditionsOraclesTest().main()
|
CryptoconditionsOraclesTest().main()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user