mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-10 15:30:55 +00:00
tools: finish release flow
This commit is contained in:
parent
31b8e872ba
commit
9f51d58f30
@ -285,11 +285,12 @@ def check(ignore_tokens, ignore_missing):
|
|||||||
@click.argument("device")
|
@click.argument("device")
|
||||||
@click.option("-r", "--version", help="Set explicit version string (default: guess from latest release)")
|
@click.option("-r", "--version", help="Set explicit version string (default: guess from latest release)")
|
||||||
@click.option("--git-tag/--no-git-tag", "-g", default=False, help="Create a corresponding Git tag")
|
@click.option("--git-tag/--no-git-tag", "-g", default=False, help="Create a corresponding Git tag")
|
||||||
@click.option("--release-soon/--no-release-soon", default=True, help="Release coins marked 'soon'")
|
|
||||||
@click.option("--release-missing/--no-release-missing", default=True, help="Release coins with missing support info")
|
@click.option("--release-missing/--no-release-missing", default=True, help="Release coins with missing support info")
|
||||||
@click.option("-n", "--dry-run", is_flag=True, help="Do not write changes")
|
@click.option("-n", "--dry-run", is_flag=True, help="Do not write changes")
|
||||||
@click.option("-s", "--soon", is_flag=True, help="Only set missing support-infos to be released 'soon'")
|
@click.option("-s", "--soon", is_flag=True, help="Only set missing support-infos to be released 'soon'")
|
||||||
@click.option("-f", "--force", is_flag=True, help="Proceed even with bad version/device info")
|
@click.option("-f", "--force", is_flag=True, help="Proceed even with bad version/device info")
|
||||||
|
@click.option("-y", "--add-all", is_flag=True, help="Do not ask for confirmation, add all selected coins")
|
||||||
|
@click.option("-v", "--verbose", is_flag=True, help="Be more verbose")
|
||||||
# fmt: on
|
# fmt: on
|
||||||
@click.pass_context
|
@click.pass_context
|
||||||
def release(
|
def release(
|
||||||
@ -297,11 +298,12 @@ def release(
|
|||||||
device: str,
|
device: str,
|
||||||
version,
|
version,
|
||||||
git_tag,
|
git_tag,
|
||||||
release_soon,
|
|
||||||
release_missing,
|
release_missing,
|
||||||
dry_run,
|
dry_run,
|
||||||
soon,
|
soon,
|
||||||
force,
|
force,
|
||||||
|
add_all,
|
||||||
|
verbose,
|
||||||
):
|
):
|
||||||
"""Release a new Trezor firmware.
|
"""Release a new Trezor firmware.
|
||||||
|
|
||||||
@ -315,6 +317,9 @@ def release(
|
|||||||
`device` can be "1", "2", or a string matching `support.json` key. Version
|
`device` can be "1", "2", or a string matching `support.json` key. Version
|
||||||
is autodetected by downloading a list of latest releases and incrementing
|
is autodetected by downloading a list of latest releases and incrementing
|
||||||
micro version by one, or you can specify `--version` explicitly.
|
micro version by one, or you can specify `--version` explicitly.
|
||||||
|
|
||||||
|
Unless `--add-all` is specified, the tool will ask you to confirm each added
|
||||||
|
coin. ERC20 tokens are added automatically. Use `--verbose` to see them.
|
||||||
"""
|
"""
|
||||||
# check condition(s)
|
# check condition(s)
|
||||||
if soon and git_tag:
|
if soon and git_tag:
|
||||||
@ -375,19 +380,18 @@ def release(
|
|||||||
print("Fixing up data...")
|
print("Fixing up data...")
|
||||||
ctx.invoke(fix, dry_run=True)
|
ctx.invoke(fix, dry_run=True)
|
||||||
|
|
||||||
# process missing (not listed) supportinfos
|
def maybe_add(coin, label):
|
||||||
if release_missing:
|
add = False
|
||||||
missing_list = find_unsupported_coins(coins_dict)[device]
|
if add_all:
|
||||||
for coin in missing_list:
|
add = True
|
||||||
key = coin["key"]
|
else:
|
||||||
# we should have no unprocessed dup tokens at this point
|
text = f"Add {label} coin {coin['key']} ({coin['name']})?"
|
||||||
assert not (coin.get("duplicate") and coin_info.is_token(coin))
|
add = click.confirm(text, default=True)
|
||||||
print(f"Adding missing {key} ({coin['name']})")
|
if add:
|
||||||
set_supported(device, key, version)
|
set_supported(device, coin["key"], version)
|
||||||
|
|
||||||
# if we're releasing, process coins marked "soon"
|
# if we're releasing, process coins marked "soon"
|
||||||
# (`not soon` because `soon` means set release version to "soon")
|
if not soon:
|
||||||
if not soon and release_soon:
|
|
||||||
supported, _ = support_dicts(device)
|
supported, _ = support_dicts(device)
|
||||||
soon_list = [
|
soon_list = [
|
||||||
coins_dict[key]
|
coins_dict[key]
|
||||||
@ -396,9 +400,24 @@ def release(
|
|||||||
]
|
]
|
||||||
for coin in soon_list:
|
for coin in soon_list:
|
||||||
key = coin["key"]
|
key = coin["key"]
|
||||||
print(f"Adding soon-released {key} ({coin['name']})")
|
print(f"Releasing {key} ({coin['name']}) marked 'soon'")
|
||||||
set_supported(device, key, version)
|
set_supported(device, key, version)
|
||||||
|
|
||||||
|
# process missing (not listed) supportinfos
|
||||||
|
if release_missing:
|
||||||
|
missing_list = find_unsupported_coins(coins_dict)[device]
|
||||||
|
tokens = [coin for coin in missing_list if coin_info.is_token(coin)]
|
||||||
|
nontokens = [coin for coin in missing_list if not coin_info.is_token(coin)]
|
||||||
|
for coin in tokens:
|
||||||
|
key = coin["key"]
|
||||||
|
assert not coin.get("duplicate")
|
||||||
|
if verbose:
|
||||||
|
print(f"Adding missing {key} ({coin['name']})")
|
||||||
|
set_supported(device, key, version)
|
||||||
|
|
||||||
|
for coin in nontokens:
|
||||||
|
maybe_add(coin, "missing")
|
||||||
|
|
||||||
tagname = f"{device}-{version}"
|
tagname = f"{device}-{version}"
|
||||||
if git_tag:
|
if git_tag:
|
||||||
if dry_run:
|
if dry_run:
|
||||||
|
Loading…
Reference in New Issue
Block a user