Skip to content

Commit

Permalink
Merge remote-tracking branch 'bitcoin/master' into btc-master
Browse files Browse the repository at this point in the history
 Conflicts:
	.cirrus.yml
	Makefile.am
	build_msvc/bitcoin-qt/bitcoin-qt.vcxproj
	build_msvc/common.init.vcxproj.in
	build_msvc/libtest_util/libtest_util.vcxproj.in
	build_msvc/test_bitcoin-qt/test_bitcoin-qt.vcxproj
	ci/test/00_setup_env_android.sh
	ci/test/00_setup_env_arm.sh
	ci/test/00_setup_env_i686_centos.sh
	ci/test/00_setup_env_i686_multiprocess.sh
	ci/test/00_setup_env_mac.sh
	ci/test/00_setup_env_native.sh
	ci/test/00_setup_env_native_asan.sh
	ci/test/00_setup_env_native_fuzz.sh
	ci/test/00_setup_env_native_fuzz_with_msan.sh
	ci/test/00_setup_env_native_fuzz_with_valgrind.sh
	ci/test/00_setup_env_native_msan.sh
	ci/test/00_setup_env_native_nowallet_libbitcoinkernel.sh
	ci/test/00_setup_env_native_tidy.sh
	ci/test/00_setup_env_native_tsan.sh
	ci/test/00_setup_env_native_valgrind.sh
	ci/test/00_setup_env_win64.sh
	ci/test/04_install.sh
	ci/test/06_script_a.sh
	ci/test/06_script_b.sh
	configure.ac
	contrib/macdeploy/macdeployqtplus
	depends/packages/qt.mk
	doc/build-unix.md
	doc/design/assumeutxo.md
	doc/fuzzing.md
	doc/reduce-memory.md
	doc/release-process.md
	share/qt/Info.plist.in
	src/.bear-tidy-config
	src/Makefile.am
	src/Makefile.bench.include
	src/Makefile.qt.include
	src/Makefile.qt_locale.include
	src/Makefile.test.include
	src/bench/mempool_eviction.cpp
	src/bench/mempool_stress.cpp
	src/bench/rpc_mempool.cpp
	src/bitcoind.cpp
	src/coins.cpp
	src/coins.h
	src/core_io.h
	src/core_write.cpp
	src/crypto/muhash.cpp
	src/init.cpp
	src/kernel/mempool_entry.h
	src/key_io.h
	src/logging.cpp
	src/logging.h
	src/net_processing.cpp
	src/node/interfaces.cpp
	src/primitives/transaction.cpp
	src/primitives/transaction.h
	src/protocol.cpp
	src/qt/addressbookpage.cpp
	src/qt/addressbookpage.h
	src/qt/addresstablemodel.cpp
	src/qt/addresstablemodel.h
	src/qt/android/gradle.properties
	src/qt/askpassphrasedialog.cpp
	src/qt/bitcoin.cpp
	src/qt/bitcoin.h
	src/qt/bitcoin_locale.qrc
	src/qt/bitcoingui.cpp
	src/qt/bitcoingui.h
	src/qt/bitcoinstrings.cpp
	src/qt/clientmodel.cpp
	src/qt/coincontroldialog.cpp
	src/qt/coincontroldialog.h
	src/qt/createwalletdialog.cpp
	src/qt/createwalletdialog.h
	src/qt/forms/coincontroldialog.ui
	src/qt/forms/createwalletdialog.ui
	src/qt/forms/debugwindow.ui
	src/qt/forms/sendcoinsdialog.ui
	src/qt/guiutil.cpp
	src/qt/locale/bitcoin_am.ts
	src/qt/locale/bitcoin_ar.ts
	src/qt/locale/bitcoin_az.ts
	src/qt/locale/bitcoin_be.ts
	src/qt/locale/bitcoin_bg.ts
	src/qt/locale/bitcoin_bn.ts
	src/qt/locale/bitcoin_bs.ts
	src/qt/locale/bitcoin_ca.ts
	src/qt/locale/bitcoin_cs.ts
	src/qt/locale/bitcoin_da.ts
	src/qt/locale/bitcoin_de.ts
	src/qt/locale/bitcoin_el.ts
	src/qt/locale/bitcoin_en.ts
	src/qt/locale/bitcoin_en.xlf
	src/qt/locale/bitcoin_eo.ts
	src/qt/locale/bitcoin_es.ts
	src/qt/locale/bitcoin_es_CL.ts
	src/qt/locale/bitcoin_es_CO.ts
	src/qt/locale/bitcoin_es_DO.ts
	src/qt/locale/bitcoin_es_MX.ts
	src/qt/locale/bitcoin_es_VE.ts
	src/qt/locale/bitcoin_et.ts
	src/qt/locale/bitcoin_eu.ts
	src/qt/locale/bitcoin_fa.ts
	src/qt/locale/bitcoin_fi.ts
	src/qt/locale/bitcoin_fil.ts
	src/qt/locale/bitcoin_fr.ts
	src/qt/locale/bitcoin_ga.ts
	src/qt/locale/bitcoin_gl.ts
	src/qt/locale/bitcoin_gl_ES.ts
	src/qt/locale/bitcoin_gu.ts
	src/qt/locale/bitcoin_ha.ts
	src/qt/locale/bitcoin_he.ts
	src/qt/locale/bitcoin_hr.ts
	src/qt/locale/bitcoin_hu.ts
	src/qt/locale/bitcoin_id.ts
	src/qt/locale/bitcoin_is.ts
	src/qt/locale/bitcoin_it.ts
	src/qt/locale/bitcoin_ja.ts
	src/qt/locale/bitcoin_ka.ts
	src/qt/locale/bitcoin_kk.ts
	src/qt/locale/bitcoin_km.ts
	src/qt/locale/bitcoin_ko.ts
	src/qt/locale/bitcoin_ku.ts
	src/qt/locale/bitcoin_ku_IQ.ts
	src/qt/locale/bitcoin_la.ts
	src/qt/locale/bitcoin_lt.ts
	src/qt/locale/bitcoin_lv.ts
	src/qt/locale/bitcoin_ml.ts
	src/qt/locale/bitcoin_mn.ts
	src/qt/locale/bitcoin_mr_IN.ts
	src/qt/locale/bitcoin_ms.ts
	src/qt/locale/bitcoin_nb.ts
	src/qt/locale/bitcoin_ne.ts
	src/qt/locale/bitcoin_nl.ts
	src/qt/locale/bitcoin_pa.ts
	src/qt/locale/bitcoin_pam.ts
	src/qt/locale/bitcoin_pl.ts
	src/qt/locale/bitcoin_pt.ts
	src/qt/locale/bitcoin_pt_BR.ts
	src/qt/locale/bitcoin_ro.ts
	src/qt/locale/bitcoin_ru.ts
	src/qt/locale/bitcoin_si.ts
	src/qt/locale/bitcoin_sk.ts
	src/qt/locale/bitcoin_sl.ts
	src/qt/locale/bitcoin_sq.ts
	src/qt/locale/bitcoin_sr.ts
	src/qt/locale/[email protected]
	src/qt/locale/bitcoin_sv.ts
	src/qt/locale/bitcoin_sw.ts
	src/qt/locale/bitcoin_szl.ts
	src/qt/locale/bitcoin_ta.ts
	src/qt/locale/bitcoin_te.ts
	src/qt/locale/bitcoin_th.ts
	src/qt/locale/bitcoin_tk.ts
	src/qt/locale/bitcoin_tl.ts
	src/qt/locale/bitcoin_tr.ts
	src/qt/locale/bitcoin_ug.ts
	src/qt/locale/bitcoin_uk.ts
	src/qt/locale/bitcoin_ur.ts
	src/qt/locale/bitcoin_uz.ts
	src/qt/locale/[email protected]
	src/qt/locale/[email protected]
	src/qt/locale/bitcoin_vi.ts
	src/qt/locale/bitcoin_zh-Hans.ts
	src/qt/locale/bitcoin_zh.ts
	src/qt/locale/bitcoin_zh_CN.ts
	src/qt/locale/bitcoin_zh_HK.ts
	src/qt/locale/bitcoin_zh_TW.ts
	src/qt/locale/bitcoin_zu.ts
	src/qt/optionsdialog.cpp
	src/qt/optionsmodel.cpp
	src/qt/paymentserver.h
	src/qt/psbtoperationsdialog.cpp
	src/qt/psbtoperationsdialog.h
	src/qt/rpcconsole.cpp
	src/qt/rpcconsole.h
	src/qt/sendcoinsdialog.cpp
	src/qt/sendcoinsdialog.h
	src/qt/splashscreen.cpp
	src/qt/test/addressbooktests.cpp
	src/qt/test/apptests.cpp
	src/qt/test/optiontests.cpp
	src/qt/test/optiontests.h
	src/qt/test/rpcnestedtests.cpp
	src/qt/test/test_main.cpp
	src/qt/test/uritests.cpp
	src/qt/test/util.cpp
	src/qt/test/util.h
	src/qt/test/wallettests.cpp
	src/qt/transactiondesc.cpp
	src/qt/transactionrecord.cpp
	src/qt/transactionrecord.h
	src/qt/transactiontablemodel.cpp
	src/qt/transactionview.cpp
	src/qt/walletcontroller.cpp
	src/qt/walletcontroller.h
	src/qt/walletmodel.cpp
	src/qt/walletmodel.h
	src/qt/winshutdownmonitor.cpp
	src/rpc/client.cpp
	src/rpc/rawtransaction.cpp
	src/script/standard.cpp
	src/script/standard.h
	src/test/fuzz/process_message.cpp
	src/test/fuzz/util.cpp
	src/test/fuzz/util.h
	src/test/fuzz/util/mempool.cpp
	src/test/hash_tests.cpp
	src/test/rpc_tests.cpp
	src/test/script_tests.cpp
	src/test/sighash_tests.cpp
	src/test/util/setup_common.cpp
	src/test/util/setup_common.h
	src/test/util/txmempool.cpp
	src/validation.cpp
	src/wallet/rpc/addresses.cpp
	src/wallet/scriptpubkeyman.h
	src/wallet/test/wallet_tests.cpp
	src/wallet/test/walletload_tests.cpp
	src/wallet/wallet.cpp
	src/wallet/wallet.h
	src/wallet/walletdb.cpp
	src/wallet/walletdb.h
	test/functional/feature_config_args.py
	test/functional/feature_filelock.py
	test/functional/feature_includeconf.py
	test/functional/feature_settings.py
	test/functional/feature_syscall_sandbox.py
	test/functional/rpc_psbt.py
	test/functional/rpc_users.py
	test/functional/rpc_whitelist.py
	test/functional/test-shell.md
	test/functional/test_framework/test_framework.py
	test/functional/test_framework/test_node.py
	test/functional/test_runner.py
	test/functional/tool_wallet.py
	test/functional/wallet_backwards_compatibility.py
	test/functional/wallet_fundrawtransaction.py
	test/lint/lint-circular-dependencies.py
	test/lint/lint-format-strings.py
	test/lint/lint-includes.py
	test/lint/lint-python.py
	test/lint/lint-shell.py
  • Loading branch information
mxaddict committed Dec 23, 2023
2 parents 9177239 + 3e69125 commit 96d08c5
Show file tree
Hide file tree
Showing 1,069 changed files with 44,548 additions and 20,533 deletions.
348 changes: 105 additions & 243 deletions .cirrus.yml

Large diffs are not rendered by default.

6 changes: 4 additions & 2 deletions .github/ISSUE_TEMPLATE/good_first_issue.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,10 @@ body:
attributes:
label: Useful Skills
description: For example, “`std::thread`”, “Qt5 GUI and async GUI design” or “basic understanding of Bitcoin mining and the Bitcoin Core RPC interface”.
validations:
required: false
value: |
* Compiling Bitcoin Core from source
* Running the C++ unit tests and the Python functional tests
* ...
- type: textarea
attributes:
label: Guidance for new contributors
Expand Down
291 changes: 291 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,291 @@
# Copyright (c) 2023 The Bitcoin Core developers
# Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php.

name: CI
on:
# See: https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#pull_request.
pull_request:
# See: https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#push.
push:
branches:
- '**'
tags-ignore:
- '**'

concurrency:
group: ${{ github.event_name != 'pull_request' && github.run_id || github.ref }}
cancel-in-progress: true

env:
DANGER_RUN_CI_ON_HOST: 1
CI_FAILFAST_TEST_LEAVE_DANGLING: 1 # GHA does not care about dangling processes and setting this variable avoids killing the CI script itself on error
MAKEJOBS: '-j10'

jobs:
test-each-commit:
name: 'test each commit'
runs-on: ubuntu-22.04
if: github.event_name == 'pull_request' && github.event.pull_request.commits != 1
timeout-minutes: 360 # Use maximum time, see https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idtimeout-minutes. Assuming a worst case time of 1 hour per commit, this leads to a --max-count=6 below.
env:
MAX_COUNT: 6
steps:
- name: Determine fetch depth
run: echo "FETCH_DEPTH=$((${{ github.event.pull_request.commits }} + 2))" >> "$GITHUB_ENV"
- uses: actions/checkout@v4
with:
ref: ${{ github.event.pull_request.head.sha }}
fetch-depth: ${{ env.FETCH_DEPTH }}
- name: Determine commit range
run: |
# Checkout HEAD~ and find the test base commit
# Checkout HEAD~ because it would be wasteful to rerun tests on the PR
# head commit that are already run by other jobs.
git checkout HEAD~
# Figure out test base commit by listing ancestors of HEAD, excluding
# ancestors of the most recent merge commit, limiting the list to the
# newest MAX_COUNT ancestors, ordering it from oldest to newest, and
# taking the first one.
#
# If the branch contains up to MAX_COUNT ancestor commits after the
# most recent merge commit, all of those commits will be tested. If it
# contains more, only the most recent MAX_COUNT commits will be
# tested.
#
# In the command below, the ^@ suffix is used to refer to all parents
# of the merge commit as described in:
# https://git-scm.com/docs/git-rev-parse#_other_rev_parent_shorthand_notations
# and the ^ prefix is used to exclude these parents and all their
# ancestors from the rev-list output as described in:
# https://git-scm.com/docs/git-rev-list
echo "TEST_BASE=$(git rev-list -n$((${{ env.MAX_COUNT }} + 1)) --reverse HEAD ^$(git rev-list -n1 --merges HEAD)^@ | head -1)" >> "$GITHUB_ENV"
- run: |
sudo apt-get update
sudo apt-get install clang-15 ccache build-essential libtool autotools-dev automake pkg-config bsdmainutils python3-zmq libevent-dev libboost-dev libsqlite3-dev libdb++-dev systemtap-sdt-dev libminiupnpc-dev libnatpmp-dev libqt5gui5 libqt5core5a libqt5dbus5 qttools5-dev qttools5-dev-tools qtwayland5 libqrencode-dev -y
- name: Compile and run tests
run: |
# Run tests on commits after the last merge commit and before the PR head commit
# Use clang++, because it is a bit faster and uses less memory than g++
git rebase --exec "echo Running test-one-commit on \$( git log -1 ) && ./autogen.sh && CC=clang-15 CXX=clang++-15 ./configure && make clean && make -j $(nproc) check && ./test/functional/test_runner.py -j $(( $(nproc) * 2 ))" ${{ env.TEST_BASE }}
macos-native-x86_64:
name: 'macOS 13 native, x86_64, no depends, sqlite only, gui'
# Use latest image, but hardcode version to avoid silent upgrades (and breaks).
# See: https://github.com/actions/runner-images#available-images.
runs-on: macos-13

# No need to run on the read-only mirror, unless it is a PR.
if: github.repository != 'bitcoin-core/gui' || github.event_name == 'pull_request'

timeout-minutes: 120

env:
FILE_ENV: './ci/test/00_setup_env_mac_native.sh'
BASE_ROOT_DIR: ${{ github.workspace }}

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Clang version
run: clang --version

- name: Install Homebrew packages
run: brew install automake libtool pkg-config gnu-getopt ccache boost libevent miniupnpc libnatpmp zeromq qt@5 qrencode

- name: Set Ccache directory
run: echo "CCACHE_DIR=${RUNNER_TEMP}/ccache_dir" >> "$GITHUB_ENV"

- name: Restore Ccache cache
id: ccache-cache
uses: actions/cache/restore@v3
with:
path: ${{ env.CCACHE_DIR }}
key: ${{ github.job }}-ccache-${{ github.run_id }}
restore-keys: ${{ github.job }}-ccache-

- name: CI script
run: ./ci/test_run_all.sh

- name: Save Ccache cache
uses: actions/cache/save@v3
if: github.event_name != 'pull_request' && steps.ccache-cache.outputs.cache-hit != 'true'
with:
path: ${{ env.CCACHE_DIR }}
# https://github.com/actions/cache/blob/main/tips-and-workarounds.md#update-a-cache
key: ${{ github.job }}-ccache-${{ github.run_id }}

win64-native:
name: 'Win64 native, VS 2022'
# Use latest image, but hardcode version to avoid silent upgrades (and breaks).
# See: https://github.com/actions/runner-images#available-images.
runs-on: windows-2022

# No need to run on the read-only mirror, unless it is a PR.
if: github.repository != 'bitcoin-core/gui' || github.event_name == 'pull_request'

env:
CCACHE_MAXSIZE: '200M'
CI_CCACHE_VERSION: '4.7.5'
CI_QT_CONF: '-release -silent -opensource -confirm-license -opengl desktop -static -static-runtime -mp -qt-zlib -qt-pcre -qt-libpng -nomake examples -nomake tests -nomake tools -no-angle -no-dbus -no-gif -no-gtk -no-ico -no-icu -no-libjpeg -no-libudev -no-sql-sqlite -no-sql-odbc -no-sqlite -no-vulkan -skip qt3d -skip qtactiveqt -skip qtandroidextras -skip qtcharts -skip qtconnectivity -skip qtdatavis3d -skip qtdeclarative -skip doc -skip qtdoc -skip qtgamepad -skip qtgraphicaleffects -skip qtimageformats -skip qtlocation -skip qtlottie -skip qtmacextras -skip qtmultimedia -skip qtnetworkauth -skip qtpurchasing -skip qtquick3d -skip qtquickcontrols -skip qtquickcontrols2 -skip qtquicktimeline -skip qtremoteobjects -skip qtscript -skip qtscxml -skip qtsensors -skip qtserialbus -skip qtserialport -skip qtspeech -skip qtsvg -skip qtvirtualkeyboard -skip qtwayland -skip qtwebchannel -skip qtwebengine -skip qtwebglplugin -skip qtwebsockets -skip qtwebview -skip qtx11extras -skip qtxmlpatterns -no-openssl -no-feature-bearermanagement -no-feature-printdialog -no-feature-printer -no-feature-printpreviewdialog -no-feature-printpreviewwidget -no-feature-sql -no-feature-sqlmodel -no-feature-textbrowser -no-feature-textmarkdownwriter -no-feature-textodfwriter -no-feature-xml'
CI_QT_DIR: 'qt-everywhere-src-5.15.11'
CI_QT_URL: 'https://download.qt.io/official_releases/qt/5.15/5.15.11/single/qt-everywhere-opensource-src-5.15.11.zip'
PYTHONUTF8: 1
TEST_RUNNER_TIMEOUT_FACTOR: 40

steps:
- name: Checkout
uses: actions/checkout@v4

- name: Configure Developer Command Prompt for Microsoft Visual C++
# Using microsoft/setup-msbuild is not enough.
uses: ilammy/msvc-dev-cmd@v1
with:
arch: x64

- name: Check MSBuild and Qt
run: |
msbuild -version | Out-File -FilePath "$env:GITHUB_WORKSPACE\msbuild_version"
Get-Content -Path "$env:GITHUB_WORKSPACE\msbuild_version"
$env:VCToolsVersion | Out-File -FilePath "$env:GITHUB_WORKSPACE\toolset_version"
Get-Content -Path "$env:GITHUB_WORKSPACE\toolset_version"
$env:CI_QT_URL | Out-File -FilePath "$env:GITHUB_WORKSPACE\qt_url"
$env:CI_QT_CONF | Out-File -FilePath "$env:GITHUB_WORKSPACE\qt_conf"
- name: Restore static Qt cache
id: static-qt-cache
uses: actions/cache/restore@v3
with:
path: C:\Qt_static
key: ${{ github.job }}-static-qt-${{ hashFiles('msbuild_version', 'qt_url', 'qt_conf') }}

- name: Build static Qt. Download
if: steps.static-qt-cache.outputs.cache-hit != 'true'
shell: cmd
run: |
curl --location --output C:\qt-src.zip %CI_QT_URL%
choco install --yes --no-progress jom
- name: Build static Qt. Expand source archive
if: steps.static-qt-cache.outputs.cache-hit != 'true'
shell: cmd
run: tar -xf C:\qt-src.zip -C C:\

- name: Build static Qt. Create build directory
if: steps.static-qt-cache.outputs.cache-hit != 'true'
run: |
Rename-Item -Path "C:\$env:CI_QT_DIR" -NewName "C:\qt-src"
New-Item -ItemType Directory -Path "C:\qt-src\build"
- name: Build static Qt. Configure
if: steps.static-qt-cache.outputs.cache-hit != 'true'
working-directory: C:\qt-src\build
shell: cmd
run: ..\configure %CI_QT_CONF% -prefix C:\Qt_static

- name: Build static Qt. Build
if: steps.static-qt-cache.outputs.cache-hit != 'true'
working-directory: C:\qt-src\build
shell: cmd
run: jom

- name: Build static Qt. Install
if: steps.static-qt-cache.outputs.cache-hit != 'true'
working-directory: C:\qt-src\build
shell: cmd
run: jom install

- name: Save static Qt cache
if: steps.static-qt-cache.outputs.cache-hit != 'true'
uses: actions/cache/save@v3
with:
path: C:\Qt_static
key: ${{ github.job }}-static-qt-${{ hashFiles('msbuild_version', 'qt_url', 'qt_conf') }}

- name: Ccache installation cache
id: ccache-installation-cache
uses: actions/cache@v3
with:
path: |
C:\ProgramData\chocolatey\lib\ccache
C:\ProgramData\chocolatey\bin\ccache.exe
C:\ccache\cl.exe
key: ${{ github.job }}-ccache-installation-${{ env.CI_CCACHE_VERSION }}

- name: Install Ccache
if: steps.ccache-installation-cache.outputs.cache-hit != 'true'
run: |
choco install --yes --no-progress ccache --version=$env:CI_CCACHE_VERSION
New-Item -ItemType Directory -Path "C:\ccache"
Copy-Item -Path "$env:ChocolateyInstall\lib\ccache\tools\ccache-$env:CI_CCACHE_VERSION-windows-x86_64\ccache.exe" -Destination "C:\ccache\cl.exe"
- name: Restore Ccache cache
id: ccache-cache
uses: actions/cache/restore@v3
with:
path: ~/AppData/Local/ccache
key: ${{ github.job }}-ccache-${{ github.run_id }}
restore-keys: ${{ github.job }}-ccache-

- name: Using vcpkg with MSBuild
run: |
Set-Location "$env:VCPKG_INSTALLATION_ROOT"
Add-Content -Path "triplets\x64-windows-static.cmake" -Value "set(VCPKG_BUILD_TYPE release)"
Add-Content -Path "triplets\x64-windows-static.cmake" -Value "set(VCPKG_PLATFORM_TOOLSET_VERSION $env:VCToolsVersion)"
.\vcpkg.exe --vcpkg-root "$env:VCPKG_INSTALLATION_ROOT" integrate install
git rev-parse HEAD | Out-File -FilePath "$env:GITHUB_WORKSPACE\vcpkg_commit"
Get-Content -Path "$env:GITHUB_WORKSPACE\vcpkg_commit"
- name: vcpkg tools cache
uses: actions/cache@v3
with:
path: C:/vcpkg/downloads/tools
key: ${{ github.job }}-vcpkg-tools

- name: vcpkg binary cache
uses: actions/cache@v3
with:
path: ~/AppData/Local/vcpkg/archives
key: ${{ github.job }}-vcpkg-binary-${{ hashFiles('vcpkg_commit', 'msbuild_version', 'toolset_version', 'build_msvc/vcpkg.json') }}

- name: Generate project files
run: py -3 build_msvc\msvc-autogen.py

- name: Build
shell: cmd
run: |
ccache --zero-stats
msbuild build_msvc\bitcoin.sln -property:CLToolPath=C:\ccache;CLToolExe=cl.exe;UseMultiToolTask=true;Configuration=Release -maxCpuCount -verbosity:minimal -noLogo
- name: Ccache stats
run: ccache --show-stats

- name: Save Ccache cache
uses: actions/cache/save@v3
if: github.event_name != 'pull_request' && steps.ccache-cache.outputs.cache-hit != 'true'
with:
path: ~/AppData/Local/ccache
# https://github.com/actions/cache/blob/main/tips-and-workarounds.md#update-a-cache
key: ${{ github.job }}-ccache-${{ github.run_id }}

- name: Run unit tests
run: src\test_bitcoin.exe -l test_suite

- name: Run benchmarks
run: src\bench_bitcoin.exe -sanity-check

- name: Run util tests
run: py -3 test\util\test_runner.py

- name: Run rpcauth test
run: py -3 test\util\rpcauth-test.py

- name: Run functional tests
# Don't run functional tests for pull requests.
# The test suit regularly fails to complete in windows native github
# actions as a child process stops making progress. The root cause has
# not yet been determined.
# Discussed in https://github.com/bitcoin/bitcoin/pull/28509
if: github.event_name != 'pull_request'
run: py -3 test\functional\test_runner.py --jobs $env:NUMBER_OF_PROCESSORS --ci --quiet --tmpdirprefix=$env:RUNNER_TEMP --combinedlogslen=99999999 --timeout-factor=$env:TEST_RUNNER_TIMEOUT_FACTOR --extended
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ src/qt/bitcoin-qt.includes

*.log
*.trs
*.dmg
*.zip

*.json.h
*.raw.h
Expand Down
2 changes: 1 addition & 1 deletion .python-version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
3.8.16
3.9.18
2 changes: 1 addition & 1 deletion .style.yapf
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,7 @@ each_dict_entry_on_separate_line=True
i18n_comment=

# The i18n function call names. The presence of this function stops
# reformattting on that line, because the string it has cannot be moved
# reformatting on that line, because the string it has cannot be moved
# away from the i18n comment.
i18n_function_call=

Expand Down
2 changes: 1 addition & 1 deletion .tx/config
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
[main]
host = https://www.transifex.com

[o:bitcoin:p:bitcoin:r:qt-translation-025x]
[o:bitcoin:p:bitcoin:r:qt-translation-026x]
file_filter = src/qt/locale/bitcoin_<lang>.xlf
source_file = src/qt/locale/bitcoin_en.xlf
source_lang = en
15 changes: 4 additions & 11 deletions Makefile.am
Original file line number Diff line number Diff line change
Expand Up @@ -14,23 +14,18 @@ endif
.PHONY: deploy FORCE
.INTERMEDIATE: $(COVERAGE_INFO)

export PYTHONPATH

if BUILD_BITCOIN_LIBS
pkgconfigdir = $(libdir)/pkgconfig
pkgconfig_DATA = libbitcoinconsensus.pc
endif

BITCOIND_BIN=$(top_builddir)/src/$(BITCOIN_DAEMON_NAME)$(EXEEXT)
BITCOIN_QT_BIN=$(top_builddir)/src/qt/$(BITCOIN_GUI_NAME)$(EXEEXT)
BITCOIN_TEST_BIN=$(top_builddir)/src/test/$(BITCOIN_TEST_NAME)$(EXEEXT)
BITCOIN_CLI_BIN=$(top_builddir)/src/$(BITCOIN_CLI_NAME)$(EXEEXT)
BITCOIN_TX_BIN=$(top_builddir)/src/$(BITCOIN_TX_NAME)$(EXEEXT)
BITCOIN_UTIL_BIN=$(top_builddir)/src/$(BITCOIN_UTIL_NAME)$(EXEEXT)
BITCOIN_WALLET_BIN=$(top_builddir)/src/$(BITCOIN_WALLET_TOOL_NAME)$(EXEEXT)
BITCOIN_NODE_BIN=$(top_builddir)/src/$(BITCOIN_MP_NODE_NAME)$(EXEEXT)
BITCOIN_GUI_BIN=$(top_builddir)/src/$(BITCOIN_MP_GUI_NAME)$(EXEEXT)
BITCOIN_WIN_INSTALLER=$(PACKAGE)-$(PACKAGE_VERSION)-win64-setup$(EXEEXT)

empty :=
space := $(empty) $(empty)
Expand Down Expand Up @@ -99,7 +94,7 @@ $(COV_TOOL_WRAPPER):
@chmod +x $(COV_TOOL_WRAPPER)

baseline.info: $(COV_TOOL_WRAPPER)
$(LCOV) -c -i -d $(abs_builddir)/src -o $@
$(LCOV) $(LCOV_OPTS) -c -i -d $(abs_builddir)/src -o $@

baseline_filtered.info: baseline.info
$(abs_builddir)/contrib/filter-lcov.py $(LCOV_FILTER_PATTERN) $< $@
Expand Down Expand Up @@ -133,13 +128,13 @@ functional_test_filtered.info: functional_test.info
$(LCOV) -a $@ $(LCOV_OPTS) -o $@

fuzz_coverage.info: fuzz_filtered.info
$(LCOV) -a $(LCOV_OPTS) baseline_filtered.info -a fuzz_filtered.info -o $@ | $(GREP) "\%" | $(AWK) '{ print substr($$3,2,50) "/" $$5 }' > coverage_percent.txt
$(LCOV) $(LCOV_OPTS) -a baseline_filtered.info -a fuzz_filtered.info -o $@ | $(GREP) "\%" | $(AWK) '{ print substr($$3,2,50) "/" $$5 }' > coverage_percent.txt

test_bitcoin_coverage.info: baseline_filtered.info test_bitcoin_filtered.info
$(LCOV) -a $(LCOV_OPTS) baseline_filtered.info -a test_bitcoin_filtered.info -o $@
$(LCOV) $(LCOV_OPTS) -a baseline_filtered.info -a test_bitcoin_filtered.info -o $@

total_coverage.info: test_bitcoin_filtered.info functional_test_filtered.info
$(LCOV) -a $(LCOV_OPTS) baseline_filtered.info -a test_bitcoin_filtered.info -a functional_test_filtered.info -o $@ | $(GREP) "\%" | $(AWK) '{ print substr($$3,2,50) "/" $$5 }' > coverage_percent.txt
$(LCOV) $(LCOV_OPTS) -a baseline_filtered.info -a test_bitcoin_filtered.info -a functional_test_filtered.info -o $@ | $(GREP) "\%" | $(AWK) '{ print substr($$3,2,50) "/" $$5 }' > coverage_percent.txt

fuzz.coverage/.dirstamp: fuzz_coverage.info
$(GENHTML) -s $(LCOV_OPTS) $< -o $(@D)
Expand Down Expand Up @@ -224,8 +219,6 @@ EXTRA_DIST += \
test/util/data/txcreatesignv2.hex \
test/util/rpcauth-test.py

CLEANFILES = $(OSX_DMG) $(BITCOIN_WIN_INSTALLER)

DISTCHECK_CONFIGURE_FLAGS = --enable-man

doc/doxygen/.stamp: doc/Doxyfile FORCE
Expand Down
Loading

0 comments on commit 96d08c5

Please sign in to comment.