Skip to content

Commit

Permalink
Merge bitcoin#27389: test: refactor: replace unnecessary BytesIO uses
Browse files Browse the repository at this point in the history
f842ed9 test: refactor: replace unnecessary `BytesIO` uses (Sebastian Falbesoner)

Pull request description:

  Rather than needing to create intermediate stream variables, we can use helper functions like `tx_from_hex` instead or access the result directly, leading both to increased readability and less code.

ACKs for top commit:
  stickies-v:
    ACK f842ed9
  brunoerg:
    crACK f842ed9
  aureleoules:
    ACK f842ed9 - It seems that these are the only instances that can be changed and it simplifies test code.

Tree-SHA512: 7f4fd7a26720d1988bf27f66c817ff6cd7060350a3be62d28e7848c768fd43578719ca475193d4057ccf4f2458af18564fd513fe3a1d458a11c799927c12bd65
  • Loading branch information
fanquake committed Apr 4, 2023
2 parents 369d4c0 + f842ed9 commit 49b87bf
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 15 deletions.
5 changes: 2 additions & 3 deletions test/functional/feature_taproot.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
CTxInWitness,
CTxOut,
SEQUENCE_FINAL,
tx_from_hex,
)
from test_framework.script import (
ANNEX_TAG,
Expand Down Expand Up @@ -109,7 +110,6 @@
program_to_witness,
)
from collections import OrderedDict, namedtuple
from io import BytesIO
import json
import hashlib
import os
Expand Down Expand Up @@ -1386,8 +1386,7 @@ def test_spenders(self, node, spenders, input_counts):
# Add change
fund_tx.vout.append(CTxOut(balance - 10000, random.choice(host_spks)))
# Ask the wallet to sign
ss = BytesIO(bytes.fromhex(node.signrawtransactionwithwallet(fund_tx.serialize().hex())["hex"]))
fund_tx.deserialize(ss)
fund_tx = tx_from_hex(node.signrawtransactionwithwallet(fund_tx.serialize().hex())["hex"])
# Construct UTXOData entries
fund_tx.rehash()
for i in range(count_this_tx):
Expand Down
9 changes: 3 additions & 6 deletions test/functional/interface_rest.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,7 @@
from decimal import Decimal
from enum import Enum
import http.client
from io import BytesIO
import json
from struct import pack, unpack
import typing
import urllib.parse

Expand Down Expand Up @@ -160,12 +158,11 @@ def run_test(self):
bin_request = b'\x01\x02'
for txid, n in [spending, spent]:
bin_request += bytes.fromhex(txid)
bin_request += pack("i", n)
bin_request += n.to_bytes(4, 'little')

bin_response = self.test_rest_request("/getutxos", http_method='POST', req_type=ReqType.BIN, body=bin_request, ret_type=RetType.BYTES)
output = BytesIO(bin_response)
chain_height, = unpack("<i", output.read(4))
response_hash = output.read(32)[::-1].hex()
chain_height = int.from_bytes(bin_response[0:4], 'little')
response_hash = bin_response[4:36][::-1].hex()

assert_equal(bb_hash, response_hash) # check if getutxo's chaintip during calculation was fine
assert_equal(chain_height, 201) # chain height must be 201 (pre-mined chain [200] + generated block [1])
Expand Down
10 changes: 4 additions & 6 deletions test/functional/interface_zmq.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
"""Test the ZMQ notification interface."""
import struct
from time import sleep

from test_framework.address import (
ADDRESS_BCRT1_P2WSH_OP_TRUE,
Expand All @@ -16,8 +17,8 @@
)
from test_framework.test_framework import BitcoinTestFramework
from test_framework.messages import (
CTransaction,
hash256,
tx_from_hex,
)
from test_framework.util import (
assert_equal,
Expand All @@ -28,8 +29,7 @@
MiniWallet,
)
from test_framework.netutil import test_ipv6_local
from io import BytesIO
from time import sleep


# Test may be skipped and not have zmq installed
try:
Expand Down Expand Up @@ -198,9 +198,7 @@ def test_basic(self):
txid = hashtx.receive()

# Should receive the coinbase raw transaction.
hex = rawtx.receive()
tx = CTransaction()
tx.deserialize(BytesIO(hex))
tx = tx_from_hex(rawtx.receive().hex())
tx.calc_sha256()
assert_equal(tx.hash, txid.hex())

Expand Down

0 comments on commit 49b87bf

Please sign in to comment.