dash-docs/en/doxygen/html/pruning_8py_source.html

148 lines
92 KiB
HTML

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.14"/>
<meta name="viewport" content="width=device-width, initial-scale=1"/>
<title>Dash Core: qa/rpc-tests/pruning.py Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtreedata.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(document).ready(initResizable);
/* @license-end */</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/searchdata.js"></script>
<script type="text/javascript" src="search/search.js"></script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td id="projectlogo"><img alt="Logo" src="bitcoin_logo_doxygen.png"/></td>
<td id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">Dash Core
&#160;<span id="projectnumber">0.12.2.1</span>
</div>
<div id="projectbrief">P2P Digital Currency</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.14 -->
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
var searchBox = new SearchBox("searchBox", "search",false,'Search');
/* @license-end */
</script>
<script type="text/javascript" src="menudata.js"></script>
<script type="text/javascript" src="menu.js"></script>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(function() {
initMenu('',true,false,'search.php','Search');
$(document).ready(function() { init_search(); });
});
/* @license-end */</script>
<div id="main-nav"></div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
/* @license magnet:?xt=urn:btih:cf05388f2679ee054f2beb29a391d25f4e673ac3&amp;dn=gpl-2.0.txt GPL-v2 */
$(document).ready(function(){initNavTree('pruning_8py_source.html','');});
/* @license-end */
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
</div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
<div class="header">
<div class="headertitle">
<div class="title">pruning.py</div> </div>
</div><!--header-->
<div class="contents">
<a href="pruning_8py.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"><a class="line" href="namespacepruning.html"> 1</a></span>&#160;<span class="comment">#!/usr/bin/env python2</span></div><div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment"># Copyright (c) 2014-2015 The Bitcoin Core developers</span></div><div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment"># Distributed under the MIT software license, see the accompanying</span></div><div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;<span class="comment"># file COPYING or http://www.opensource.org/licenses/mit-license.php.</span></div><div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;</div><div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;<span class="comment">#</span></div><div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="comment"># Test pruning code</span></div><div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;<span class="comment"># ********</span></div><div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="comment"># WARNING:</span></div><div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;<span class="comment"># This test uses 4GB of disk space.</span></div><div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160;<span class="comment"># This test takes 30 mins or more (up to 2 hours)</span></div><div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="comment"># ********</span></div><div class="line"><a name="l00013"></a><span class="lineno"> 13</span>&#160;</div><div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;<span class="keyword">from</span> <a class="code" href="namespacetest__framework_1_1test__framework.html">test_framework.test_framework</a> <span class="keyword">import</span> BitcoinTestFramework</div><div class="line"><a name="l00015"></a><span class="lineno"> 15</span>&#160;<span class="keyword">from</span> <a class="code" href="namespacetest__framework_1_1util.html">test_framework.util</a> <span class="keyword">import</span> *</div><div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160;</div><div class="line"><a name="l00017"></a><span class="lineno"><a class="line" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc"> 17</a></span>&#160;<span class="keyword">def </span><a class="code" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">calc_usage</a>(blockdir):</div><div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160; <span class="keywordflow">return</span> <a class="code" href="Examples_8cpp.html#a936f4b586a8f869a9d0d197cc5110653">sum</a>(os.path.getsize(blockdir+f) <span class="keywordflow">for</span> f <span class="keywordflow">in</span> os.listdir(blockdir) <span class="keywordflow">if</span> os.path.isfile(blockdir+f)) / (1024. * 1024.)</div><div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160;</div><div class="line"><a name="l00020"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html"> 20</a></span>&#160;<span class="keyword">class </span><a class="code" href="classpruning_1_1PruneTest.html">PruneTest</a>(<a class="code" href="classtest__framework_1_1test__framework_1_1BitcoinTestFramework.html">BitcoinTestFramework</a>):</div><div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160;</div><div class="line"><a name="l00022"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#af907fc2b7bd11abd2219aaf6617db941"> 22</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#af907fc2b7bd11abd2219aaf6617db941">__init__</a>(self):</div><div class="line"><a name="l00023"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d"> 23</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">utxo</a> = []</div><div class="line"><a name="l00024"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912"> 24</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a> = [<span class="stringliteral">&quot;&quot;</span>,<span class="stringliteral">&quot;&quot;</span>]</div><div class="line"><a name="l00025"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#abefcd2b362562f6a119a6f98389af72d"> 25</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#abefcd2b362562f6a119a6f98389af72d">txouts</a> = <a class="code" href="namespacetest__framework_1_1util.html#a8fc6d48b2e47cf4a444310feff09ca5a">gen_return_txouts</a>()</div><div class="line"><a name="l00026"></a><span class="lineno"> 26</span>&#160;</div><div class="line"><a name="l00027"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#ae7543da37da3741b39d226abaa6d11c2"> 27</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#ae7543da37da3741b39d226abaa6d11c2">setup_chain</a>(self):</div><div class="line"><a name="l00028"></a><span class="lineno"> 28</span>&#160; print(<span class="stringliteral">&quot;Initializing test directory &quot;</span>+self.options.tmpdir)</div><div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#a0d5c2187844d0b046113dbea6b956413">initialize_chain_clean</a>(self.options.tmpdir, 3)</div><div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160;</div><div class="line"><a name="l00031"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#aa248b2ba0d8a163cbf6853a138b7088b"> 31</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#aa248b2ba0d8a163cbf6853a138b7088b">setup_network</a>(self):</div><div class="line"><a name="l00032"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d"> 32</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a> = []</div><div class="line"><a name="l00033"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a27465bae24c709aec91f34c0a1585669"> 33</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a27465bae24c709aec91f34c0a1585669">is_network_split</a> = <span class="keyword">False</span></div><div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160;</div><div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160; <span class="comment"># Create nodes 0 and 1 to mine</span></div><div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>.append(<a class="code" href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">start_node</a>(0, self.options.tmpdir, [<span class="stringliteral">&quot;-debug&quot;</span>,<span class="stringliteral">&quot;-maxreceivebuffer=20000&quot;</span>,<span class="stringliteral">&quot;-blockmaxsize=999000&quot;</span>, <span class="stringliteral">&quot;-checkblocks=5&quot;</span>], timewait=900))</div><div class="line"><a name="l00037"></a><span class="lineno"> 37</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>.append(<a class="code" href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">start_node</a>(1, self.options.tmpdir, [<span class="stringliteral">&quot;-debug&quot;</span>,<span class="stringliteral">&quot;-maxreceivebuffer=20000&quot;</span>,<span class="stringliteral">&quot;-blockmaxsize=999000&quot;</span>, <span class="stringliteral">&quot;-checkblocks=5&quot;</span>], timewait=900))</div><div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160;</div><div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160; <span class="comment"># Create node 2 to test pruning</span></div><div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>.append(<a class="code" href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">start_node</a>(2, self.options.tmpdir, [<span class="stringliteral">&quot;-debug&quot;</span>,<span class="stringliteral">&quot;-maxreceivebuffer=20000&quot;</span>,<span class="stringliteral">&quot;-prune=550&quot;</span>], timewait=900))</div><div class="line"><a name="l00041"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd"> 41</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a> = self.options.tmpdir+<span class="stringliteral">&quot;/node2/regtest/blocks/&quot;</span></div><div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;</div><div class="line"><a name="l00043"></a><span class="lineno"> 43</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a>[0] = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="server_8h.html#a271b9e4c68747b1c497a42e2379c590b">getnewaddress</a>()</div><div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a>[1] = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="server_8h.html#a271b9e4c68747b1c497a42e2379c590b">getnewaddress</a>()</div><div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160;</div><div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160; <span class="comment"># Determine default relay fee</span></div><div class="line"><a name="l00047"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#aafa84de841f3aabd80c70e7b785ba7c7"> 47</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#aafa84de841f3aabd80c70e7b785ba7c7">relayfee</a> = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="rpc_2net_8cpp.html#a46fc244635dd8fafde0e76960822c6cd">getnetworkinfo</a>()[<span class="stringliteral">&quot;relayfee&quot;</span>]</div><div class="line"><a name="l00048"></a><span class="lineno"> 48</span>&#160;</div><div class="line"><a name="l00049"></a><span class="lineno"> 49</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0], 1)</div><div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1], 2)</div><div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2], 0)</div><div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">sync_blocks</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0:3])</div><div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160;</div><div class="line"><a name="l00054"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a4506829c30d782379189739dc9b498fb"> 54</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#a4506829c30d782379189739dc9b498fb">create_big_chain</a>(self):</div><div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160; <span class="comment"># Start by creating some coinbases we can spend later</span></div><div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a>(200)</div><div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">sync_blocks</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0:2])</div><div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a>(150)</div><div class="line"><a name="l00059"></a><span class="lineno"> 59</span>&#160; <span class="comment"># Then mine enough full blocks to create more than 550MiB of data</span></div><div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160; <span class="keywordflow">for</span> i <span class="keywordflow">in</span> xrange(645):</div><div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46">mine_full_block</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0], self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a>[0])</div><div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160;</div><div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">sync_blocks</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0:3])</div><div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160;</div><div class="line"><a name="l00065"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a41efbad4a14653958f974359852f59d3"> 65</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#a41efbad4a14653958f974359852f59d3">test_height_min</a>(self):</div><div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160; <span class="keywordflow">if</span> <span class="keywordflow">not</span> os.path.isfile(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>+<span class="stringliteral">&quot;blk00000.dat&quot;</span>):</div><div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160; <span class="keywordflow">raise</span> AssertionError(<span class="stringliteral">&quot;blk00000.dat is missing, pruning too early&quot;</span>)</div><div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Success&quot;</span></div><div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Though we&#39;re already using more than 550MiB, current usage:&quot;</span>, <a class="code" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">calc_usage</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>)</div><div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Mining 25 more blocks should cause the first block file to be pruned&quot;</span></div><div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; <span class="comment"># Pruning doesn&#39;t run until we&#39;re allocating another chunk, 20 full blocks past the height cutoff will ensure this</span></div><div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; <span class="keywordflow">for</span> i <span class="keywordflow">in</span> xrange(25):</div><div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46">mine_full_block</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0],self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a>[0])</div><div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160;</div><div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160; waitstart = time.time()</div><div class="line"><a name="l00076"></a><span class="lineno"> 76</span>&#160; <span class="keywordflow">while</span> os.path.isfile(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>+<span class="stringliteral">&quot;blk00000.dat&quot;</span>):</div><div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; time.sleep(0.1)</div><div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; <span class="keywordflow">if</span> time.time() - waitstart &gt; 10:</div><div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; <span class="keywordflow">raise</span> AssertionError(<span class="stringliteral">&quot;blk00000.dat not pruned when it should be&quot;</span>)</div><div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160;</div><div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Success&quot;</span></div><div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160; usage = <a class="code" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">calc_usage</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>)</div><div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Usage should be below target:&quot;</span>, usage</div><div class="line"><a name="l00084"></a><span class="lineno"> 84</span>&#160; <span class="keywordflow">if</span> (usage &gt; 550):</div><div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; <span class="keywordflow">raise</span> AssertionError(<span class="stringliteral">&quot;Pruning target not being met&quot;</span>)</div><div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160;</div><div class="line"><a name="l00087"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a8cd45c5d4b98334ac13606ed0620e637"> 87</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#a8cd45c5d4b98334ac13606ed0620e637">create_chain_with_staleblocks</a>(self):</div><div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; <span class="comment"># Create stale blocks in manageable sized chunks</span></div><div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Mine 24 (stale) blocks on Node 1, followed by 25 (main chain) block reorg from Node 0, for 12 rounds&quot;</span></div><div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160;</div><div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; <span class="keywordflow">for</span> j <span class="keywordflow">in</span> xrange(12):</div><div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; <span class="comment"># Disconnect node 0 so it can mine a longer reorg chain without knowing about node 1&#39;s soon-to-be-stale chain</span></div><div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="comment"># Node 2 stays connected, so it hears about the stale blocks and then reorg&#39;s when node0 reconnects</span></div><div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; <span class="comment"># Stopping node 0 also clears its mempool, so it doesn&#39;t have node1&#39;s transactions to accidentally mine</span></div><div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#adedab36f7b224153aba7cefb50663d3c">stop_node</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0],0)</div><div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0]=<a class="code" href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">start_node</a>(0, self.options.tmpdir, [<span class="stringliteral">&quot;-debug&quot;</span>,<span class="stringliteral">&quot;-maxreceivebuffer=20000&quot;</span>,<span class="stringliteral">&quot;-blockmaxsize=999000&quot;</span>, <span class="stringliteral">&quot;-checkblocks=5&quot;</span>], timewait=900)</div><div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160; <span class="comment"># Mine 24 blocks in node 1</span></div><div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">utxo</a> = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="server_8h.html#a465ffe9ab07fa4986f64d618404ba7c3">listunspent</a>()</div><div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; <span class="keywordflow">for</span> i <span class="keywordflow">in</span> xrange(24):</div><div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <span class="keywordflow">if</span> j == 0:</div><div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46">mine_full_block</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1],self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a>[1])</div><div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; <span class="keywordflow">else</span>:</div><div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a>(1) <span class="comment">#tx&#39;s already in mempool from previous disconnects</span></div><div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160;</div><div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160; <span class="comment"># Reorg back with 25 block chain from node 0</span></div><div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">utxo</a> = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="server_8h.html#a465ffe9ab07fa4986f64d618404ba7c3">listunspent</a>()</div><div class="line"><a name="l00107"></a><span class="lineno"> 107</span>&#160; <span class="keywordflow">for</span> i <span class="keywordflow">in</span> xrange(25): </div><div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46">mine_full_block</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0],self.<a class="code" href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">address</a>[0])</div><div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160;</div><div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; <span class="comment"># Create connections in the order so both nodes can see the reorg at the same time</span></div><div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1], 0)</div><div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2], 0)</div><div class="line"><a name="l00113"></a><span class="lineno"> 113</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">sync_blocks</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0:3])</div><div class="line"><a name="l00114"></a><span class="lineno"> 114</span>&#160;</div><div class="line"><a name="l00115"></a><span class="lineno"> 115</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Usage can be over target because of high stale rate:&quot;</span>, <a class="code" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">calc_usage</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>)</div><div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160;</div><div class="line"><a name="l00117"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#acc8811da27e475e38567d77ce2befe32"> 117</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#acc8811da27e475e38567d77ce2befe32">reorg_test</a>(self):</div><div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; <span class="comment"># Node 1 will mine a 300 block chain starting 287 blocks back from Node 0 and Node 2&#39;s tip</span></div><div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160; <span class="comment"># This will cause Node 2 to do a reorg requiring 288 blocks of undo data to the reorg_test chain</span></div><div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; <span class="comment"># Reboot node 1 to clear its mempool (hopefully make the invalidate faster)</span></div><div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160; <span class="comment"># Lower the block max size so we don&#39;t keep mining all our big mempool transactions (from disconnected blocks)</span></div><div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#adedab36f7b224153aba7cefb50663d3c">stop_node</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1],1)</div><div class="line"><a name="l00123"></a><span class="lineno"> 123</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1]=<a class="code" href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">start_node</a>(1, self.options.tmpdir, [<span class="stringliteral">&quot;-debug&quot;</span>,<span class="stringliteral">&quot;-maxreceivebuffer=20000&quot;</span>,<span class="stringliteral">&quot;-blockmaxsize=5000&quot;</span>, <span class="stringliteral">&quot;-checkblocks=5&quot;</span>, <span class="stringliteral">&quot;-disablesafemode&quot;</span>], timewait=900)</div><div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160;</div><div class="line"><a name="l00125"></a><span class="lineno"> 125</span>&#160; height = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>()</div><div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Current block height:&quot;</span>, height</div><div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160;</div><div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160; invalidheight = height-287</div><div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; badhash = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(invalidheight)</div><div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Invalidating block at height:&quot;</span>,invalidheight,badhash</div><div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="namespaceinvalidateblock.html">invalidateblock</a>(badhash)</div><div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160;</div><div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; <span class="comment"># We&#39;ve now switched to our previously mined-24 block fork on node 1, but thats not what we want</span></div><div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160; <span class="comment"># So invalidate that fork as well, until we&#39;re on the same chain as node 0/2 (but at an ancestor 288 blocks ago)</span></div><div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160; mainchainhash = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(invalidheight - 1)</div><div class="line"><a name="l00136"></a><span class="lineno"> 136</span>&#160; curhash = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(invalidheight - 1)</div><div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; <span class="keywordflow">while</span> curhash != mainchainhash:</div><div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="namespaceinvalidateblock.html">invalidateblock</a>(curhash)</div><div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160; curhash = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(invalidheight - 1)</div><div class="line"><a name="l00140"></a><span class="lineno"> 140</span>&#160;</div><div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; assert(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>() == invalidheight - 1)</div><div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;New best height&quot;</span>, self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>()</div><div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160;</div><div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160; <span class="comment"># Reboot node1 to clear those giant tx&#39;s from mempool</span></div><div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#adedab36f7b224153aba7cefb50663d3c">stop_node</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1],1)</div><div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1]=<a class="code" href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">start_node</a>(1, self.options.tmpdir, [<span class="stringliteral">&quot;-debug&quot;</span>,<span class="stringliteral">&quot;-maxreceivebuffer=20000&quot;</span>,<span class="stringliteral">&quot;-blockmaxsize=5000&quot;</span>, <span class="stringliteral">&quot;-checkblocks=5&quot;</span>, <span class="stringliteral">&quot;-disablesafemode&quot;</span>], timewait=900)</div><div class="line"><a name="l00147"></a><span class="lineno"> 147</span>&#160;</div><div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Generating new longer chain of 300 more blocks&quot;</span></div><div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[1].<a class="code" href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a>(300)</div><div class="line"><a name="l00150"></a><span class="lineno"> 150</span>&#160;</div><div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Reconnect nodes&quot;</span></div><div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0], 1)</div><div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">connect_nodes</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2], 1)</div><div class="line"><a name="l00154"></a><span class="lineno"> 154</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">sync_blocks</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0:3])</div><div class="line"><a name="l00155"></a><span class="lineno"> 155</span>&#160;</div><div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Verify height on node 2:&quot;</span>,self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>()</div><div class="line"><a name="l00157"></a><span class="lineno"> 157</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Usage possibly still high bc of stale blocks in block files:&quot;</span>, <a class="code" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">calc_usage</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>)</div><div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160;</div><div class="line"><a name="l00159"></a><span class="lineno"> 159</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Mine 220 more blocks so we have requisite history (some blocks will be big and cause pruning of previous chain)&quot;</span></div><div class="line"><a name="l00160"></a><span class="lineno"> 160</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a>(220) <span class="comment">#node 0 has many large tx&#39;s in its mempool from the disconnects</span></div><div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160; <a class="code" href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">sync_blocks</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0:3])</div><div class="line"><a name="l00162"></a><span class="lineno"> 162</span>&#160;</div><div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160; usage = <a class="code" href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">calc_usage</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">prunedir</a>)</div><div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Usage should be below target:&quot;</span>, usage</div><div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160; <span class="keywordflow">if</span> (usage &gt; 550):</div><div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160; <span class="keywordflow">raise</span> AssertionError(<span class="stringliteral">&quot;Pruning target not being met&quot;</span>)</div><div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160;</div><div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; <span class="keywordflow">return</span> invalidheight,badhash</div><div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160;</div><div class="line"><a name="l00170"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a58415e3718ec8944d84ecb1ac5931819"> 170</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#a58415e3718ec8944d84ecb1ac5931819">reorg_back</a>(self):</div><div class="line"><a name="l00171"></a><span class="lineno"> 171</span>&#160; <span class="comment"># Verify that a block on the old main chain fork has been pruned away</span></div><div class="line"><a name="l00172"></a><span class="lineno"> 172</span>&#160; <span class="keywordflow">try</span>:</div><div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#afdd7f5b03a6ab23f3627721b074ef606">getblock</a>(self.forkhash)</div><div class="line"><a name="l00174"></a><span class="lineno"> 174</span>&#160; <span class="keywordflow">raise</span> AssertionError(<span class="stringliteral">&quot;Old block wasn&#39;t pruned so can&#39;t test redownload&quot;</span>)</div><div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; <span class="keywordflow">except</span> JSONRPCException <span class="keyword">as</span> e:</div><div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Will need to redownload block&quot;</span>,self.forkheight</div><div class="line"><a name="l00177"></a><span class="lineno"> 177</span>&#160;</div><div class="line"><a name="l00178"></a><span class="lineno"> 178</span>&#160; <span class="comment"># Verify that we have enough history to reorg back to the fork point</span></div><div class="line"><a name="l00179"></a><span class="lineno"> 179</span>&#160; <span class="comment"># Although this is more than 288 blocks, because this chain was written more recently</span></div><div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160; <span class="comment"># and only its other 299 small and 220 large block are in the block files after it,</span></div><div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160; <span class="comment"># its expected to still be retained</span></div><div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#afdd7f5b03a6ab23f3627721b074ef606">getblock</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(self.forkheight))</div><div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160;</div><div class="line"><a name="l00184"></a><span class="lineno"> 184</span>&#160; first_reorg_height = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>()</div><div class="line"><a name="l00185"></a><span class="lineno"> 185</span>&#160; curchainhash = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a>)</div><div class="line"><a name="l00186"></a><span class="lineno"> 186</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="namespaceinvalidateblock.html">invalidateblock</a>(curchainhash)</div><div class="line"><a name="l00187"></a><span class="lineno"> 187</span>&#160; goalbestheight = self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a></div><div class="line"><a name="l00188"></a><span class="lineno"> 188</span>&#160; goalbesthash = self.<a class="code" href="classpruning_1_1PruneTest.html#aef63ca6cfd46ff28bfef65260f7d7b62">mainchainhash2</a></div><div class="line"><a name="l00189"></a><span class="lineno"> 189</span>&#160;</div><div class="line"><a name="l00190"></a><span class="lineno"> 190</span>&#160; <span class="comment"># As of 0.10 the current block download logic is not able to reorg to the original chain created in</span></div><div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160; <span class="comment"># create_chain_with_stale_blocks because it doesn&#39;t know of any peer thats on that chain from which to</span></div><div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160; <span class="comment"># redownload its missing blocks.</span></div><div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160; <span class="comment"># Invalidate the reorg_test chain in node 0 as well, it can successfully switch to the original chain</span></div><div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160; <span class="comment"># because it has all the block data.</span></div><div class="line"><a name="l00195"></a><span class="lineno"> 195</span>&#160; <span class="comment"># However it must mine enough blocks to have a more work chain than the reorg_test chain in order</span></div><div class="line"><a name="l00196"></a><span class="lineno"> 196</span>&#160; <span class="comment"># to trigger node 2&#39;s block download logic.</span></div><div class="line"><a name="l00197"></a><span class="lineno"> 197</span>&#160; <span class="comment"># At this point node 2 is within 288 blocks of the fork point so it will preserve its ability to reorg</span></div><div class="line"><a name="l00198"></a><span class="lineno"> 198</span>&#160; <span class="keywordflow">if</span> self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>() &lt; self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a>:</div><div class="line"><a name="l00199"></a><span class="lineno"> 199</span>&#160; blocks_to_mine = first_reorg_height + 1 - self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a></div><div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Rewind node 0 to prev main chain to mine longer chain to trigger redownload. Blocks needed:&quot;</span>, blocks_to_mine</div><div class="line"><a name="l00201"></a><span class="lineno"> 201</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="namespaceinvalidateblock.html">invalidateblock</a>(curchainhash)</div><div class="line"><a name="l00202"></a><span class="lineno"> 202</span>&#160; assert(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>() == self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a>)</div><div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160; assert(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="blockchain_8cpp.html#a155137bbf47706bd55a07821025e9b6d">getbestblockhash</a>() == self.<a class="code" href="classpruning_1_1PruneTest.html#aef63ca6cfd46ff28bfef65260f7d7b62">mainchainhash2</a>)</div><div class="line"><a name="l00204"></a><span class="lineno"> 204</span>&#160; goalbesthash = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[0].<a class="code" href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a>(blocks_to_mine)[-1]</div><div class="line"><a name="l00205"></a><span class="lineno"> 205</span>&#160; goalbestheight = first_reorg_height + 1</div><div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160;</div><div class="line"><a name="l00207"></a><span class="lineno"> 207</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Verify node 2 reorged back to the main chain, some blocks of which it had to redownload&quot;</span></div><div class="line"><a name="l00208"></a><span class="lineno"> 208</span>&#160; waitstart = time.time()</div><div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160; <span class="keywordflow">while</span> self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>() &lt; goalbestheight:</div><div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; time.sleep(0.1)</div><div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; <span class="keywordflow">if</span> time.time() - waitstart &gt; 900:</div><div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160; <span class="keywordflow">raise</span> AssertionError(<span class="stringliteral">&quot;Node 2 didn&#39;t reorg to proper height&quot;</span>)</div><div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160; assert(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#a155137bbf47706bd55a07821025e9b6d">getbestblockhash</a>() == goalbesthash)</div><div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; <span class="comment"># Verify we can now have the data for a block previously pruned</span></div><div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160; assert(self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#afdd7f5b03a6ab23f3627721b074ef606">getblock</a>(self.forkhash)[<span class="stringliteral">&quot;height&quot;</span>] == self.forkheight)</div><div class="line"><a name="l00216"></a><span class="lineno"> 216</span>&#160;</div><div class="line"><a name="l00217"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46"> 217</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46">mine_full_block</a>(self, node, address):</div><div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160; <span class="comment"># Want to create a full block</span></div><div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160; <span class="comment"># We&#39;ll generate a 66k transaction below, and 14 of them is close to the 1MB block limit</span></div><div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160; <span class="keywordflow">for</span> j <span class="keywordflow">in</span> xrange(14):</div><div class="line"><a name="l00221"></a><span class="lineno"> 221</span>&#160; <span class="keywordflow">if</span> len(self.<a class="code" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">utxo</a>) &lt; 14:</div><div class="line"><a name="l00222"></a><span class="lineno"> 222</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">utxo</a> = node.listunspent()</div><div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; inputs=[]</div><div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; outputs = {}</div><div class="line"><a name="l00225"></a><span class="lineno"> 225</span>&#160; t = self.<a class="code" href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">utxo</a>.pop()</div><div class="line"><a name="l00226"></a><span class="lineno"> 226</span>&#160; inputs.append({ <span class="stringliteral">&quot;txid&quot;</span> : t[<span class="stringliteral">&quot;txid&quot;</span>], <span class="stringliteral">&quot;vout&quot;</span> : t[<span class="stringliteral">&quot;vout&quot;</span>]})</div><div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160; remchange = t[<span class="stringliteral">&quot;amount&quot;</span>] - 100*self.<a class="code" href="classpruning_1_1PruneTest.html#aafa84de841f3aabd80c70e7b785ba7c7">relayfee</a> <span class="comment"># Fee must be above min relay rate for 66kb tx</span></div><div class="line"><a name="l00228"></a><span class="lineno"> 228</span>&#160; outputs[address]=remchange</div><div class="line"><a name="l00229"></a><span class="lineno"> 229</span>&#160; <span class="comment"># Create a basic transaction that will send change back to ourself after account for a fee</span></div><div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; <span class="comment"># And then insert the 128 generated transaction outs in the middle rawtx[92] is where the #</span></div><div class="line"><a name="l00231"></a><span class="lineno"> 231</span>&#160; <span class="comment"># of txouts is stored and is the only thing we overwrite from the original transaction</span></div><div class="line"><a name="l00232"></a><span class="lineno"> 232</span>&#160; rawtx = node.createrawtransaction(inputs, outputs)</div><div class="line"><a name="l00233"></a><span class="lineno"> 233</span>&#160; newtx = rawtx[0:92]</div><div class="line"><a name="l00234"></a><span class="lineno"> 234</span>&#160; newtx = newtx + self.<a class="code" href="classpruning_1_1PruneTest.html#abefcd2b362562f6a119a6f98389af72d">txouts</a></div><div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160; newtx = newtx + rawtx[94:]</div><div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; <span class="comment"># Appears to be ever so slightly faster to sign with SIGHASH_NONE</span></div><div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160; signresult = node.signrawtransaction(newtx,<span class="keywordtype">None</span>,<span class="keywordtype">None</span>,<span class="stringliteral">&quot;NONE&quot;</span>)</div><div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; txid = node.sendrawtransaction(signresult[<span class="stringliteral">&quot;hex&quot;</span>], <span class="keyword">True</span>)</div><div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; <span class="comment"># Mine a full sized block which will be these transactions we just created</span></div><div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160; node.generate(1)</div><div class="line"><a name="l00241"></a><span class="lineno"> 241</span>&#160;</div><div class="line"><a name="l00242"></a><span class="lineno"> 242</span>&#160;</div><div class="line"><a name="l00243"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a8d70422ed343c72b00457c211996632b"> 243</a></span>&#160; <span class="keyword">def </span><a class="code" href="classpruning_1_1PruneTest.html#a8d70422ed343c72b00457c211996632b">run_test</a>(self):</div><div class="line"><a name="l00244"></a><span class="lineno"> 244</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Warning! This test requires 4GB of disk space and takes over 30 mins (up to 2 hours)&quot;</span></div><div class="line"><a name="l00245"></a><span class="lineno"> 245</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Mining a big blockchain of 995 blocks&quot;</span></div><div class="line"><a name="l00246"></a><span class="lineno"> 246</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a4506829c30d782379189739dc9b498fb">create_big_chain</a>()</div><div class="line"><a name="l00247"></a><span class="lineno"> 247</span>&#160; <span class="comment"># Chain diagram key:</span></div><div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160; <span class="comment"># * blocks on main chain</span></div><div class="line"><a name="l00249"></a><span class="lineno"> 249</span>&#160; <span class="comment"># +,&amp;,$,@ blocks on other forks</span></div><div class="line"><a name="l00250"></a><span class="lineno"> 250</span>&#160; <span class="comment"># X invalidated block</span></div><div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160; <span class="comment"># N1 Node 1</span></div><div class="line"><a name="l00252"></a><span class="lineno"> 252</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00253"></a><span class="lineno"> 253</span>&#160; <span class="comment"># Start by mining a simple chain that all nodes have</span></div><div class="line"><a name="l00254"></a><span class="lineno"> 254</span>&#160; <span class="comment"># N0=N1=N2 **...*(995)</span></div><div class="line"><a name="l00255"></a><span class="lineno"> 255</span>&#160;</div><div class="line"><a name="l00256"></a><span class="lineno"> 256</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Check that we haven&#39;t started pruning yet because we&#39;re below PruneAfterHeight&quot;</span></div><div class="line"><a name="l00257"></a><span class="lineno"> 257</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a41efbad4a14653958f974359852f59d3">test_height_min</a>()</div><div class="line"><a name="l00258"></a><span class="lineno"> 258</span>&#160; <span class="comment"># Extend this chain past the PruneAfterHeight</span></div><div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160; <span class="comment"># N0=N1=N2 **...*(1020)</span></div><div class="line"><a name="l00260"></a><span class="lineno"> 260</span>&#160;</div><div class="line"><a name="l00261"></a><span class="lineno"> 261</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Check that we&#39;ll exceed disk space target if we have a very high stale block rate&quot;</span></div><div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a8cd45c5d4b98334ac13606ed0620e637">create_chain_with_staleblocks</a>()</div><div class="line"><a name="l00263"></a><span class="lineno"> 263</span>&#160; <span class="comment"># Disconnect N0</span></div><div class="line"><a name="l00264"></a><span class="lineno"> 264</span>&#160; <span class="comment"># And mine a 24 block chain on N1 and a separate 25 block chain on N0</span></div><div class="line"><a name="l00265"></a><span class="lineno"> 265</span>&#160; <span class="comment"># N1=N2 **...*+...+(1044)</span></div><div class="line"><a name="l00266"></a><span class="lineno"> 266</span>&#160; <span class="comment"># N0 **...**...**(1045)</span></div><div class="line"><a name="l00267"></a><span class="lineno"> 267</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00268"></a><span class="lineno"> 268</span>&#160; <span class="comment"># reconnect nodes causing reorg on N1 and N2</span></div><div class="line"><a name="l00269"></a><span class="lineno"> 269</span>&#160; <span class="comment"># N1=N2 **...*(1020) *...**(1045)</span></div><div class="line"><a name="l00270"></a><span class="lineno"> 270</span>&#160; <span class="comment"># \</span></div><div class="line"><a name="l00271"></a><span class="lineno"> 271</span>&#160; <span class="comment"># +...+(1044)</span></div><div class="line"><a name="l00272"></a><span class="lineno"> 272</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00273"></a><span class="lineno"> 273</span>&#160; <span class="comment"># repeat this process until you have 12 stale forks hanging off the</span></div><div class="line"><a name="l00274"></a><span class="lineno"> 274</span>&#160; <span class="comment"># main chain on N1 and N2</span></div><div class="line"><a name="l00275"></a><span class="lineno"> 275</span>&#160; <span class="comment"># N0 *************************...***************************(1320)</span></div><div class="line"><a name="l00276"></a><span class="lineno"> 276</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00277"></a><span class="lineno"> 277</span>&#160; <span class="comment"># N1=N2 **...*(1020) *...**(1045) *.. ..**(1295) *...**(1320)</span></div><div class="line"><a name="l00278"></a><span class="lineno"> 278</span>&#160; <span class="comment"># \ \ \</span></div><div class="line"><a name="l00279"></a><span class="lineno"> 279</span>&#160; <span class="comment"># +...+(1044) &amp;.. $...$(1319)</span></div><div class="line"><a name="l00280"></a><span class="lineno"> 280</span>&#160;</div><div class="line"><a name="l00281"></a><span class="lineno"> 281</span>&#160; <span class="comment"># Save some current chain state for later use</span></div><div class="line"><a name="l00282"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113"> 282</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a> = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a>() <span class="comment">#1320</span></div><div class="line"><a name="l00283"></a><span class="lineno"><a class="line" href="classpruning_1_1PruneTest.html#aef63ca6cfd46ff28bfef65260f7d7b62"> 283</a></span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#aef63ca6cfd46ff28bfef65260f7d7b62">mainchainhash2</a> = self.<a class="code" href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">nodes</a>[2].<a class="code" href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a>(self.<a class="code" href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">mainchainheight</a>)</div><div class="line"><a name="l00284"></a><span class="lineno"> 284</span>&#160;</div><div class="line"><a name="l00285"></a><span class="lineno"> 285</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Check that we can survive a 288 block reorg still&quot;</span></div><div class="line"><a name="l00286"></a><span class="lineno"> 286</span>&#160; (self.forkheight,self.forkhash) = self.<a class="code" href="classpruning_1_1PruneTest.html#acc8811da27e475e38567d77ce2befe32">reorg_test</a>() <span class="comment">#(1033, )</span></div><div class="line"><a name="l00287"></a><span class="lineno"> 287</span>&#160; <span class="comment"># Now create a 288 block reorg by mining a longer chain on N1</span></div><div class="line"><a name="l00288"></a><span class="lineno"> 288</span>&#160; <span class="comment"># First disconnect N1</span></div><div class="line"><a name="l00289"></a><span class="lineno"> 289</span>&#160; <span class="comment"># Then invalidate 1033 on main chain and 1032 on fork so height is 1032 on main chain</span></div><div class="line"><a name="l00290"></a><span class="lineno"> 290</span>&#160; <span class="comment"># N1 **...*(1020) **...**(1032)X..</span></div><div class="line"><a name="l00291"></a><span class="lineno"> 291</span>&#160; <span class="comment"># \</span></div><div class="line"><a name="l00292"></a><span class="lineno"> 292</span>&#160; <span class="comment"># ++...+(1031)X..</span></div><div class="line"><a name="l00293"></a><span class="lineno"> 293</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00294"></a><span class="lineno"> 294</span>&#160; <span class="comment"># Now mine 300 more blocks on N1</span></div><div class="line"><a name="l00295"></a><span class="lineno"> 295</span>&#160; <span class="comment"># N1 **...*(1020) **...**(1032) @@...@(1332)</span></div><div class="line"><a name="l00296"></a><span class="lineno"> 296</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00297"></a><span class="lineno"> 297</span>&#160; <span class="comment"># \ X...</span></div><div class="line"><a name="l00298"></a><span class="lineno"> 298</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00299"></a><span class="lineno"> 299</span>&#160; <span class="comment"># ++...+(1031)X.. ..</span></div><div class="line"><a name="l00300"></a><span class="lineno"> 300</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00301"></a><span class="lineno"> 301</span>&#160; <span class="comment"># Reconnect nodes and mine 220 more blocks on N1</span></div><div class="line"><a name="l00302"></a><span class="lineno"> 302</span>&#160; <span class="comment"># N1 **...*(1020) **...**(1032) @@...@@@(1552)</span></div><div class="line"><a name="l00303"></a><span class="lineno"> 303</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00304"></a><span class="lineno"> 304</span>&#160; <span class="comment"># \ X...</span></div><div class="line"><a name="l00305"></a><span class="lineno"> 305</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00306"></a><span class="lineno"> 306</span>&#160; <span class="comment"># ++...+(1031)X.. ..</span></div><div class="line"><a name="l00307"></a><span class="lineno"> 307</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00308"></a><span class="lineno"> 308</span>&#160; <span class="comment"># N2 **...*(1020) **...**(1032) @@...@@@(1552)</span></div><div class="line"><a name="l00309"></a><span class="lineno"> 309</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00310"></a><span class="lineno"> 310</span>&#160; <span class="comment"># \ *...**(1320)</span></div><div class="line"><a name="l00311"></a><span class="lineno"> 311</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00312"></a><span class="lineno"> 312</span>&#160; <span class="comment"># ++...++(1044) ..</span></div><div class="line"><a name="l00313"></a><span class="lineno"> 313</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00314"></a><span class="lineno"> 314</span>&#160; <span class="comment"># N0 ********************(1032) @@...@@@(1552)</span></div><div class="line"><a name="l00315"></a><span class="lineno"> 315</span>&#160; <span class="comment"># \</span></div><div class="line"><a name="l00316"></a><span class="lineno"> 316</span>&#160; <span class="comment"># *...**(1320)</span></div><div class="line"><a name="l00317"></a><span class="lineno"> 317</span>&#160;</div><div class="line"><a name="l00318"></a><span class="lineno"> 318</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Test that we can rerequest a block we previously pruned if needed for a reorg&quot;</span></div><div class="line"><a name="l00319"></a><span class="lineno"> 319</span>&#160; self.<a class="code" href="classpruning_1_1PruneTest.html#a58415e3718ec8944d84ecb1ac5931819">reorg_back</a>()</div><div class="line"><a name="l00320"></a><span class="lineno"> 320</span>&#160; <span class="comment"># Verify that N2 still has block 1033 on current chain (@), but not on main chain (*)</span></div><div class="line"><a name="l00321"></a><span class="lineno"> 321</span>&#160; <span class="comment"># Invalidate 1033 on current chain (@) on N2 and we should be able to reorg to</span></div><div class="line"><a name="l00322"></a><span class="lineno"> 322</span>&#160; <span class="comment"># original main chain (*), but will require redownload of some blocks</span></div><div class="line"><a name="l00323"></a><span class="lineno"> 323</span>&#160; <span class="comment"># In order to have a peer we think we can download from, must also perform this invalidation</span></div><div class="line"><a name="l00324"></a><span class="lineno"> 324</span>&#160; <span class="comment"># on N0 and mine a new longest chain to trigger.</span></div><div class="line"><a name="l00325"></a><span class="lineno"> 325</span>&#160; <span class="comment"># Final result:</span></div><div class="line"><a name="l00326"></a><span class="lineno"> 326</span>&#160; <span class="comment"># N0 ********************(1032) **...****(1553)</span></div><div class="line"><a name="l00327"></a><span class="lineno"> 327</span>&#160; <span class="comment"># \</span></div><div class="line"><a name="l00328"></a><span class="lineno"> 328</span>&#160; <span class="comment"># X@...@@@(1552)</span></div><div class="line"><a name="l00329"></a><span class="lineno"> 329</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00330"></a><span class="lineno"> 330</span>&#160; <span class="comment"># N2 **...*(1020) **...**(1032) **...****(1553)</span></div><div class="line"><a name="l00331"></a><span class="lineno"> 331</span>&#160; <span class="comment"># \ \</span></div><div class="line"><a name="l00332"></a><span class="lineno"> 332</span>&#160; <span class="comment"># \ X@...@@@(1552)</span></div><div class="line"><a name="l00333"></a><span class="lineno"> 333</span>&#160; <span class="comment"># \</span></div><div class="line"><a name="l00334"></a><span class="lineno"> 334</span>&#160; <span class="comment"># +..</span></div><div class="line"><a name="l00335"></a><span class="lineno"> 335</span>&#160; <span class="comment">#</span></div><div class="line"><a name="l00336"></a><span class="lineno"> 336</span>&#160; <span class="comment"># N1 doesn&#39;t change because 1033 on main chain (*) is invalid</span></div><div class="line"><a name="l00337"></a><span class="lineno"> 337</span>&#160;</div><div class="line"><a name="l00338"></a><span class="lineno"> 338</span>&#160; <span class="keywordflow">print</span> <span class="stringliteral">&quot;Done&quot;</span></div><div class="line"><a name="l00339"></a><span class="lineno"> 339</span>&#160;</div><div class="line"><a name="l00340"></a><span class="lineno"> 340</span>&#160;<span class="keywordflow">if</span> __name__ == <span class="stringliteral">&#39;__main__&#39;</span>:</div><div class="line"><a name="l00341"></a><span class="lineno"> 341</span>&#160; <a class="code" href="classpruning_1_1PruneTest.html">PruneTest</a>().<a class="code" href="classtest__framework_1_1test__framework_1_1BitcoinTestFramework.html#a076857f5499c37bacf64a8ccb6ba5197">main</a>()</div><div class="ttc" id="classpruning_1_1PruneTest_html_ae7543da37da3741b39d226abaa6d11c2"><div class="ttname"><a href="classpruning_1_1PruneTest.html#ae7543da37da3741b39d226abaa6d11c2">pruning.PruneTest.setup_chain</a></div><div class="ttdeci">def setup_chain(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00027">pruning.py:27</a></div></div>
<div class="ttc" id="namespaceinvalidateblock_html"><div class="ttname"><a href="namespaceinvalidateblock.html">invalidateblock</a></div><div class="ttdef"><b>Definition:</b> <a href="invalidateblock_8py_source.html#l00001">invalidateblock.py:1</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a7c1637bdfedb15232481690f17ad0e46"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a7c1637bdfedb15232481690f17ad0e46">pruning.PruneTest.mine_full_block</a></div><div class="ttdeci">def mine_full_block(self, node, address)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00217">pruning.py:217</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_aafa84de841f3aabd80c70e7b785ba7c7"><div class="ttname"><a href="classpruning_1_1PruneTest.html#aafa84de841f3aabd80c70e7b785ba7c7">pruning.PruneTest.relayfee</a></div><div class="ttdeci">relayfee</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00047">pruning.py:47</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_aef63ca6cfd46ff28bfef65260f7d7b62"><div class="ttname"><a href="classpruning_1_1PruneTest.html#aef63ca6cfd46ff28bfef65260f7d7b62">pruning.PruneTest.mainchainhash2</a></div><div class="ttdeci">mainchainhash2</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00283">pruning.py:283</a></div></div>
<div class="ttc" id="Examples_8cpp_html_a936f4b586a8f869a9d0d197cc5110653"><div class="ttname"><a href="Examples_8cpp.html#a936f4b586a8f869a9d0d197cc5110653">sum</a></div><div class="ttdeci">volatile double sum</div><div class="ttdef"><b>Definition:</b> <a href="Examples_8cpp_source.html#l00023">Examples.cpp:23</a></div></div>
<div class="ttc" id="namespacepruning_html_a5667a4691b4d134189b7e7cdfec31cdc"><div class="ttname"><a href="namespacepruning.html#a5667a4691b4d134189b7e7cdfec31cdc">pruning.calc_usage</a></div><div class="ttdeci">def calc_usage(blockdir)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00017">pruning.py:17</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a41efbad4a14653958f974359852f59d3"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a41efbad4a14653958f974359852f59d3">pruning.PruneTest.test_height_min</a></div><div class="ttdeci">def test_height_min(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00065">pruning.py:65</a></div></div>
<div class="ttc" id="blockchain_8cpp_html_afdd7f5b03a6ab23f3627721b074ef606"><div class="ttname"><a href="blockchain_8cpp.html#afdd7f5b03a6ab23f3627721b074ef606">getblock</a></div><div class="ttdeci">UniValue getblock(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="blockchain_8cpp_source.html#l00483">blockchain.cpp:483</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a9f9714af5c7a2aa84c29931c531fc81d"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a9f9714af5c7a2aa84c29931c531fc81d">pruning.PruneTest.utxo</a></div><div class="ttdeci">utxo</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00023">pruning.py:23</a></div></div>
<div class="ttc" id="server_8h_html_a465ffe9ab07fa4986f64d618404ba7c3"><div class="ttname"><a href="server_8h.html#a465ffe9ab07fa4986f64d618404ba7c3">listunspent</a></div><div class="ttdeci">UniValue listunspent(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="rpcwallet_8cpp_source.html#l02533">rpcwallet.cpp:2533</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a2a22d6cd77ba2d7405963c1e403b695d"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a2a22d6cd77ba2d7405963c1e403b695d">pruning.PruneTest.nodes</a></div><div class="ttdeci">nodes</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00032">pruning.py:32</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html_aa1eacfbd44ba6019d659733acf4b1a71"><div class="ttname"><a href="namespacetest__framework_1_1util.html#aa1eacfbd44ba6019d659733acf4b1a71">test_framework.util.connect_nodes</a></div><div class="ttdeci">def connect_nodes(from_connection, node_num)</div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00343">util.py:343</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_abefcd2b362562f6a119a6f98389af72d"><div class="ttname"><a href="classpruning_1_1PruneTest.html#abefcd2b362562f6a119a6f98389af72d">pruning.PruneTest.txouts</a></div><div class="ttdeci">txouts</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00025">pruning.py:25</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1test__framework_html"><div class="ttname"><a href="namespacetest__framework_1_1test__framework.html">test_framework.test_framework</a></div><div class="ttdef"><b>Definition:</b> <a href="test__framework_8py_source.html#l00001">test_framework.py:1</a></div></div>
<div class="ttc" id="classtest__framework_1_1test__framework_1_1BitcoinTestFramework_html"><div class="ttname"><a href="classtest__framework_1_1test__framework_1_1BitcoinTestFramework.html">test_framework.test_framework.BitcoinTestFramework</a></div><div class="ttdef"><b>Definition:</b> <a href="test__framework_8py_source.html#l00032">test_framework.py:32</a></div></div>
<div class="ttc" id="server_8h_html_a271b9e4c68747b1c497a42e2379c590b"><div class="ttname"><a href="server_8h.html#a271b9e4c68747b1c497a42e2379c590b">getnewaddress</a></div><div class="ttdeci">UniValue getnewaddress(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="rpcwallet_8cpp_source.html#l00113">rpcwallet.cpp:113</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a58415e3718ec8944d84ecb1ac5931819"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a58415e3718ec8944d84ecb1ac5931819">pruning.PruneTest.reorg_back</a></div><div class="ttdeci">def reorg_back(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00170">pruning.py:170</a></div></div>
<div class="ttc" id="blockchain_8cpp_html_ac1ec45e4b8f71fd32a1a3a984c62429f"><div class="ttname"><a href="blockchain_8cpp.html#ac1ec45e4b8f71fd32a1a3a984c62429f">getblockhash</a></div><div class="ttdeci">UniValue getblockhash(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="blockchain_8cpp_source.html#l00311">blockchain.cpp:311</a></div></div>
<div class="ttc" id="blockchain_8cpp_html_ae0f8b6c1a99fcf8a0e786df27a41a40d"><div class="ttname"><a href="blockchain_8cpp.html#ae0f8b6c1a99fcf8a0e786df27a41a40d">getblockcount</a></div><div class="ttdeci">UniValue getblockcount(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="blockchain_8cpp_source.html#l00131">blockchain.cpp:131</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html_a0d5c2187844d0b046113dbea6b956413"><div class="ttname"><a href="namespacetest__framework_1_1util.html#a0d5c2187844d0b046113dbea6b956413">test_framework.util.initialize_chain_clean</a></div><div class="ttdeci">def initialize_chain_clean(test_dir, num_nodes)</div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00252">util.py:252</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a406e3146d1438f01f1a359d023b9f113"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a406e3146d1438f01f1a359d023b9f113">pruning.PruneTest.mainchainheight</a></div><div class="ttdeci">mainchainheight</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00282">pruning.py:282</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a523f76f73ce244831f48f097eaa2a912"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a523f76f73ce244831f48f097eaa2a912">pruning.PruneTest.address</a></div><div class="ttdeci">address</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00024">pruning.py:24</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html"><div class="ttname"><a href="classpruning_1_1PruneTest.html">pruning.PruneTest</a></div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00020">pruning.py:20</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a27465bae24c709aec91f34c0a1585669"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a27465bae24c709aec91f34c0a1585669">pruning.PruneTest.is_network_split</a></div><div class="ttdeci">is_network_split</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00033">pruning.py:33</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html_a8fc6d48b2e47cf4a444310feff09ca5a"><div class="ttname"><a href="namespacetest__framework_1_1util.html#a8fc6d48b2e47cf4a444310feff09ca5a">test_framework.util.gen_return_txouts</a></div><div class="ttdeci">def gen_return_txouts()</div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00559">util.py:559</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html_aebc7ae4dc3512e677020141c7370b2e1"><div class="ttname"><a href="namespacetest__framework_1_1util.html#aebc7ae4dc3512e677020141c7370b2e1">test_framework.util.start_node</a></div><div class="ttdeci">def start_node(i, dirname, extra_args=None, rpchost=None, timewait=None, binary=None)</div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00281">util.py:281</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html_adedab36f7b224153aba7cefb50663d3c"><div class="ttname"><a href="namespacetest__framework_1_1util.html#adedab36f7b224153aba7cefb50663d3c">test_framework.util.stop_node</a></div><div class="ttdeci">def stop_node(node, i)</div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00323">util.py:323</a></div></div>
<div class="ttc" id="mining_8cpp_html_afc5f2c0cbe40a2f876b46df2929cf359"><div class="ttname"><a href="mining_8cpp.html#afc5f2c0cbe40a2f876b46df2929cf359">generate</a></div><div class="ttdeci">UniValue generate(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="mining_8cpp_source.html#l00122">mining.cpp:122</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_aa248b2ba0d8a163cbf6853a138b7088b"><div class="ttname"><a href="classpruning_1_1PruneTest.html#aa248b2ba0d8a163cbf6853a138b7088b">pruning.PruneTest.setup_network</a></div><div class="ttdeci">def setup_network(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00031">pruning.py:31</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html_aa20567f95203db19bbd3bf531ddabff6"><div class="ttname"><a href="namespacetest__framework_1_1util.html#aa20567f95203db19bbd3bf531ddabff6">test_framework.util.sync_blocks</a></div><div class="ttdeci">def sync_blocks(rpc_connections, wait=1)</div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00117">util.py:117</a></div></div>
<div class="ttc" id="classtest__framework_1_1test__framework_1_1BitcoinTestFramework_html_a076857f5499c37bacf64a8ccb6ba5197"><div class="ttname"><a href="classtest__framework_1_1test__framework_1_1BitcoinTestFramework.html#a076857f5499c37bacf64a8ccb6ba5197">test_framework.test_framework.BitcoinTestFramework.main</a></div><div class="ttdeci">def main(self)</div><div class="ttdef"><b>Definition:</b> <a href="test__framework_8py_source.html#l00097">test_framework.py:97</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a4506829c30d782379189739dc9b498fb"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a4506829c30d782379189739dc9b498fb">pruning.PruneTest.create_big_chain</a></div><div class="ttdeci">def create_big_chain(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00054">pruning.py:54</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_acc8811da27e475e38567d77ce2befe32"><div class="ttname"><a href="classpruning_1_1PruneTest.html#acc8811da27e475e38567d77ce2befe32">pruning.PruneTest.reorg_test</a></div><div class="ttdeci">def reorg_test(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00117">pruning.py:117</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a8cd45c5d4b98334ac13606ed0620e637"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a8cd45c5d4b98334ac13606ed0620e637">pruning.PruneTest.create_chain_with_staleblocks</a></div><div class="ttdeci">def create_chain_with_staleblocks(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00087">pruning.py:87</a></div></div>
<div class="ttc" id="blockchain_8cpp_html_a155137bbf47706bd55a07821025e9b6d"><div class="ttname"><a href="blockchain_8cpp.html#a155137bbf47706bd55a07821025e9b6d">getbestblockhash</a></div><div class="ttdeci">UniValue getbestblockhash(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="blockchain_8cpp_source.html#l00148">blockchain.cpp:148</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_af907fc2b7bd11abd2219aaf6617db941"><div class="ttname"><a href="classpruning_1_1PruneTest.html#af907fc2b7bd11abd2219aaf6617db941">pruning.PruneTest.__init__</a></div><div class="ttdeci">def __init__(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00022">pruning.py:22</a></div></div>
<div class="ttc" id="rpc_2net_8cpp_html_a46fc244635dd8fafde0e76960822c6cd"><div class="ttname"><a href="rpc_2net_8cpp.html#a46fc244635dd8fafde0e76960822c6cd">getnetworkinfo</a></div><div class="ttdeci">UniValue getnetworkinfo(const UniValue &amp;params, bool fHelp)</div><div class="ttdef"><b>Definition:</b> <a href="rpc_2net_8cpp_source.html#l00392">net.cpp:392</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a85e158ab0f0d594b43719d0c3dcc79bd"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a85e158ab0f0d594b43719d0c3dcc79bd">pruning.PruneTest.prunedir</a></div><div class="ttdeci">prunedir</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00041">pruning.py:41</a></div></div>
<div class="ttc" id="namespacetest__framework_1_1util_html"><div class="ttname"><a href="namespacetest__framework_1_1util.html">test_framework.util</a></div><div class="ttdef"><b>Definition:</b> <a href="util_8py_source.html#l00001">util.py:1</a></div></div>
<div class="ttc" id="classpruning_1_1PruneTest_html_a8d70422ed343c72b00457c211996632b"><div class="ttname"><a href="classpruning_1_1PruneTest.html#a8d70422ed343c72b00457c211996632b">pruning.PruneTest.run_test</a></div><div class="ttdeci">def run_test(self)</div><div class="ttdef"><b>Definition:</b> <a href="pruning_8py_source.html#l00243">pruning.py:243</a></div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="dir_62ba24d7ce8eecc59962fe5b590c1065.html">qa</a></li><li class="navelem"><a class="el" href="dir_dbddb259b29a77ea11562b7a380aa303.html">rpc-tests</a></li><li class="navelem"><a class="el" href="pruning_8py.html">pruning.py</a></li>
<li class="footer">Generated on Thu Dec 14 2017 13:15:02 for Dash Core by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.14 </li>
</ul>
</div>
</body>
</html>