2019-01-11 19:49:23 -03:00
|
|
|
import binascii
|
2018-11-04 01:24:41 -05:00
|
|
|
import logging
|
2018-06-12 11:53:29 -04:00
|
|
|
import asyncio
|
2018-06-26 17:27:24 -04:00
|
|
|
|
2019-01-11 19:49:23 -03:00
|
|
|
from lbrynet.schema.address import decode_address
|
2018-12-21 16:18:44 -03:00
|
|
|
from lbrynet.schema.schema import SECP256k1
|
2019-01-11 19:49:23 -03:00
|
|
|
from lbrynet.schema.signature import Signature, NAMED_SECP256K1
|
|
|
|
from lbrynet.schema.signer import get_signer
|
2018-11-04 01:24:41 -05:00
|
|
|
from torba.testcase import IntegrationTestCase
|
2018-09-17 17:31:44 -03:00
|
|
|
from lbrynet.schema.claim import ClaimDict
|
2018-11-04 04:42:47 -05:00
|
|
|
from lbrynet.extras.wallet.transaction import Transaction
|
|
|
|
from lbrynet.extras.wallet.account import generate_certificate
|
|
|
|
from lbrynet.extras.wallet.dewies import dewies_to_lbc as d2l, lbc_to_dewies as l2d
|
2018-06-26 17:27:24 -04:00
|
|
|
|
2018-09-17 17:31:44 -03:00
|
|
|
import lbrynet.schema
|
|
|
|
lbrynet.schema.BLOCKCHAIN_NAME = 'lbrycrd_regtest'
|
2018-06-12 11:53:29 -04:00
|
|
|
|
|
|
|
|
|
|
|
example_claim_dict = {
|
|
|
|
"version": "_0_0_1",
|
|
|
|
"claimType": "streamType",
|
|
|
|
"stream": {
|
|
|
|
"source": {
|
|
|
|
"source": "d5169241150022f996fa7cd6a9a1c421937276a3275eb912790bd07ba7aec1fac5fd45431d226b8fb402691e79aeb24b",
|
|
|
|
"version": "_0_0_1",
|
|
|
|
"contentType": "video/mp4",
|
|
|
|
"sourceType": "lbry_sd_hash"
|
|
|
|
},
|
|
|
|
"version": "_0_0_1",
|
|
|
|
"metadata": {
|
|
|
|
"license": "LBRY Inc",
|
|
|
|
"description": "What is LBRY? An introduction with Alex Tabarrok",
|
|
|
|
"language": "en",
|
|
|
|
"title": "What is LBRY?",
|
|
|
|
"author": "Samuel Bryan",
|
|
|
|
"version": "_0_1_0",
|
|
|
|
"nsfw": False,
|
|
|
|
"licenseUrl": "",
|
|
|
|
"preview": "",
|
|
|
|
"thumbnail": "https://s3.amazonaws.com/files.lbry.io/logo.png"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-07-09 17:04:59 -04:00
|
|
|
class BasicTransactionTest(IntegrationTestCase):
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-11-04 01:24:41 -05:00
|
|
|
VERBOSITY = logging.WARN
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-06-26 17:27:24 -04:00
|
|
|
async def test_creating_updating_and_abandoning_claim_with_channel(self):
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-10-15 17:16:43 -04:00
|
|
|
await self.account.ensure_address_gap()
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-10-15 17:16:43 -04:00
|
|
|
address1, address2 = await self.account.receiving.get_addresses(limit=2, only_usable=True)
|
2018-07-14 23:03:51 -04:00
|
|
|
sendtxid1 = await self.blockchain.send_to_address(address1, 5)
|
|
|
|
sendtxid2 = await self.blockchain.send_to_address(address2, 5)
|
2018-06-14 01:32:11 -04:00
|
|
|
await self.blockchain.generate(1)
|
2018-06-26 17:27:24 -04:00
|
|
|
await asyncio.wait([
|
|
|
|
self.on_transaction_id(sendtxid1),
|
2018-10-16 21:28:47 -04:00
|
|
|
self.on_transaction_id(sendtxid2)
|
2018-06-26 17:27:24 -04:00
|
|
|
])
|
2018-06-14 01:32:11 -04:00
|
|
|
|
2018-10-15 17:16:43 -04:00
|
|
|
self.assertEqual(d2l(await self.account.get_balance()), '10.0')
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-06-26 17:27:24 -04:00
|
|
|
cert, key = generate_certificate()
|
2018-10-15 17:16:43 -04:00
|
|
|
cert_tx = await Transaction.claim('@bar', cert, l2d('1.0'), address1, [self.account], self.account)
|
2018-06-12 11:53:29 -04:00
|
|
|
claim = ClaimDict.load_dict(example_claim_dict)
|
2018-12-31 01:08:02 -03:00
|
|
|
claim = claim.sign(key, address1, cert_tx.outputs[0].claim_id, name='foo')
|
2018-10-15 17:16:43 -04:00
|
|
|
claim_tx = await Transaction.claim('foo', claim, l2d('1.0'), address1, [self.account], self.account)
|
2018-06-26 17:27:24 -04:00
|
|
|
|
|
|
|
await self.broadcast(cert_tx)
|
2018-07-09 17:04:59 -04:00
|
|
|
await self.broadcast(claim_tx)
|
2018-06-26 17:27:24 -04:00
|
|
|
await asyncio.wait([ # mempool
|
2018-11-07 16:12:03 -05:00
|
|
|
self.ledger.wait(claim_tx),
|
|
|
|
self.ledger.wait(cert_tx)
|
2018-06-26 17:27:24 -04:00
|
|
|
])
|
2018-06-14 01:32:11 -04:00
|
|
|
await self.blockchain.generate(1)
|
2018-06-26 17:27:24 -04:00
|
|
|
await asyncio.wait([ # confirmed
|
2018-11-07 16:12:03 -05:00
|
|
|
self.ledger.wait(claim_tx),
|
|
|
|
self.ledger.wait(cert_tx)
|
2018-06-26 17:27:24 -04:00
|
|
|
])
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-10-16 21:28:47 -04:00
|
|
|
self.assertEqual(d2l(await self.account.get_balance()), '7.985786')
|
2018-10-15 17:16:43 -04:00
|
|
|
self.assertEqual(d2l(await self.account.get_balance(include_claims=True)), '9.985786')
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-10-15 17:16:43 -04:00
|
|
|
response = await self.ledger.resolve(0, 10, 'lbry://@bar/foo')
|
2018-06-26 17:27:24 -04:00
|
|
|
self.assertIn('lbry://@bar/foo', response)
|
2018-08-03 22:27:08 -03:00
|
|
|
self.assertIn('claim', response['lbry://@bar/foo'])
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-10-15 17:16:43 -04:00
|
|
|
abandon_tx = await Transaction.abandon([claim_tx.outputs[0]], [self.account], self.account)
|
2018-07-09 17:04:59 -04:00
|
|
|
await self.broadcast(abandon_tx)
|
2018-11-07 16:12:03 -05:00
|
|
|
await self.ledger.wait(abandon_tx)
|
2018-07-09 17:04:59 -04:00
|
|
|
await self.blockchain.generate(1)
|
2018-11-07 16:12:03 -05:00
|
|
|
await self.ledger.wait(abandon_tx)
|
2018-06-12 11:53:29 -04:00
|
|
|
|
2018-10-15 17:16:43 -04:00
|
|
|
response = await self.ledger.resolve(0, 10, 'lbry://@bar/foo')
|
2018-08-03 22:27:08 -03:00
|
|
|
self.assertNotIn('claim', response['lbry://@bar/foo'])
|
2018-09-27 01:56:04 -03:00
|
|
|
|
|
|
|
# checks for expected format in inexistent URIs
|
2018-10-15 17:16:43 -04:00
|
|
|
response = await self.ledger.resolve(0, 10, 'lbry://404', 'lbry://@404')
|
2018-09-27 01:56:04 -03:00
|
|
|
self.assertEqual('URI lbry://404 cannot be resolved', response['lbry://404']['error'])
|
|
|
|
self.assertEqual('URI lbry://@404 cannot be resolved', response['lbry://@404']['error'])
|
2018-12-21 16:18:44 -03:00
|
|
|
|
|
|
|
async def test_new_signature_model(self):
|
|
|
|
address1, address2 = await self.account.receiving.get_addresses(limit=2, only_usable=True)
|
|
|
|
sendtxid1 = await self.blockchain.send_to_address(address1, 5)
|
|
|
|
sendtxid2 = await self.blockchain.send_to_address(address2, 5)
|
|
|
|
await self.blockchain.generate(1)
|
|
|
|
await asyncio.wait([
|
|
|
|
self.on_transaction_id(sendtxid1),
|
|
|
|
self.on_transaction_id(sendtxid2)
|
|
|
|
])
|
|
|
|
|
|
|
|
self.assertEqual(d2l(await self.account.get_balance()), '10.0')
|
|
|
|
|
|
|
|
cert, key = generate_certificate()
|
|
|
|
cert_tx = await Transaction.claim('@bar', cert, l2d('1.0'), address1, [self.account], self.account)
|
|
|
|
claim = ClaimDict.load_dict(example_claim_dict)
|
2019-01-05 06:02:43 -03:00
|
|
|
claim = claim.sign(key, address1, cert_tx.outputs[0].claim_id, name='foo', curve=SECP256k1, force_detached=True)
|
2018-12-21 16:18:44 -03:00
|
|
|
claim_tx = await Transaction.claim('foo', claim, l2d('1.0'), address1, [self.account], self.account)
|
|
|
|
|
|
|
|
await self.broadcast(cert_tx)
|
|
|
|
await self.broadcast(claim_tx)
|
|
|
|
await self.ledger.wait(claim_tx)
|
|
|
|
await self.blockchain.generate(1)
|
|
|
|
await self.ledger.wait(claim_tx)
|
|
|
|
|
|
|
|
response = await self.ledger.resolve(0, 10, 'lbry://@bar/foo')
|
|
|
|
self.assertIn('lbry://@bar/foo', response)
|
|
|
|
self.assertIn('claim', response['lbry://@bar/foo'])
|
2019-01-11 19:49:23 -03:00
|
|
|
|
|
|
|
async def test_new_signature_model_from_unserializable_claim(self):
|
|
|
|
address1, address2 = await self.account.receiving.get_addresses(limit=2, only_usable=True)
|
|
|
|
sendtxid1 = await self.blockchain.send_to_address(address1, 5)
|
|
|
|
sendtxid2 = await self.blockchain.send_to_address(address2, 5)
|
|
|
|
await self.blockchain.generate(1)
|
|
|
|
await asyncio.wait([
|
|
|
|
self.on_transaction_id(sendtxid1),
|
|
|
|
self.on_transaction_id(sendtxid2)
|
|
|
|
])
|
|
|
|
|
|
|
|
self.assertEqual(d2l(await self.account.get_balance()), '10.0')
|
|
|
|
|
|
|
|
cert, key = generate_certificate()
|
|
|
|
cert_tx = await Transaction.claim('@bar', cert, l2d('1.0'), address1, [self.account], self.account)
|
|
|
|
original = ClaimDict.load_dict(example_claim_dict).serialized
|
|
|
|
altered = original + b'\x00\x01\x02\x30\x50\x80\x99' # pretend this extra trash is from some unknown protobuf
|
|
|
|
|
|
|
|
# manually sign
|
|
|
|
signer = get_signer(SECP256k1).load_pem(key)
|
|
|
|
signature = signer.sign(
|
|
|
|
b'foo',
|
|
|
|
decode_address(address1),
|
|
|
|
altered,
|
|
|
|
binascii.unhexlify(cert_tx.outputs[0].claim_id),
|
|
|
|
)
|
|
|
|
detached_sig = Signature(NAMED_SECP256K1(
|
|
|
|
signature,
|
|
|
|
binascii.unhexlify(cert_tx.outputs[0].claim_id),
|
|
|
|
altered
|
|
|
|
))
|
|
|
|
claim_tx = await Transaction.claim('foo', detached_sig, l2d('1.0'), address1, [self.account], self.account)
|
|
|
|
|
|
|
|
await self.broadcast(cert_tx)
|
|
|
|
await self.broadcast(claim_tx)
|
|
|
|
await self.ledger.wait(claim_tx)
|
|
|
|
await self.blockchain.generate(1)
|
|
|
|
await self.ledger.wait(claim_tx)
|
|
|
|
|
|
|
|
response = await self.ledger.resolve(0, 10, 'lbry://@bar/foo')
|
|
|
|
self.assertIn('lbry://@bar/foo', response)
|
|
|
|
self.assertIn('claim', response['lbry://@bar/foo'])
|