def sync(product, version, logger=LOGGER, config=CONFIG): """takes currently saved json data of given release from data repo, generates wiki, and commits product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True, must_exist_in="inflight") data = load_json(data_path) commit_msg = "{} {} - syncing wiki with current data".format(product, version) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def track(product, version, gtb_date, logger=LOGGER, config=CONFIG): """Start tracking an upcoming release. product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=False) data = {} commit_msg = "{} {} started tracking upcoming release.".format(product, version) gtb_date = sanitize_date_input(gtb_date, logger) data = get_tracking_release_data(release, gtb_date, logger, config) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def cancel(product, version, logger=LOGGER, config=CONFIG): """Similar to newbuild where it aborts current buildnum of given release but does not create a new build. """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True, must_exist_in="inflight") data = load_json(data_path) logger.info("Most recent buildnum has been aborted. Release cancelled.") commit_msg = "{} {} - cancelling release".format(product, version) current_build_index = get_current_build_index(data) data["inflight"][current_build_index]["aborted"] = True write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def prereq(product, version, resolve, logger=LOGGER, config=CONFIG): """Add or resolve a prerequisite (pre gtb) product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr Without any options, you will be prompted to add a prerequisite human task """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True, must_exist_in="upcoming") data = load_json(data_path) resolve_msg = "Resolved {}".format(resolve) if resolve else "" commit_msg = "{} {} - updated prerequisites. {}".format(product, version, resolve_msg) data = update_prereq_human_tasks(data, resolve) data = order_data(data) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def issue(product, version, resolve, logger=LOGGER, config=CONFIG): """Add or resolve an issue against current buildnum product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr Without any options, you will be prompted to add an issue """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True, must_exist_in="inflight") data = load_json(data_path) resolve_msg = "Resolved {}".format(resolve) if resolve else "" commit_msg = "{} {} - updated inflight issue. {}".format(product, version, resolve_msg) data = update_inflight_issue(data, resolve, logger) data = order_data(data) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def graphid(graphid, product, version, phase, logger=LOGGER, config=CONFIG): """Add a graphid to a release. product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr The phase must match the product. """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True, must_exist_in="inflight") data = load_json(data_path) validate_phase(product, version, phase, logger, config) commit_msg = "{} {} - added {} graphid.".format(product, version, phase) data = update_inflight_graphid(data, phase, graphid, logger) data = order_data(data) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def newbuild(product, version, logger=LOGGER, config=CONFIG): """Mark a release as submitted to shipit product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr If this is the first buildnum, move the release from upcoming dir to inflight Otherwise, increment the buildnum of the already current inflight release """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True) data = load_json(data_path) commit_msg = "{} {} - new buildnum started.".format(product, version) data, data_path, wiki_path = generate_newbuild_data(data, release, data_path, wiki_path, logger, config) data = order_data(data) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def task(product, version, resolve, logger=LOGGER, config=CONFIG): """Add or resolve a human task within current buildnum product and version is also used to determine branch. e.g 57.0rc, 57.0.1, 57.0b2, 52.0.1esr Without any options, you will be prompted to add a task """ validate_rw_repo(logger, config) release, data_path, wiki_path = get_release_info(product, version, logger, config) # if we are adding a human_task, the release does not have to be inflight yet must_exist_in = "inflight" if resolve else None validate(release, logger, config, must_exist=True, must_exist_in=must_exist_in) data = load_json(data_path) resolve_msg = "Resolved {}".format(resolve) if resolve else "" commit_msg = "{} {} - updated inflight tasks. {}".format(product, version, resolve_msg) data = update_inflight_human_tasks(data, resolve, logger) data = order_data(data) write_and_commit(data, data_path, wiki_path, commit_msg, logger, config)
def wnp_blob(wnp_url, product, version, blob_name, for_channels, for_locales, for_version, output_file, logger=LOGGER, config=CONFIG): """Generate local Balrog blob with WNP rule.""" if not blob_name: validate_rw_repo(logger, config) release, data_path, _ = get_release_info(product, version, logger, config) validate(release, logger, config, must_exist=True, must_exist_in="inflight") data = load_json(data_path) current_build_index = get_current_build_index(data) build_number = current_build_index + 1 blob_name = '{}-{}-build{}'.format(product, version, build_number) try: ensure_blob_name_exists_on_balrog(blob_name) except TooManyBlobsFoundError as e: logger.critical( '{}. Which one do you want? (specify with --blob-name)'.format( e)) sys.exit(1) else: try: ensure_blob_name_exists_on_balrog(blob_name) except TooManyBlobsFoundError: # If blob_name was fully specified, then we use this one. Other blobs matching it are # suffixed by something else (e.g: Firefox-62.0-build1 vs Firefox-62.0-build1-No-WNP) pass orig_blob = get_release_blob(blob_name) new_blob = craft_wnp_blob(orig_blob, wnp_url, for_channels, for_locales, for_version) json.dump(new_blob, output_file, sort_keys=True, indent=4) logger.info('New blob written at: {}'.format(output_file.name))