r1
This commit is contained in:
@@ -0,0 +1,54 @@
|
||||
#!/usr/bin/env python3
|
||||
# Copyright (c) 2019 The PIVX developers
|
||||
# Distributed under the MIT software license, see the accompanying
|
||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||
|
||||
'''
|
||||
Covers the scenario of a valid PoS block with a valid coinstake transaction where the
|
||||
coinstake input prevout is double spent in one of the other transactions in the same block.
|
||||
'''
|
||||
|
||||
from time import sleep
|
||||
|
||||
from fake_stake.base_test import Agrarian_FakeStakeTest
|
||||
|
||||
|
||||
class PoSDoubleSpend(Agrarian_FakeStakeTest):
|
||||
|
||||
def run_test(self):
|
||||
self.description = "Covers the scenario of a valid PoS block with a valid coinstake transaction where the coinstake input prevout is double spent in one of the other transactions in the same block."
|
||||
self.init_test()
|
||||
INITAL_MINED_BLOCKS = 300
|
||||
FORK_DEPTH = 30
|
||||
self.NUM_BLOCKS = 3
|
||||
|
||||
# 1) Starting mining blocks
|
||||
self.log.info("Mining %d blocks.." % INITAL_MINED_BLOCKS)
|
||||
self.node.generate(INITAL_MINED_BLOCKS)
|
||||
|
||||
# 2) Collect the possible prevouts
|
||||
self.log.info("Collecting all unspent coins which we generated from mining...")
|
||||
staking_utxo_list = self.node.listunspent()
|
||||
|
||||
# 3) Spam Blocks on the main chain
|
||||
self.log.info("-- Main chain blocks first")
|
||||
self.test_spam("Main", staking_utxo_list, fDoubleSpend=True)
|
||||
sleep(2)
|
||||
|
||||
# 4) Mine some block as buffer
|
||||
self.log.info("Mining %d more blocks..." % FORK_DEPTH)
|
||||
self.node.generate(FORK_DEPTH)
|
||||
sleep(2)
|
||||
|
||||
# 5) Spam Blocks on a forked chain
|
||||
self.log.info("-- Forked chain blocks now")
|
||||
err_msgs = self.test_spam("Forked", staking_utxo_list, fRandomHeight=True, randomRange=FORK_DEPTH, fDoubleSpend=True)
|
||||
|
||||
if not len(err_msgs) == 0:
|
||||
self.log.error("result: " + " | ".join(err_msgs))
|
||||
raise AssertionError("TEST FAILED")
|
||||
|
||||
self.log.info("%s PASSED" % self.__class__.__name__)
|
||||
|
||||
if __name__ == '__main__':
|
||||
PoSDoubleSpend().main()
|
||||
Reference in New Issue
Block a user