1
0
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:
matejcik 2018-08-28 18:26:13 +02:00
parent 31b8e872ba
commit 9f51d58f30

View File

@ -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: