mirror of
https://github.com/bigchaindb/bigchaindb.git
synced 2024-10-13 13:34:05 +00:00
Finalize serialization logic for tx class
This commit is contained in:
parent
50562fed43
commit
ee0de84a30
@ -1,16 +1,16 @@
|
|||||||
from pytest import raises
|
from pytest import raises
|
||||||
|
|
||||||
|
|
||||||
def test_fulfillment_serialization(ffill_uri, user_vk):
|
def test_fulfillment_serialization(ffill, user_vk):
|
||||||
from bigchaindb.transaction import (
|
from bigchaindb.transaction import (
|
||||||
Fulfillment,
|
Fulfillment,
|
||||||
)
|
)
|
||||||
|
|
||||||
ffill = Fulfillment(ffill_uri, [user_vk])
|
ffill = Fulfillment(ffill, [user_vk])
|
||||||
ffill_dict = ffill.to_dict()
|
ffill_dict = ffill.to_dict()
|
||||||
assert ffill_dict['owners_before'] == [user_vk]
|
assert ffill_dict['owners_before'] == [user_vk]
|
||||||
assert ffill_dict['input'] == None
|
assert ffill_dict['input'] == None
|
||||||
assert ffill_dict['fulfillment'] == ffill_uri
|
assert ffill_dict['fulfillment'] == ffill.fulfillment.serialize_uri()
|
||||||
assert ffill_dict['fid'] == 0
|
assert ffill_dict['fid'] == 0
|
||||||
|
|
||||||
|
|
||||||
@ -29,38 +29,36 @@ def test_fulfillment_deserialization(ffill_uri, user_vk):
|
|||||||
assert Fulfillment.from_dict(ffill_dict).to_dict() == ffill_dict
|
assert Fulfillment.from_dict(ffill_dict).to_dict() == ffill_dict
|
||||||
|
|
||||||
|
|
||||||
def test_invalid_fulfillment_initialization(ffill_uri, user_vk):
|
def test_invalid_fulfillment_initialization(ffill, user_vk):
|
||||||
from bigchaindb.transaction import (
|
from bigchaindb.transaction import (
|
||||||
Fulfillment,
|
Fulfillment,
|
||||||
)
|
)
|
||||||
with raises(TypeError):
|
with raises(TypeError):
|
||||||
Fulfillment(ffill_uri, user_vk)
|
Fulfillment(ffill, user_vk)
|
||||||
|
|
||||||
|
|
||||||
def test_condition_serialization(cond_uri, user_vk):
|
def test_condition_serialization(user_vk):
|
||||||
from bigchaindb.transaction import (
|
from bigchaindb.transaction import (
|
||||||
Condition,
|
Condition,
|
||||||
)
|
)
|
||||||
|
|
||||||
cond = Condition(cond_uri, [user_vk])
|
cond = Condition.gen_default(user_vk)
|
||||||
cond_dict = cond.to_dict()
|
cond_dict = cond.to_dict()
|
||||||
assert cond_dict['owners_after'] == [user_vk]
|
assert cond_dict['owners_after'] == [user_vk]
|
||||||
assert cond_dict['condition']['uri'] == cond_uri
|
assert cond_dict['condition']['uri'] == cond.condition.condition_uri
|
||||||
assert cond_dict['cid'] == 0
|
assert cond_dict['cid'] == 0
|
||||||
|
|
||||||
|
|
||||||
def test_condition_deserialization(cond_uri, user_vk):
|
def test_condition_deserialization(user_vk):
|
||||||
from bigchaindb.transaction import (
|
from bigchaindb.transaction import (
|
||||||
Condition,
|
Condition,
|
||||||
)
|
)
|
||||||
from cryptoconditions import (
|
|
||||||
Condition as CCCondition,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
cond = Condition.gen_default(user_vk)
|
||||||
cond_dict = {
|
cond_dict = {
|
||||||
'condition': {
|
'condition': {
|
||||||
'uri': cond_uri,
|
'uri': cond.condition.condition_uri,
|
||||||
'details': CCCondition.from_uri(cond_uri).to_dict()
|
'details': cond.condition.to_dict()
|
||||||
},
|
},
|
||||||
'owners_after': [user_vk],
|
'owners_after': [user_vk],
|
||||||
'cid': 0,
|
'cid': 0,
|
||||||
@ -69,12 +67,12 @@ def test_condition_deserialization(cond_uri, user_vk):
|
|||||||
assert Condition.from_dict(cond_dict).to_dict() == cond_dict
|
assert Condition.from_dict(cond_dict).to_dict() == cond_dict
|
||||||
|
|
||||||
|
|
||||||
def test_invalid_condition_initialization(cond_uri, user_vk):
|
def test_invalid_condition_initialization(ffill, user_vk):
|
||||||
from bigchaindb.transaction import (
|
from bigchaindb.transaction import (
|
||||||
Condition,
|
Condition,
|
||||||
)
|
)
|
||||||
with raises(TypeError):
|
with raises(TypeError):
|
||||||
Condition(cond_uri, user_vk)
|
Condition(ffill.condition, user_vk)
|
||||||
|
|
||||||
|
|
||||||
def test_gen_default_condition(user_vk):
|
def test_gen_default_condition(user_vk):
|
||||||
@ -82,8 +80,39 @@ def test_gen_default_condition(user_vk):
|
|||||||
Condition,
|
Condition,
|
||||||
)
|
)
|
||||||
from cryptoconditions import Ed25519Fulfillment
|
from cryptoconditions import Ed25519Fulfillment
|
||||||
cond = Condition.gen_default_condition(user_vk)
|
cond = Condition.gen_default(user_vk)
|
||||||
assert cond.owners_after == [user_vk]
|
assert cond.owners_after == [user_vk]
|
||||||
assert cond.cid == 0
|
assert cond.cid == 0
|
||||||
# TODO: Would be nice if Cryptoconditions would implement a `__eq__` method
|
# TODO: Would be nice if Cryptoconditions would implement a `__eq__` method
|
||||||
assert cond.condition.to_dict() == Ed25519Fulfillment(public_key=user_vk).condition.to_dict()
|
# NOTE: This doesn't make sense yet...
|
||||||
|
assert cond.condition.to_dict() == Ed25519Fulfillment(public_key=user_vk).to_dict()
|
||||||
|
|
||||||
|
|
||||||
|
def test_create_default_transaction(user_vk):
|
||||||
|
from bigchaindb.transaction import (
|
||||||
|
Condition,
|
||||||
|
Transaction,
|
||||||
|
)
|
||||||
|
cond = Condition.gen_default(user_vk)
|
||||||
|
tx = Transaction([cond])
|
||||||
|
assert tx.conditions == [cond]
|
||||||
|
assert tx.fulfillments == []
|
||||||
|
assert tx.inputs is None
|
||||||
|
assert tx.payload is None
|
||||||
|
|
||||||
|
|
||||||
|
def test_sign_default_transaction(user_vk, user_sk):
|
||||||
|
from bigchaindb.transaction import (
|
||||||
|
Fulfillment,
|
||||||
|
Transaction,
|
||||||
|
)
|
||||||
|
|
||||||
|
ffill = Fulfillment.gen_default(user_vk)
|
||||||
|
ffill.to_dict()
|
||||||
|
cond = ffill.gen_condition()
|
||||||
|
tx = Transaction(Transaction.CREATE, [ffill], [cond])
|
||||||
|
tx.sign([user_sk])
|
||||||
|
tx_dict = tx.to_dict()
|
||||||
|
# TODO: We need to make sure to serialize the transaction correctly!!!
|
||||||
|
assert len(tx.fulfillments) > 0
|
||||||
|
assert tx_dict['transaction']['conditions'][0] == cond.to_dict()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user