diff --git a/test/functional/zerocoin_valid_public_spend.py b/test/functional/zerocoin_valid_public_spend.py new file mode 100755 index 0000000000000..76730661feea3 --- /dev/null +++ b/test/functional/zerocoin_valid_public_spend.py @@ -0,0 +1,73 @@ +#!/usr/bin/env python3 +# Copyright (c) 2019 The PIVX Core developers +# Distributed under the MIT software license, see the accompanying +# file COPYING or http://www.opensource.org/licenses/mit-license.php. + +''' +Covers the 'Wrapped Serials Attack' scenario +''' + +import random +from time import sleep + +from test_framework.authproxy import JSONRPCException +from test_framework.util import assert_equal, assert_greater_than + +from fake_stake.base_test import PIVX_FakeStakeTest + +class zPIVValidCoinSpendTest(PIVX_FakeStakeTest): + + def run_test(self): + self.description = "Covers the 'valid publicCoinSpend spend' scenario." + self.init_test() + + INITAL_MINED_BLOCKS = 301 # Blocks mined before minting + MORE_MINED_BLOCKS = 52 # Blocks mined after minting (before spending) + DENOM_TO_USE = 1 # zc denomination used for double spending attack + + # 1) Start mining blocks + self.log.info("Mining %d first blocks..." % INITAL_MINED_BLOCKS) + self.node.generate(INITAL_MINED_BLOCKS) + sleep(2) + + # 2) Mint zerocoins + self.log.info("Minting %d-denom zPIVs..." % DENOM_TO_USE) + self.node.mintzerocoin(DENOM_TO_USE) + self.node.generate(1) + sleep(2) + self.node.mintzerocoin(DENOM_TO_USE) + sleep(2) + + # 3) Mine more blocks and collect the mint + self.log.info("Mining %d more blocks..." % MORE_MINED_BLOCKS) + self.node.generate(MORE_MINED_BLOCKS) + sleep(2) + list = self.node.listmintedzerocoins(True, True) + mint = list[0] + + # 4) Get the raw zerocoin data + exported_zerocoins = self.node.exportzerocoins(False) + zc = [x for x in exported_zerocoins if mint["serial hash"] == x["id"]] + if len(zc) == 0: + raise AssertionError("mint not found") + + # 5) Spend the minted coin (mine six more blocks) + self.log.info("Spending the minted coin with serial %s and mining six more blocks..." % zc[0]["s"]) + txid = self.node.spendzerocoinmints([mint["serial hash"]])['txid'] + self.log.info("Spent on tx %s" % txid) + self.node.generate(6) + sleep(2) + + rawTx = self.node.getrawtransaction(txid, 1) + if rawTx is None: + self.log.warning("rawTx is: %s" % rawTx) + raise AssertionError("TEST FAILED") + else: + assert (rawTx["confirmations"] == 6) + + self.log.info("%s PASSED" % self.__class__.__name__) + + + +if __name__ == '__main__': + zPIVValidCoinSpendTest().main()