mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-11-15 16:38:23 +01:00
test: add windows support to get previous releases script
Needed to allow the wallet migration functional test to run under native windows. Platform variable renamed to not clash with platform package.
This commit is contained in:
@@ -11,31 +11,38 @@
|
|||||||
import argparse
|
import argparse
|
||||||
import contextlib
|
import contextlib
|
||||||
from fnmatch import fnmatch
|
from fnmatch import fnmatch
|
||||||
|
import hashlib
|
||||||
import os
|
import os
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
import platform
|
||||||
import re
|
import re
|
||||||
import shutil
|
import shutil
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
import hashlib
|
import time
|
||||||
|
import urllib.request
|
||||||
|
import zipfile
|
||||||
|
|
||||||
SHA256_SUMS = {
|
SHA256_SUMS = {
|
||||||
"0e2819135366f150d9906e294b61dff58fd1996ebd26c2f8e979d6c0b7a79580": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-aarch64-linux-gnu.tar.gz"},
|
"0e2819135366f150d9906e294b61dff58fd1996ebd26c2f8e979d6c0b7a79580": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-aarch64-linux-gnu.tar.gz"},
|
||||||
"d86fc90824a85c38b25c8488115178d5785dbc975f5ff674f9f5716bc8ad6e65": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-arm-linux-gnueabihf.tar.gz"},
|
"d86fc90824a85c38b25c8488115178d5785dbc975f5ff674f9f5716bc8ad6e65": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-arm-linux-gnueabihf.tar.gz"},
|
||||||
"1b0a7408c050e3d09a8be8e21e183ef7ee570385dc41216698cc3ab392a484e7": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-osx64.tar.gz"},
|
"1b0a7408c050e3d09a8be8e21e183ef7ee570385dc41216698cc3ab392a484e7": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-osx64.tar.gz"},
|
||||||
"706e0472dbc933ed2757650d54cbcd780fd3829ebf8f609b32780c7eedebdbc9": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-x86_64-linux-gnu.tar.gz"},
|
"706e0472dbc933ed2757650d54cbcd780fd3829ebf8f609b32780c7eedebdbc9": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"5ea84b6a4c1b03d5f4d1a718fbed215e2fd0e66ca7d59ca6141218d163ce1301": {"tag": "v0.14.3", "archive": "bitcoin-0.14.3-win64.zip"},
|
||||||
|
|
||||||
"60c93e3462c303eb080be7cf623f1a7684b37fd47a018ad3848bc23e13c84e1c": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-aarch64-linux-gnu.tar.gz"},
|
"60c93e3462c303eb080be7cf623f1a7684b37fd47a018ad3848bc23e13c84e1c": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-aarch64-linux-gnu.tar.gz"},
|
||||||
"55b577e0fb306fb429d4be6c9316607753e8543e5946b542d75d876a2f08654c": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-arm-linux-gnueabihf.tar.gz"},
|
"55b577e0fb306fb429d4be6c9316607753e8543e5946b542d75d876a2f08654c": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-arm-linux-gnueabihf.tar.gz"},
|
||||||
"b9024dde373ea7dad707363e07ec7e265383204127539ae0c234bff3a61da0d1": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-osx64.tar.gz"},
|
"b9024dde373ea7dad707363e07ec7e265383204127539ae0c234bff3a61da0d1": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-osx64.tar.gz"},
|
||||||
"fa71cb52ee5e0459cbf5248cdec72df27995840c796f58b304607a1ed4c165af": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-riscv64-linux-gnu.tar.gz"},
|
"fa71cb52ee5e0459cbf5248cdec72df27995840c796f58b304607a1ed4c165af": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-riscv64-linux-gnu.tar.gz"},
|
||||||
"376194f06596ecfa40331167c39bc70c355f960280bd2a645fdbf18f66527397": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-x86_64-linux-gnu.tar.gz"},
|
"376194f06596ecfa40331167c39bc70c355f960280bd2a645fdbf18f66527397": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"e59fba67afce011d32b5d723a3a0be12da1b8a34f5d7966e504520c48d64716d": {"tag": "v0.20.1", "archive": "bitcoin-0.20.1-win64.zip"},
|
||||||
|
|
||||||
"43416854330914992bbba2d0e9adf2a6fff4130be9af8ae2ef1186e743d9a3fe": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-aarch64-linux-gnu.tar.gz"},
|
"43416854330914992bbba2d0e9adf2a6fff4130be9af8ae2ef1186e743d9a3fe": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-aarch64-linux-gnu.tar.gz"},
|
||||||
"f028af308eda45a3c4c90f9332f96b075bf21e3495c945ebce48597151808176": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-arm-linux-gnueabihf.tar.gz"},
|
"f028af308eda45a3c4c90f9332f96b075bf21e3495c945ebce48597151808176": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-arm-linux-gnueabihf.tar.gz"},
|
||||||
"695fb624fa6423f5da4f443b60763dd1d77488bfe5ef63760904a7b54e91298d": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-osx64.tar.gz"},
|
"695fb624fa6423f5da4f443b60763dd1d77488bfe5ef63760904a7b54e91298d": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-osx64.tar.gz"},
|
||||||
"f8b2adfeae021a672effbc7bd40d5c48d6b94e53b2dd660f787340bf1a52e4e9": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-riscv64-linux-gnu.tar.gz"},
|
"f8b2adfeae021a672effbc7bd40d5c48d6b94e53b2dd660f787340bf1a52e4e9": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-riscv64-linux-gnu.tar.gz"},
|
||||||
"da7766775e3f9c98d7a9145429f2be8297c2672fe5b118fd3dc2411fb48e0032": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-x86_64-linux-gnu.tar.gz"},
|
"da7766775e3f9c98d7a9145429f2be8297c2672fe5b118fd3dc2411fb48e0032": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"1d0052c4ce80227fb6d0bc1c4e673ba21033e219c1f935d25f130ef7f43360d4": {"tag": "v0.21.0", "archive": "bitcoin-0.21.0-win64.zip"},
|
||||||
|
|
||||||
"ac718fed08570a81b3587587872ad85a25173afa5f9fbbd0c03ba4d1714cfa3e": {"tag": "v22.0", "archive": "bitcoin-22.0-aarch64-linux-gnu.tar.gz"},
|
"ac718fed08570a81b3587587872ad85a25173afa5f9fbbd0c03ba4d1714cfa3e": {"tag": "v22.0", "archive": "bitcoin-22.0-aarch64-linux-gnu.tar.gz"},
|
||||||
"b8713c6c5f03f5258b54e9f436e2ed6d85449aa24c2c9972f91963d413e86311": {"tag": "v22.0", "archive": "bitcoin-22.0-arm-linux-gnueabihf.tar.gz"},
|
"b8713c6c5f03f5258b54e9f436e2ed6d85449aa24c2c9972f91963d413e86311": {"tag": "v22.0", "archive": "bitcoin-22.0-arm-linux-gnueabihf.tar.gz"},
|
||||||
@@ -44,6 +51,7 @@ SHA256_SUMS = {
|
|||||||
"91b1e012975c5a363b5b5fcc81b5b7495e86ff703ec8262d4b9afcfec633c30d": {"tag": "v22.0", "archive": "bitcoin-22.0-powerpc64le-linux-gnu.tar.gz"},
|
"91b1e012975c5a363b5b5fcc81b5b7495e86ff703ec8262d4b9afcfec633c30d": {"tag": "v22.0", "archive": "bitcoin-22.0-powerpc64le-linux-gnu.tar.gz"},
|
||||||
"9cc3a62c469fe57e11485fdd32c916f10ce7a2899299855a2e479256ff49ff3c": {"tag": "v22.0", "archive": "bitcoin-22.0-riscv64-linux-gnu.tar.gz"},
|
"9cc3a62c469fe57e11485fdd32c916f10ce7a2899299855a2e479256ff49ff3c": {"tag": "v22.0", "archive": "bitcoin-22.0-riscv64-linux-gnu.tar.gz"},
|
||||||
"59ebd25dd82a51638b7a6bb914586201e67db67b919b2a1ff08925a7936d1b16": {"tag": "v22.0", "archive": "bitcoin-22.0-x86_64-linux-gnu.tar.gz"},
|
"59ebd25dd82a51638b7a6bb914586201e67db67b919b2a1ff08925a7936d1b16": {"tag": "v22.0", "archive": "bitcoin-22.0-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"9485e4b52ed6cebfe474ab4d7d0c1be6d0bb879ba7246a8239326b2230a77eb1": {"tag": "v22.0", "archive": "bitcoin-22.0-win64.zip"},
|
||||||
|
|
||||||
"06f4c78271a77752ba5990d60d81b1751507f77efda1e5981b4e92fd4d9969fb": {"tag": "v23.0", "archive": "bitcoin-23.0-aarch64-linux-gnu.tar.gz"},
|
"06f4c78271a77752ba5990d60d81b1751507f77efda1e5981b4e92fd4d9969fb": {"tag": "v23.0", "archive": "bitcoin-23.0-aarch64-linux-gnu.tar.gz"},
|
||||||
"952c574366aff76f6d6ad1c9ee45a361d64fa04155e973e926dfe7e26f9703a3": {"tag": "v23.0", "archive": "bitcoin-23.0-arm-linux-gnueabihf.tar.gz"},
|
"952c574366aff76f6d6ad1c9ee45a361d64fa04155e973e926dfe7e26f9703a3": {"tag": "v23.0", "archive": "bitcoin-23.0-arm-linux-gnueabihf.tar.gz"},
|
||||||
@@ -53,6 +61,7 @@ SHA256_SUMS = {
|
|||||||
"078f96b1e92895009c798ab827fb3fde5f6719eee886bd0c0e93acab18ea4865": {"tag": "v23.0", "archive": "bitcoin-23.0-riscv64-linux-gnu.tar.gz"},
|
"078f96b1e92895009c798ab827fb3fde5f6719eee886bd0c0e93acab18ea4865": {"tag": "v23.0", "archive": "bitcoin-23.0-riscv64-linux-gnu.tar.gz"},
|
||||||
"c816780583009a9dad426dc0c183c89be9da98906e1e2c7ebae91041c1aaaaf3": {"tag": "v23.0", "archive": "bitcoin-23.0-x86_64-apple-darwin.tar.gz"},
|
"c816780583009a9dad426dc0c183c89be9da98906e1e2c7ebae91041c1aaaaf3": {"tag": "v23.0", "archive": "bitcoin-23.0-x86_64-apple-darwin.tar.gz"},
|
||||||
"2cca490c1f2842884a3c5b0606f179f9f937177da4eadd628e3f7fd7e25d26d0": {"tag": "v23.0", "archive": "bitcoin-23.0-x86_64-linux-gnu.tar.gz"},
|
"2cca490c1f2842884a3c5b0606f179f9f937177da4eadd628e3f7fd7e25d26d0": {"tag": "v23.0", "archive": "bitcoin-23.0-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"004b2e25b21e0f14cbcce6acec37f221447abbb3ea7931c689e508054bfc6cf6": {"tag": "v23.0", "archive": "bitcoin-23.0-win64.zip"},
|
||||||
|
|
||||||
"0b48b9e69b30037b41a1e6b78fb7cbcc48c7ad627908c99686e81f3802454609": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-aarch64-linux-gnu.tar.gz"},
|
"0b48b9e69b30037b41a1e6b78fb7cbcc48c7ad627908c99686e81f3802454609": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-aarch64-linux-gnu.tar.gz"},
|
||||||
"37d7660f0277301744e96426bbb001d2206b8d4505385dfdeedf50c09aaaef60": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-arm-linux-gnueabihf.tar.gz"},
|
"37d7660f0277301744e96426bbb001d2206b8d4505385dfdeedf50c09aaaef60": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-arm-linux-gnueabihf.tar.gz"},
|
||||||
@@ -62,6 +71,7 @@ SHA256_SUMS = {
|
|||||||
"6b163cef7de4beb07b8cb3347095e0d76a584019b1891135cd1268a1f05b9d88": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-riscv64-linux-gnu.tar.gz"},
|
"6b163cef7de4beb07b8cb3347095e0d76a584019b1891135cd1268a1f05b9d88": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-riscv64-linux-gnu.tar.gz"},
|
||||||
"e2f751512f3c0f00eb68ba946d9c829e6cf99422a61e8f5e0a7c109c318674d0": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-x86_64-apple-darwin.tar.gz"},
|
"e2f751512f3c0f00eb68ba946d9c829e6cf99422a61e8f5e0a7c109c318674d0": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-x86_64-apple-darwin.tar.gz"},
|
||||||
"49df6e444515d457ea0b885d66f521f2a26ca92ccf73d5296082e633544253bf": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-x86_64-linux-gnu.tar.gz"},
|
"49df6e444515d457ea0b885d66f521f2a26ca92ccf73d5296082e633544253bf": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"8784ce304f22c495392d3adfd7fc2c645d093db9bd4d42666c41adf540539fff": {"tag": "v24.0.1", "archive": "bitcoin-24.0.1-win64.zip"},
|
||||||
|
|
||||||
"3a7bdd959a0b426624f63f394f25e5b7769a5a2f96f8126dcc2ea53f3fa5212b": {"tag": "v25.0", "archive": "bitcoin-25.0-aarch64-linux-gnu.tar.gz"},
|
"3a7bdd959a0b426624f63f394f25e5b7769a5a2f96f8126dcc2ea53f3fa5212b": {"tag": "v25.0", "archive": "bitcoin-25.0-aarch64-linux-gnu.tar.gz"},
|
||||||
"e537c8630b05e63242d979c3004f851fd73c2a10b5b4fdbb161788427c7b3c0f": {"tag": "v25.0", "archive": "bitcoin-25.0-arm-linux-gnueabihf.tar.gz"},
|
"e537c8630b05e63242d979c3004f851fd73c2a10b5b4fdbb161788427c7b3c0f": {"tag": "v25.0", "archive": "bitcoin-25.0-arm-linux-gnueabihf.tar.gz"},
|
||||||
@@ -71,6 +81,7 @@ SHA256_SUMS = {
|
|||||||
"fe6e347a66043946920c72c9c4afca301968101e6b82fb90a63d7885ebcceb32": {"tag": "v25.0", "archive": "bitcoin-25.0-riscv64-linux-gnu.tar.gz"},
|
"fe6e347a66043946920c72c9c4afca301968101e6b82fb90a63d7885ebcceb32": {"tag": "v25.0", "archive": "bitcoin-25.0-riscv64-linux-gnu.tar.gz"},
|
||||||
"5708fc639cdfc27347cccfd50db9b73b53647b36fb5f3a4a93537cbe8828c27f": {"tag": "v25.0", "archive": "bitcoin-25.0-x86_64-apple-darwin.tar.gz"},
|
"5708fc639cdfc27347cccfd50db9b73b53647b36fb5f3a4a93537cbe8828c27f": {"tag": "v25.0", "archive": "bitcoin-25.0-x86_64-apple-darwin.tar.gz"},
|
||||||
"33930d432593e49d58a9bff4c30078823e9af5d98594d2935862788ce8a20aec": {"tag": "v25.0", "archive": "bitcoin-25.0-x86_64-linux-gnu.tar.gz"},
|
"33930d432593e49d58a9bff4c30078823e9af5d98594d2935862788ce8a20aec": {"tag": "v25.0", "archive": "bitcoin-25.0-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"7154b35ecc8247589070ae739b7c73c4dee4794bea49eb18dc66faed65b819e7": {"tag": "v25.0", "archive": "bitcoin-25.0-win64.zip"},
|
||||||
|
|
||||||
"7fa582d99a25c354d23e371a5848bd9e6a79702870f9cbbf1292b86e647d0f4e": {"tag": "v28.0", "archive": "bitcoin-28.0-aarch64-linux-gnu.tar.gz"},
|
"7fa582d99a25c354d23e371a5848bd9e6a79702870f9cbbf1292b86e647d0f4e": {"tag": "v28.0", "archive": "bitcoin-28.0-aarch64-linux-gnu.tar.gz"},
|
||||||
"e004b7910bedd6dd18b6c52b4eef398d55971da666487a82cd48708d2879727e": {"tag": "v28.0", "archive": "bitcoin-28.0-arm-linux-gnueabihf.tar.gz"},
|
"e004b7910bedd6dd18b6c52b4eef398d55971da666487a82cd48708d2879727e": {"tag": "v28.0", "archive": "bitcoin-28.0-arm-linux-gnueabihf.tar.gz"},
|
||||||
@@ -79,6 +90,7 @@ SHA256_SUMS = {
|
|||||||
"6ee1a520b638132a16725020146abea045db418ce91c02493f02f541cd53062a": {"tag": "v28.0", "archive": "bitcoin-28.0-riscv64-linux-gnu.tar.gz"},
|
"6ee1a520b638132a16725020146abea045db418ce91c02493f02f541cd53062a": {"tag": "v28.0", "archive": "bitcoin-28.0-riscv64-linux-gnu.tar.gz"},
|
||||||
"77e931bbaaf47771a10c376230bf53223f5380864bad3568efc7f4d02e40a0f7": {"tag": "v28.0", "archive": "bitcoin-28.0-x86_64-apple-darwin.tar.gz"},
|
"77e931bbaaf47771a10c376230bf53223f5380864bad3568efc7f4d02e40a0f7": {"tag": "v28.0", "archive": "bitcoin-28.0-x86_64-apple-darwin.tar.gz"},
|
||||||
"7fe294b02b25b51acb8e8e0a0eb5af6bbafa7cd0c5b0e5fcbb61263104a82fbc": {"tag": "v28.0", "archive": "bitcoin-28.0-x86_64-linux-gnu.tar.gz"},
|
"7fe294b02b25b51acb8e8e0a0eb5af6bbafa7cd0c5b0e5fcbb61263104a82fbc": {"tag": "v28.0", "archive": "bitcoin-28.0-x86_64-linux-gnu.tar.gz"},
|
||||||
|
"85282f4ec1bcb0cfe8db0f195e8e0f6fb77cfbe89242a81fff2bc2e9292f7acf": {"tag": "v28.0", "archive": "bitcoin-28.0-win64.zip"},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -92,31 +104,71 @@ def pushd(new_dir) -> None:
|
|||||||
os.chdir(previous_dir)
|
os.chdir(previous_dir)
|
||||||
|
|
||||||
|
|
||||||
|
def download_from_url(url, archive):
|
||||||
|
last_print_time = time.time()
|
||||||
|
|
||||||
|
def progress_hook(progress_bytes, total_size):
|
||||||
|
nonlocal last_print_time
|
||||||
|
now = time.time()
|
||||||
|
percent = min(100, (progress_bytes * 100) / total_size)
|
||||||
|
bar_length = 40
|
||||||
|
filled_length = int(bar_length * percent / 100)
|
||||||
|
bar = '#' * filled_length + '-' * (bar_length - filled_length)
|
||||||
|
if now - last_print_time >= 1 or percent >= 100:
|
||||||
|
print(f'\rDownloading: [{bar}] {percent:.1f}%', flush=True, end="")
|
||||||
|
last_print_time = now
|
||||||
|
|
||||||
|
with urllib.request.urlopen(url) as response:
|
||||||
|
if response.status != 200:
|
||||||
|
raise RuntimeError(f"HTTP request failed with status code: {response.status}")
|
||||||
|
|
||||||
|
total_size = int(response.getheader('Content-Length', 0))
|
||||||
|
progress_bytes = 0
|
||||||
|
|
||||||
|
with open(archive, 'wb') as file:
|
||||||
|
while True:
|
||||||
|
chunk = response.read(8192)
|
||||||
|
if not chunk:
|
||||||
|
break
|
||||||
|
file.write(chunk)
|
||||||
|
progress_bytes += len(chunk)
|
||||||
|
progress_hook(progress_bytes, total_size)
|
||||||
|
|
||||||
|
print('\n', flush=True, end="") # Flush to avoid error output on the same line.
|
||||||
|
|
||||||
|
|
||||||
def download_binary(tag, args) -> int:
|
def download_binary(tag, args) -> int:
|
||||||
if Path(tag).is_dir():
|
if Path(tag).is_dir():
|
||||||
if not args.remove_dir:
|
if not args.remove_dir:
|
||||||
print('Using cached {}'.format(tag))
|
print('Using cached {}'.format(tag))
|
||||||
return 0
|
return 0
|
||||||
shutil.rmtree(tag)
|
shutil.rmtree(tag)
|
||||||
Path(tag).mkdir()
|
|
||||||
bin_path = 'bin/bitcoin-core-{}'.format(tag[1:])
|
bin_path = 'bin/bitcoin-core-{}'.format(tag[1:])
|
||||||
|
|
||||||
match = re.compile('v(.*)(rc[0-9]+)$').search(tag)
|
match = re.compile('v(.*)(rc[0-9]+)$').search(tag)
|
||||||
if match:
|
if match:
|
||||||
bin_path = 'bin/bitcoin-core-{}/test.{}'.format(
|
bin_path = 'bin/bitcoin-core-{}/test.{}'.format(
|
||||||
match.group(1), match.group(2))
|
match.group(1), match.group(2))
|
||||||
platform = args.platform
|
|
||||||
if tag < "v23" and platform in ["x86_64-apple-darwin", "arm64-apple-darwin"]:
|
|
||||||
platform = "osx64"
|
|
||||||
archive = 'bitcoin-{tag}-{platform}.tar.gz'.format(
|
|
||||||
tag=tag[1:], platform=platform)
|
|
||||||
archiveUrl = 'https://bitcoincore.org/{bin_path}/{archive}'.format(
|
|
||||||
bin_path=bin_path, archive=archive)
|
|
||||||
|
|
||||||
print('Fetching: {archiveUrl}'.format(archiveUrl=archiveUrl))
|
host = args.host
|
||||||
|
if tag < "v23" and host in ["x86_64-apple-darwin", "arm64-apple-darwin"]:
|
||||||
|
host = "osx64"
|
||||||
|
|
||||||
ret = subprocess.run(['curl', '--fail', '--remote-name', archiveUrl]).returncode
|
archive_format = 'tar.gz'
|
||||||
if ret:
|
if host == 'win64':
|
||||||
return ret
|
archive_format = 'zip'
|
||||||
|
|
||||||
|
archive = f'bitcoin-{tag[1:]}-{host}.{archive_format}'
|
||||||
|
archive_url = f'https://bitcoincore.org/{bin_path}/{archive}'
|
||||||
|
|
||||||
|
print(f'Fetching: {archive_url}')
|
||||||
|
|
||||||
|
try:
|
||||||
|
download_from_url(archive_url, archive)
|
||||||
|
except Exception as e:
|
||||||
|
print(f"\nDownload failed: {e}", file=sys.stderr)
|
||||||
|
return 1
|
||||||
|
|
||||||
hasher = hashlib.sha256()
|
hasher = hashlib.sha256()
|
||||||
with open(archive, "rb") as afile:
|
with open(archive, "rb") as afile:
|
||||||
@@ -125,20 +177,37 @@ def download_binary(tag, args) -> int:
|
|||||||
|
|
||||||
if archiveHash not in SHA256_SUMS or SHA256_SUMS[archiveHash]['archive'] != archive:
|
if archiveHash not in SHA256_SUMS or SHA256_SUMS[archiveHash]['archive'] != archive:
|
||||||
if archive in [v['archive'] for v in SHA256_SUMS.values()]:
|
if archive in [v['archive'] for v in SHA256_SUMS.values()]:
|
||||||
print("Checksum did not match")
|
print(f"Checksum {archiveHash} did not match", file=sys.stderr)
|
||||||
return 1
|
else:
|
||||||
|
print("Checksum for given version doesn't exist", file=sys.stderr)
|
||||||
print("Checksum for given version doesn't exist")
|
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
print("Checksum matched")
|
print("Checksum matched")
|
||||||
|
Path(tag).mkdir()
|
||||||
|
|
||||||
# Extract archive
|
# Extract archive
|
||||||
ret = subprocess.run(['tar', '-zxf', archive, '-C', tag,
|
if host == 'win64':
|
||||||
'--strip-components=1',
|
try:
|
||||||
'bitcoin-{tag}'.format(tag=tag[1:])]).returncode
|
with zipfile.ZipFile(archive, 'r') as zip:
|
||||||
if ret != 0:
|
zip.extractall(tag)
|
||||||
print(f"Failed to extract the {tag} archive")
|
# Remove the top level directory to match tar's --strip-components=1
|
||||||
return ret
|
extracted_items = os.listdir(tag)
|
||||||
|
top_level_dir = os.path.join(tag, extracted_items[0])
|
||||||
|
# Move all files & subdirectories up one level
|
||||||
|
for item in os.listdir(top_level_dir):
|
||||||
|
shutil.move(os.path.join(top_level_dir, item), tag)
|
||||||
|
# Remove the now-empty top-level directory
|
||||||
|
os.rmdir(top_level_dir)
|
||||||
|
except Exception as e:
|
||||||
|
print(f"Zip extraction failed: {e}", file=sys.stderr)
|
||||||
|
return 1
|
||||||
|
else:
|
||||||
|
ret = subprocess.run(['tar', '-zxf', archive, '-C', tag,
|
||||||
|
'--strip-components=1',
|
||||||
|
'bitcoin-{tag}'.format(tag=tag[1:])]).returncode
|
||||||
|
if ret != 0:
|
||||||
|
print(f"Failed to extract the {tag} tarball", file=sys.stderr)
|
||||||
|
return ret
|
||||||
|
|
||||||
Path(archive).unlink()
|
Path(archive).unlink()
|
||||||
|
|
||||||
@@ -158,7 +227,7 @@ def download_binary(tag, args) -> int:
|
|||||||
['codesign', '-s', '-', binary_path + arm_binary]
|
['codesign', '-s', '-', binary_path + arm_binary]
|
||||||
).returncode
|
).returncode
|
||||||
if ret != 0:
|
if ret != 0:
|
||||||
print(f"Failed to self-sign {tag} {arm_binary} arm64 binary")
|
print(f"Failed to self-sign {tag} {arm_binary} arm64 binary", file=sys.stderr)
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
# Confirm success
|
# Confirm success
|
||||||
@@ -166,14 +235,20 @@ def download_binary(tag, args) -> int:
|
|||||||
['codesign', '-v', binary_path + arm_binary]
|
['codesign', '-v', binary_path + arm_binary]
|
||||||
).returncode
|
).returncode
|
||||||
if ret != 0:
|
if ret != 0:
|
||||||
print(f"Failed to verify the self-signed {tag} {arm_binary} arm64 binary")
|
print(f"Failed to verify the self-signed {tag} {arm_binary} arm64 binary", file=sys.stderr)
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
def check_host(args) -> int:
|
def set_host(args) -> int:
|
||||||
args.host = os.environ.get('HOST', subprocess.check_output(
|
if platform.system().lower() == 'windows':
|
||||||
|
if platform.machine() != 'AMD64':
|
||||||
|
print('Only 64bit Windows supported', file=sys.stderr)
|
||||||
|
return 1
|
||||||
|
args.host = 'win64'
|
||||||
|
return 0
|
||||||
|
host = os.environ.get('HOST', subprocess.check_output(
|
||||||
'./depends/config.guess').decode())
|
'./depends/config.guess').decode())
|
||||||
platforms = {
|
platforms = {
|
||||||
'aarch64-*-linux*': 'aarch64-linux-gnu',
|
'aarch64-*-linux*': 'aarch64-linux-gnu',
|
||||||
@@ -183,12 +258,12 @@ def check_host(args) -> int:
|
|||||||
'x86_64-apple-darwin*': 'x86_64-apple-darwin',
|
'x86_64-apple-darwin*': 'x86_64-apple-darwin',
|
||||||
'aarch64-apple-darwin*': 'arm64-apple-darwin',
|
'aarch64-apple-darwin*': 'arm64-apple-darwin',
|
||||||
}
|
}
|
||||||
args.platform = ''
|
args.host = ''
|
||||||
for pattern, target in platforms.items():
|
for pattern, target in platforms.items():
|
||||||
if fnmatch(args.host, pattern):
|
if fnmatch(host, pattern):
|
||||||
args.platform = target
|
args.host = target
|
||||||
if not args.platform:
|
if not args.host:
|
||||||
print('Not sure which binary to download for {}'.format(args.host))
|
print('Not sure which binary to download for {}'.format(host), file=sys.stderr)
|
||||||
return 1
|
return 1
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
@@ -196,7 +271,7 @@ def check_host(args) -> int:
|
|||||||
def main(args) -> int:
|
def main(args) -> int:
|
||||||
Path(args.target_dir).mkdir(exist_ok=True, parents=True)
|
Path(args.target_dir).mkdir(exist_ok=True, parents=True)
|
||||||
print("Releases directory: {}".format(args.target_dir))
|
print("Releases directory: {}".format(args.target_dir))
|
||||||
ret = check_host(args)
|
ret = set_host(args)
|
||||||
if ret:
|
if ret:
|
||||||
return ret
|
return ret
|
||||||
with pushd(args.target_dir):
|
with pushd(args.target_dir):
|
||||||
|
|||||||
Reference in New Issue
Block a user