Skip to content

Release 1.0.0-alpha.1 #1025

@notmandatory

Description

@notmandatory

Create a new alpha release

Summary

The BDK 1.0.0-alpha release should be used for experimentation only, APIs are still unstable and the code is not fully tested. This alpha.1 release introduces the new ChainOracle struct for more efficient chain syncing. A new std default feature was added for bdk, bdk_chain and bdk_esplora crates; when disabled these crates can be used in no-std projects. BDK 1.0.0-alpha.x docs are now published to docs.rs.

Commit

f4d2a76

Changelog

Fixed

Changed

Added

Checklist

Release numbering must follow Semantic Versioning. These steps assume the current master
branch development version is MAJOR.MINOR.0.

Before publishing the release

Change the master branch to the next MINOR+1 version:

  • Switch to the master branch.
  • Create a new PR branch called bump_dev_1.0.0-alpha.1.
  • Bump the crates versions and README files
    • bdk to 1.0.0-alpha.1.
    • bdk_chain to 0.5.0
    • bdk_electrum to 0.3.0
    • bdk_esplora to 0.3.0
    • bdk_file_store to 0.2.0
  • Bump the example-crates versions and README files
    • example_cli to 0.2.0
    • example_electrum to 0.2.0
    • wallet_electrum_example to 0.2.0
    • wallet_esplora to 0.2.0
    • wallet_esplora_async to 0.2.0
  • Commit the changes with message "Bump version to 1.0.0-alpha.1".
  • Create PR and merge the bump_dev_1.0.0-alpha.1 branch to master.
    • Title PR "Bump version to 1.0.0-alpha.1".

On the day of the release

Tag and publish new release:

  • Add a tag to the HEAD commit in the master branch.
    • The tag name should be v1.0.0-alpha.1
    • The first line of the tag message should be "Release 1.0.0-alpha.1".
    • In the body of the tag message put a copy of the Summary and Changelog for the release.
    • Make sure the tag is signed, for extra safety use the explicit --sign flag.
  • Wait for the CI to finish one last time.
  • Push the new tag to the bitcoindevkit/bdk repo.
  • Publish all the updated crates to crates.io.
  • Create the release on GitHub.
    • Go to "tags", click on the dots on the right and select "Create Release".
    • Set the title to Release 1.0.0-alpha.1.
    • In the release notes body put the Summary and Changelog.
    • Use the "+ Auto-generate release notes" button to add details from included PRs.
    • Until we reach a 1.0.0 release check the "Pre-release" box.
  • Make sure the new release shows up on crates.io and that the docs are built correctly on docs.rs.
  • Announce the release, using the Summary, on Discord, Twitter and Nostr.
  • Celebrate 🎉

Metadata

Metadata

Assignees

Labels

releaseRelease related issue or PR

Type

No type

Projects

Status

Done

Milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions