forked from LBRYCommunity/lbry-sdk
add tests for claim_list_by_channel
This commit is contained in:
parent
ba59e126cd
commit
d1b0180437
1 changed files with 39 additions and 4 deletions
|
@ -487,7 +487,7 @@ class ClaimManagement(CommandTestCase):
|
||||||
|
|
||||||
VERBOSITY = logging.WARN
|
VERBOSITY = logging.WARN
|
||||||
|
|
||||||
async def make_claim(self, name='hovercraft', amount='1.0', data=b'hi!', channel_name=None):
|
async def make_claim(self, name='hovercraft', amount='1.0', data=b'hi!', channel_name=None, confirm=True):
|
||||||
with tempfile.NamedTemporaryFile() as file:
|
with tempfile.NamedTemporaryFile() as file:
|
||||||
file.write(data)
|
file.write(data)
|
||||||
file.flush()
|
file.flush()
|
||||||
|
@ -495,6 +495,7 @@ class ClaimManagement(CommandTestCase):
|
||||||
name, amount, file_path=file.name, channel_name=channel_name
|
name, amount, file_path=file.name, channel_name=channel_name
|
||||||
))
|
))
|
||||||
self.assertTrue(claim['success'])
|
self.assertTrue(claim['success'])
|
||||||
|
if confirm:
|
||||||
await self.on_transaction_dict(claim['tx'])
|
await self.on_transaction_dict(claim['tx'])
|
||||||
await self.generate(1)
|
await self.generate(1)
|
||||||
await self.on_transaction_dict(claim['tx'])
|
await self.on_transaction_dict(claim['tx'])
|
||||||
|
@ -711,6 +712,40 @@ class ClaimManagement(CommandTestCase):
|
||||||
self.assertTrue(response[uri]['claim']['signature_is_valid'])
|
self.assertTrue(response[uri]['claim']['signature_is_valid'])
|
||||||
self.assertEqual(response[uri]['claim']['txid'], original_claim['tx']['txid'])
|
self.assertEqual(response[uri]['claim']['txid'], original_claim['tx']['txid'])
|
||||||
|
|
||||||
|
async def test_claim_list_by_channel(self):
|
||||||
|
self.maxDiff = None
|
||||||
|
tx = await self.daemon.jsonrpc_account_fund(None, None, '0.001', outputs=100, broadcast=True)
|
||||||
|
await self.ledger.wait(tx)
|
||||||
|
await self.generate(1)
|
||||||
|
await self.ledger.wait(tx)
|
||||||
|
channel = await self.out(self.daemon.jsonrpc_channel_new('@abc', "0.0001"))
|
||||||
|
self.assertTrue(channel['success'])
|
||||||
|
await self.confirm_tx(channel['tx']['txid'])
|
||||||
|
|
||||||
|
# 4 claims per block, 3 blocks. Sorted by height (descending) then claim_id (ascending).
|
||||||
|
claims = []
|
||||||
|
for j in range(3):
|
||||||
|
same_height_claims = []
|
||||||
|
for k in range(3):
|
||||||
|
claim = await self.make_claim(amount='0.000001', name=f'c{j}-{k}', channel_name='@abc', confirm=False)
|
||||||
|
self.assertTrue(claim['success'])
|
||||||
|
same_height_claims.append(claim['claim_id'])
|
||||||
|
await self.on_transaction_dict(claim['tx'])
|
||||||
|
claim = await self.make_claim(amount='0.000001', name=f'c{j}-4', channel_name='@abc', confirm=True)
|
||||||
|
self.assertTrue(claim['success'])
|
||||||
|
same_height_claims.append(claim['claim_id'])
|
||||||
|
same_height_claims.sort(key=lambda x: int(x, 16))
|
||||||
|
claims = same_height_claims + claims
|
||||||
|
|
||||||
|
page = await self.out(self.daemon.jsonrpc_claim_list_by_channel(1, page_size=20, uri='@abc'))
|
||||||
|
page_claim_ids = [item['claim_id'] for item in page['@abc']['claims_in_channel']]
|
||||||
|
self.assertEqual(page_claim_ids, claims)
|
||||||
|
page = await self.out(self.daemon.jsonrpc_claim_list_by_channel(1, page_size=6, uri='@abc'))
|
||||||
|
page_claim_ids = [item['claim_id'] for item in page['@abc']['claims_in_channel']]
|
||||||
|
self.assertEqual(page_claim_ids, claims[:6])
|
||||||
|
out_of_bounds = await self.out(self.daemon.jsonrpc_claim_list_by_channel(2, page_size=20, uri='@abc'))
|
||||||
|
self.assertEqual(out_of_bounds['error'], 'claim 20 greater than max 12')
|
||||||
|
|
||||||
async def test_regular_supports_and_tip_supports(self):
|
async def test_regular_supports_and_tip_supports(self):
|
||||||
# account2 will be used to send tips and supports to account1
|
# account2 will be used to send tips and supports to account1
|
||||||
account2_id = (await self.daemon.jsonrpc_account_create('second account'))['id']
|
account2_id = (await self.daemon.jsonrpc_account_create('second account'))['id']
|
||||||
|
|
Loading…
Add table
Reference in a new issue