2018-07-12 15:05:24 -04:00
|
|
|
import tempfile
|
2019-02-11 21:35:07 -05:00
|
|
|
from integration.testcase import CommandTestCase
|
2018-08-16 21:42:38 -04:00
|
|
|
|
2018-07-04 22:16:02 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
class EpicAdventuresOfChris45(CommandTestCase):
|
2018-11-04 01:24:41 -05:00
|
|
|
|
2018-10-16 11:03:56 -04:00
|
|
|
async def test_no_this_is_not_a_test_its_an_adventure(self):
|
2018-07-31 22:59:51 -04:00
|
|
|
# Chris45 is an avid user of LBRY and this is his story. It's fact and fiction
|
|
|
|
# and everything in between; it's also the setting of some record setting
|
|
|
|
# integration tests.
|
2018-07-06 01:17:20 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# Chris45 starts everyday by checking his balance.
|
2018-10-16 11:03:56 -04:00
|
|
|
result = await self.daemon.jsonrpc_account_balance()
|
2018-10-03 17:28:17 -04:00
|
|
|
self.assertEqual(result, '10.0')
|
2018-07-31 22:59:51 -04:00
|
|
|
# "10 LBC, yippy! I can do a lot with that.", he thinks to himself,
|
|
|
|
# enthusiastically. But he is hungry so he goes into the kitchen
|
|
|
|
# to make himself a spamdwich.
|
2018-07-10 00:20:37 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# While making the spamdwich he wonders... has anyone on LBRY
|
|
|
|
# registered the @spam channel yet? "I should do that!" he
|
|
|
|
# exclaims and goes back to his computer to do just that!
|
2018-10-16 11:03:56 -04:00
|
|
|
channel = await self.out(self.daemon.jsonrpc_channel_new('@spam', "1.0"))
|
2018-07-16 23:32:37 -04:00
|
|
|
self.assertTrue(channel['success'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(channel['tx']['txid'])
|
2018-07-10 00:20:37 -04:00
|
|
|
|
2018-08-03 21:39:48 -04:00
|
|
|
# Do we have it locally?
|
2018-10-16 11:03:56 -04:00
|
|
|
channels = await self.out(self.daemon.jsonrpc_channel_list())
|
2018-08-03 21:39:48 -04:00
|
|
|
self.assertEqual(len(channels), 1)
|
2018-08-04 12:10:41 -04:00
|
|
|
self.assertEqual(channels[0]['name'], '@spam')
|
2018-08-03 21:39:48 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# As the new channel claim travels through the intertubes and makes its
|
|
|
|
# way into the mempool and then a block and then into the claimtrie,
|
|
|
|
# Chris doesn't sit idly by: he checks his balance!
|
|
|
|
|
2018-10-16 11:03:56 -04:00
|
|
|
result = await self.daemon.jsonrpc_account_balance()
|
2018-10-03 17:28:17 -04:00
|
|
|
self.assertEqual(result, '8.989893')
|
2018-07-21 21:12:33 -04:00
|
|
|
|
2018-10-08 10:54:40 -04:00
|
|
|
# He waits for 6 more blocks (confirmations) to make sure the balance has been settled.
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(6)
|
|
|
|
result = await self.daemon.jsonrpc_account_balance(confirmations=6)
|
2018-10-03 17:28:17 -04:00
|
|
|
self.assertEqual(result, '8.989893')
|
2018-07-31 22:59:51 -04:00
|
|
|
|
2018-08-04 12:10:41 -04:00
|
|
|
# And is the channel resolvable and empty?
|
2019-02-11 21:35:07 -05:00
|
|
|
response = await self.out(self.daemon.jsonrpc_resolve('lbry://@spam'))
|
2018-08-04 12:10:41 -04:00
|
|
|
self.assertIn('lbry://@spam', response)
|
|
|
|
self.assertIn('certificate', response['lbry://@spam'])
|
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# "What goes well with spam?" ponders Chris...
|
|
|
|
# "A hovercraft with eels!" he exclaims.
|
|
|
|
# "That's what goes great with spam!" he further confirms.
|
2018-07-21 21:12:33 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# And so, many hours later, Chris is finished writing his epic story
|
|
|
|
# about eels driving a hovercraft across the wetlands while eating spam
|
|
|
|
# and decides it's time to publish it to the @spam channel.
|
2018-07-12 15:05:24 -04:00
|
|
|
with tempfile.NamedTemporaryFile() as file:
|
2018-07-31 22:59:51 -04:00
|
|
|
file.write(b'blah blah blah...')
|
|
|
|
file.write(b'[insert long story about eels driving hovercraft]')
|
|
|
|
file.write(b'yada yada yada!')
|
|
|
|
file.write(b'the end')
|
2018-07-12 15:05:24 -04:00
|
|
|
file.flush()
|
2018-10-16 11:03:56 -04:00
|
|
|
claim1 = await self.out(self.daemon.jsonrpc_publish(
|
2018-09-24 00:30:24 -04:00
|
|
|
'hovercraft', '1.0', file_path=file.name, channel_id=channel['claim_id']
|
2018-08-16 21:42:38 -04:00
|
|
|
))
|
2018-07-31 22:59:51 -04:00
|
|
|
self.assertTrue(claim1['success'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(claim1['tx']['txid'])
|
2018-07-29 19:15:06 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# He quickly checks the unconfirmed balance to make sure everything looks
|
|
|
|
# correct.
|
2018-10-16 11:03:56 -04:00
|
|
|
result = await self.daemon.jsonrpc_account_balance()
|
2018-10-03 17:28:17 -04:00
|
|
|
self.assertEqual(result, '7.969786')
|
2018-07-29 19:15:06 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# Also checks that his new story can be found on the blockchain before
|
|
|
|
# giving the link to all his friends.
|
2019-02-11 21:35:07 -05:00
|
|
|
response = await self.out(self.daemon.jsonrpc_resolve('lbry://@spam/hovercraft'))
|
2018-07-29 19:15:06 -04:00
|
|
|
self.assertIn('lbry://@spam/hovercraft', response)
|
2018-08-03 21:39:48 -04:00
|
|
|
self.assertIn('claim', response['lbry://@spam/hovercraft'])
|
2018-07-29 19:15:06 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# He goes to tell everyone about it and in the meantime 5 blocks are confirmed.
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
2018-07-31 22:59:51 -04:00
|
|
|
# When he comes back he verifies the confirmed balance.
|
2018-10-16 11:03:56 -04:00
|
|
|
result = await self.daemon.jsonrpc_account_balance()
|
2018-10-03 17:28:17 -04:00
|
|
|
self.assertEqual(result, '7.969786')
|
2018-07-29 19:15:06 -04:00
|
|
|
|
2018-07-31 22:59:51 -04:00
|
|
|
# As people start reading his story they discover some typos and notify
|
|
|
|
# Chris who explains in despair "Oh! Noooooos!" but then remembers
|
|
|
|
# "No big deal! I can update my claim." And so he updates his claim.
|
2018-07-29 19:15:06 -04:00
|
|
|
with tempfile.NamedTemporaryFile() as file:
|
2018-07-31 22:59:51 -04:00
|
|
|
file.write(b'blah blah blah...')
|
|
|
|
file.write(b'[typo fixing sounds being made]')
|
|
|
|
file.write(b'yada yada yada!')
|
2018-07-29 19:15:06 -04:00
|
|
|
file.flush()
|
2018-10-16 11:03:56 -04:00
|
|
|
claim2 = await self.out(self.daemon.jsonrpc_publish(
|
2018-09-24 00:30:24 -04:00
|
|
|
'hovercraft', '1.0', file_path=file.name, channel_name='@spam'
|
2018-08-16 21:42:38 -04:00
|
|
|
))
|
2018-07-31 22:59:51 -04:00
|
|
|
self.assertTrue(claim2['success'])
|
2018-08-04 12:10:41 -04:00
|
|
|
self.assertEqual(claim2['claim_id'], claim1['claim_id'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(claim2['tx']['txid'])
|
2018-07-31 22:59:51 -04:00
|
|
|
|
|
|
|
# After some soul searching Chris decides that his story needs more
|
|
|
|
# heart and a better ending. He takes down the story and begins the rewrite.
|
2018-11-07 18:07:33 -05:00
|
|
|
abandon = await self.out(self.daemon.jsonrpc_claim_abandon(claim1['claim_id'], blocking=False))
|
2018-07-31 22:59:51 -04:00
|
|
|
self.assertTrue(abandon['success'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(abandon['tx']['txid'])
|
2018-08-03 21:39:48 -04:00
|
|
|
|
2018-09-20 23:25:04 +05:30
|
|
|
# And now checks that the claim doesn't resolve anymore.
|
2019-02-11 21:35:07 -05:00
|
|
|
response = await self.out(self.daemon.jsonrpc_resolve('lbry://@spam/hovercraft'))
|
2018-08-03 21:39:48 -04:00
|
|
|
self.assertNotIn('claim', response['lbry://@spam/hovercraft'])
|
2018-08-30 00:04:25 -04:00
|
|
|
|
2018-09-03 21:11:30 +05:30
|
|
|
# After abandoning he just waits for his LBCs to be returned to his account
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
|
|
|
result = await self.daemon.jsonrpc_account_balance()
|
2019-01-18 00:50:43 -03:00
|
|
|
self.assertEqual(result, '8.9693585')
|
2018-09-03 21:11:30 +05:30
|
|
|
|
2018-09-03 21:11:40 +05:30
|
|
|
# Amidst all this Chris receives a call from his friend Ramsey
|
|
|
|
# who says that it is of utmost urgency that Chris transfer him
|
|
|
|
# 1 LBC to which Chris readily obliges
|
2018-10-16 11:03:56 -04:00
|
|
|
ramsey_account_id = (await self.daemon.jsonrpc_account_create("Ramsey"))['id']
|
2018-09-21 11:40:02 -04:00
|
|
|
ramsey_account = self.daemon.get_account_or_error(ramsey_account_id)
|
2018-10-16 11:03:56 -04:00
|
|
|
ramsey_address = await self.daemon.jsonrpc_address_unused(ramsey_account_id)
|
|
|
|
result = await self.out(self.daemon.jsonrpc_wallet_send('1.0', ramsey_address))
|
2018-09-03 21:11:30 +05:30
|
|
|
self.assertIn("txid", result)
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(result['txid'])
|
2018-09-03 21:11:30 +05:30
|
|
|
|
2018-09-03 21:11:40 +05:30
|
|
|
# Chris then eagerly waits for 6 confirmations to check his balance and then calls Ramsey to verify whether
|
2018-09-03 21:11:30 +05:30
|
|
|
# he received it or not
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
|
|
|
result = await self.daemon.jsonrpc_account_balance()
|
2018-09-03 21:11:40 +05:30
|
|
|
# Chris' balance was correct
|
2019-01-18 00:50:43 -03:00
|
|
|
self.assertEqual(result, '7.9692345')
|
2018-09-03 21:11:30 +05:30
|
|
|
|
2018-09-03 21:11:40 +05:30
|
|
|
# Ramsey too assured him that he had received the 1 LBC and thanks him
|
2018-10-16 11:03:56 -04:00
|
|
|
result = await self.daemon.jsonrpc_account_balance(ramsey_account_id)
|
2018-10-03 17:28:17 -04:00
|
|
|
self.assertEqual(result, '1.0')
|
2018-09-03 21:11:30 +05:30
|
|
|
|
2018-09-03 21:11:40 +05:30
|
|
|
# After Chris is done with all the "helping other people" stuff he decides that it's time to
|
|
|
|
# write a new story and publish it to lbry. All he needed was a fresh start and he came up with:
|
|
|
|
with tempfile.NamedTemporaryFile() as file:
|
|
|
|
file.write(b'Amazingly Original First Line')
|
|
|
|
file.write(b'Super plot for the grand novel')
|
|
|
|
file.write(b'Totally un-cliched ending')
|
|
|
|
file.write(b'**Audience Gasps**')
|
|
|
|
file.flush()
|
2018-10-16 15:04:20 -04:00
|
|
|
claim3 = await self.out(self.daemon.jsonrpc_publish(
|
2018-09-24 00:30:24 -04:00
|
|
|
'fresh-start', '1.0', file_path=file.name, channel_name='@spam'
|
2018-09-03 21:11:40 +05:30
|
|
|
))
|
|
|
|
self.assertTrue(claim3['success'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(claim3['tx']['txid'])
|
2018-09-03 21:11:40 +05:30
|
|
|
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
2018-09-03 21:11:40 +05:30
|
|
|
|
|
|
|
# He gives the link of his story to all his friends and hopes that this is the much needed break for him
|
|
|
|
uri = 'lbry://@spam/fresh-start'
|
|
|
|
|
|
|
|
# And voila, and bravo and encore! His Best Friend Ramsey read the story and immediately knew this was a hit
|
|
|
|
# Now to keep this claim winning on the lbry blockchain he immediately supports the claim
|
2018-10-16 11:03:56 -04:00
|
|
|
tx = await self.out(self.daemon.jsonrpc_claim_new_support(
|
2018-09-24 00:30:24 -04:00
|
|
|
'fresh-start', claim3['claim_id'], '0.2', account_id=ramsey_account_id
|
2018-09-03 21:11:40 +05:30
|
|
|
))
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(tx['txid'])
|
2018-09-03 21:11:40 +05:30
|
|
|
|
|
|
|
# And check if his support showed up
|
2019-02-11 21:35:07 -05:00
|
|
|
resolve_result = await self.out(self.daemon.jsonrpc_resolve(uri))
|
2018-09-03 21:11:40 +05:30
|
|
|
# It obviously did! Because, blockchain baby \O/
|
2018-11-30 16:11:23 -05:00
|
|
|
self.assertEqual(resolve_result[uri]['claim']['amount'], '1.0')
|
|
|
|
self.assertEqual(resolve_result[uri]['claim']['effective_amount'], '1.2')
|
|
|
|
self.assertEqual(resolve_result[uri]['claim']['supports'][0]['amount'], '0.2')
|
2018-09-03 21:11:40 +05:30
|
|
|
self.assertEqual(resolve_result[uri]['claim']['supports'][0]['txid'], tx['txid'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
2018-09-03 21:11:40 +05:30
|
|
|
|
|
|
|
# Now he also wanted to support the original creator of the Award Winning Novel
|
|
|
|
# So he quickly decides to send a tip to him
|
2018-10-16 11:03:56 -04:00
|
|
|
tx = await self.out(
|
2018-09-24 00:30:24 -04:00
|
|
|
self.daemon.jsonrpc_claim_tip(claim3['claim_id'], '0.3', account_id=ramsey_account_id))
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(tx['txid'])
|
2018-09-03 21:11:40 +05:30
|
|
|
|
|
|
|
# And again checks if it went to the just right place
|
2019-02-11 21:35:07 -05:00
|
|
|
resolve_result = await self.out(self.daemon.jsonrpc_resolve(uri))
|
2018-09-03 21:11:40 +05:30
|
|
|
# Which it obviously did. Because....?????
|
2018-11-30 16:11:23 -05:00
|
|
|
self.assertEqual(resolve_result[uri]['claim']['supports'][1]['amount'], '0.3')
|
2018-09-03 21:11:40 +05:30
|
|
|
self.assertEqual(resolve_result[uri]['claim']['supports'][1]['txid'], tx['txid'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
2018-09-05 00:35:45 +05:30
|
|
|
|
|
|
|
# Seeing the ravishing success of his novel Chris adds support to his claim too
|
2018-10-16 11:03:56 -04:00
|
|
|
tx = await self.out(self.daemon.jsonrpc_claim_new_support('fresh-start', claim3['claim_id'], '0.4'))
|
|
|
|
await self.confirm_tx(tx['txid'])
|
2018-09-05 00:35:45 +05:30
|
|
|
|
|
|
|
# And check if his support showed up
|
2019-02-11 21:35:07 -05:00
|
|
|
resolve_result = await self.out(self.daemon.jsonrpc_resolve(uri))
|
2018-09-05 00:35:45 +05:30
|
|
|
# It did!
|
2018-11-30 16:11:23 -05:00
|
|
|
self.assertEqual(resolve_result[uri]['claim']['supports'][2]['amount'], '0.4')
|
2018-09-05 00:35:45 +05:30
|
|
|
self.assertEqual(resolve_result[uri]['claim']['supports'][2]['txid'], tx['txid'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
2018-09-03 21:11:40 +05:30
|
|
|
|
2018-09-20 23:25:04 +05:30
|
|
|
# Now Ramsey who is a singer by profession, is preparing for his new "gig". He has everything in place for that
|
|
|
|
# the instruments, the theatre, the ads, everything, EXCEPT lyrics!! He panicked.. But then he remembered
|
|
|
|
# something, so he un-panicked. He quickly calls up his best bud Chris and requests him to write hit lyrics for
|
|
|
|
# his song, seeing as his novel had smashed all the records, he was the perfect candidate!
|
|
|
|
# .......
|
|
|
|
# Chris agrees.. 17 hours 43 minutes and 14 seconds later, he makes his publish
|
|
|
|
with tempfile.NamedTemporaryFile() as file:
|
|
|
|
file.write(b'The Whale amd The Bookmark')
|
|
|
|
file.write(b'I know right? Totally a hit song')
|
|
|
|
file.write(b'That\'s what goes around for songs these days anyways')
|
|
|
|
file.flush()
|
2018-10-16 15:04:20 -04:00
|
|
|
claim4 = await self.out(self.daemon.jsonrpc_publish(
|
2018-09-24 00:30:24 -04:00
|
|
|
'hit-song', '1.0', file_path=file.name, channel_id=channel['claim_id']
|
2018-09-20 23:25:04 +05:30
|
|
|
))
|
|
|
|
self.assertTrue(claim4['success'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(claim4['tx']['txid'])
|
2018-09-20 23:25:04 +05:30
|
|
|
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.generate(5)
|
2018-09-20 23:25:04 +05:30
|
|
|
|
|
|
|
# He sends the link to Ramsey, all happy and proud
|
|
|
|
uri = 'lbry://@spam/hit-song'
|
|
|
|
|
|
|
|
# But sadly Ramsey wasn't so pleased. It was hard for him to tell Chris...
|
|
|
|
# Chris, though a bit heartbroken, abandoned the claim for now, but instantly started working on new hit lyrics
|
2018-11-07 18:07:33 -05:00
|
|
|
abandon = await self.out(self.daemon.jsonrpc_claim_abandon(txid=claim4['tx']['txid'], nout=0, blocking=False))
|
2018-09-20 23:25:04 +05:30
|
|
|
self.assertTrue(abandon['success'])
|
2018-10-16 11:03:56 -04:00
|
|
|
await self.confirm_tx(abandon['tx']['txid'])
|
2018-09-20 23:25:04 +05:30
|
|
|
|
|
|
|
# He them checks that the claim doesn't resolve anymore.
|
2019-02-11 21:35:07 -05:00
|
|
|
response = await self.out(self.daemon.jsonrpc_resolve(uri))
|
2018-09-20 23:25:04 +05:30
|
|
|
self.assertNotIn('claim', response[uri])
|