LUCENE-8852 ReleaseWizard tool (#710)

(cherry picked from commit 87c131baa7)
This commit is contained in:
Jan Høydahl 2019-06-20 14:45:17 +02:00
parent 741207da14
commit 0d7a652974
11 changed files with 3987 additions and 2 deletions

3
.gitignore vendored
View File

@ -26,4 +26,5 @@ pom.xml
/nbproject
/nb-build
.pydevproject
__pycache__
__pycache__
/dev-tools/scripts/scripts.iml

View File

@ -0,0 +1,9 @@
<?xml version="1.0" encoding="UTF-8"?>
<module type="PYTHON_MODULE" version="4">
<component name="NewModuleRootManager" inherit-compiler-output="true">
<exclude-output />
<content url="file://$MODULE_DIR$" />
<orderEntry type="jdk" jdkName="Python 3.7" jdkType="Python SDK" />
<orderEntry type="sourceFolder" forTests="false" />
</component>
</module>

211
dev-tools/scripts/README.md Normal file
View File

@ -0,0 +1,211 @@
# Developer Scripts
This folder contains various useful scripts for developers, mostly related to
releasing new versions of Lucene/Solr and testing those.
Python scripts require Python 3. To install necessary python modules, please run:
pip3 install -r requirements.txt
## Scripts description
### smokeTestRelease.py
Used to validate new release candidates (RC). The script downloads an RC from a URL
or local folder, then runs a number of sanity checks on the artifacts, and then runs
the full tests.
usage: smokeTestRelease.py [-h] [--tmp-dir PATH] [--not-signed]
[--local-keys PATH] [--revision REVISION]
[--version X.Y.Z(-ALPHA|-BETA)?]
[--test-java12 JAVA12_HOME] [--download-only]
url ...
Utility to test a release.
positional arguments:
url Url pointing to release to test
test_args Arguments to pass to ant for testing, e.g.
-Dwhat=ever.
optional arguments:
-h, --help show this help message and exit
--tmp-dir PATH Temporary directory to test inside, defaults to
/tmp/smoke_lucene_$version_$revision
--not-signed Indicates the release is not signed
--local-keys PATH Uses local KEYS file instead of fetching from
https://archive.apache.org/dist/lucene/KEYS
--revision REVISION GIT revision number that release was built with,
defaults to that in URL
--version X.Y.Z(-ALPHA|-BETA)?
Version of the release, defaults to that in URL
--test-java12 JAVA12_HOME
Path to Java12 home directory, to run tests with if
specified
--download-only Only perform download and sha hash check steps
Example usage:
python3 -u dev-tools/scripts/smokeTestRelease.py https://dist.apache.org/repos/dist/dev/lucene/lucene-solr-6.0.1-RC2-revc7510a0...
### releaseWizard.py
The Release Wizard guides the Release Manager through the release process step
by step, helping you to to run the right commands in the right order, generating
e-mail templates with the correct texts, versions, paths etc, obeying
the voting rules and much more. It also serves as a documentation of all the
steps, with timestamps, preserving log files from each command etc, showing only
the steps and commands required for a major/minor/bugfix release. It also lets
you generate a full Asciidoc guide for the release. The wizard will execute many
of the other tools in this folder.
usage: releaseWizard.py [-h] [--dry-run] [--init]
Script to guide a RM through the whole release process
optional arguments:
-h, --help show this help message and exit
--dry-run Do not execute any commands, but echo them instead. Display
extra debug info
--init Re-initialize root and version
Go push that release!
### buildAndPushRelease.py
usage: buildAndPushRelease.py [-h] [--no-prepare] [--local-keys PATH]
[--push-local PATH] [--sign KEYID]
[--rc-num NUM] [--root PATH] [--logfile PATH]
Utility to build, push, and test a release.
optional arguments:
-h, --help show this help message and exit
--no-prepare Use the already built release in the provided checkout
--local-keys PATH Uses local KEYS file to validate presence of RM's gpg key
--push-local PATH Push the release to the local path
--sign KEYID Sign the release with the given gpg key
--rc-num NUM Release Candidate number. Default: 1
--root PATH Root of Git working tree for lucene-solr. Default: "."
(the current directory)
--logfile PATH Specify log file path (default /tmp/release.log)
Example usage for a Release Manager:
python3 -u dev-tools/scripts/buildAndPushRelease.py --push-local /tmp/releases/6.0.1 --sign 6E68DA61 --rc-num 1
### addBackcompatIndexes.py
usage: addBackcompatIndexes.py [-h] [--force] [--no-cleanup] [--temp-dir DIR]
version
Add backcompat index and test for new version. See:
http://wiki.apache.org/lucene-java/ReleaseTodo#Generate_Backcompat_Indexes
positional arguments:
version Version to add, of the form X.Y.Z
optional arguments:
-h, --help show this help message and exit
--force Redownload the version and rebuild, even if it already
exists
--no-cleanup Do not cleanup the built indexes, so that they can be reused
for adding to another branch
--temp-dir DIR Temp directory to build backcompat indexes within
### addVersion.py
usage: addVersion.py [-h] version
Add a new version to CHANGES, to Version.java, lucene/version.properties and
solrconfig.xml files
positional arguments:
version
optional arguments:
-h, --help show this help message and exit
### releasedJirasRegex.py
Pulls out all JIRAs mentioned at the beginning of bullet items
under the given version in the given CHANGES.txt file
and prints a regular expression that will match all of them
usage: releasedJirasRegex.py [-h] version changes
Prints a regex matching JIRAs fixed in the given version by parsing the given
CHANGES.txt file
positional arguments:
version Version of the form X.Y.Z
changes CHANGES.txt file to parse
optional arguments:
-h, --help show this help message and exit
### reproduceJenkinsFailures.py
usage: reproduceJenkinsFailures.py [-h] [--no-git] [--iters N] URL
Must be run from a Lucene/Solr git workspace. Downloads the Jenkins
log pointed to by the given URL, parses it for Git revision and failed
Lucene/Solr tests, checks out the Git revision in the local workspace,
groups the failed tests by module, then runs
'ant test -Dtest.dups=%d -Dtests.class="*.test1[|*.test2[...]]" ...'
in each module of interest, failing at the end if any of the runs fails.
To control the maximum number of concurrent JVMs used for each module's
test run, set 'tests.jvms', e.g. in ~/lucene.build.properties
positional arguments:
URL Points to the Jenkins log to parse
optional arguments:
-h, --help show this help message and exit
--no-git Do not run "git" at all
--iters N Number of iterations per test suite (default: 5)
### poll-mirrors.py
usage: poll-mirrors.py [-h] [-version VERSION] [-path PATH]
[-interval INTERVAL] [-details] [-once]
Periodically checks that all Lucene/Solr mirrors contain either a copy of a
release or a specified path
optional arguments:
-h, --help show this help message and exit
-version VERSION, -v VERSION
Lucene/Solr version to check
-path PATH, -p PATH instead of a versioned release, check for
some/explicit/path
-interval INTERVAL, -i INTERVAL
seconds to wait before re-querying mirrors
-details, -d print missing mirror URLs
-once, -o run only once
### githubPRs.py
usage: githubPRs.py [-h] [--json] [--token TOKEN]
Find open Pull Requests that need attention
optional arguments:
-h, --help show this help message and exit
--json Output as json
--token TOKEN Github access token in case you query too often anonymously
### gitignore-gen.sh
TBD
### publish-solr-ref-guide.sh
TBD
### prep-solr-ref-guide-rc.sh
TBD
## Tools to be removed
* svnBranchToGit.py
* createPatch.py (svn)

2
dev-tools/scripts/addBackcompatIndexes.py Normal file → Executable file
View File

@ -1,3 +1,5 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.

6
dev-tools/scripts/addVersion.py Normal file → Executable file
View File

@ -1,3 +1,5 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
@ -174,7 +176,7 @@ def check_solr_version_tests():
print('ok')
def read_config(current_version):
parser = argparse.ArgumentParser(description='Add a new version')
parser = argparse.ArgumentParser(description='Add a new version to CHANGES, to Version.java, lucene/version.properties and solrconfig.xml files')
parser.add_argument('version', type=Version.parse)
newconf = parser.parse_args()
@ -209,6 +211,8 @@ def get_solr_init_changes():
''' % parse_properties_file('lucene/ivy-versions.properties'))
def main():
if not os.path.exists('lucene/version.properties'):
sys.exit("Tool must be run from the root of a source checkout.")
current_version = Version.parse(find_current_version())
newconf = read_config(current_version)

2
dev-tools/scripts/buildAndPushRelease.py Normal file → Executable file
View File

@ -1,3 +1,5 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.

2011
dev-tools/scripts/releaseWizard.py Executable file

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

2
dev-tools/scripts/releasedJirasRegex.py Normal file → Executable file
View File

@ -1,3 +1,5 @@
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.

View File

@ -1,2 +1,8 @@
six>=1.11.0
Jinja2>=2.10.1
PyYAML>=5.1
holidays>=0.9.10
ics>=0.4
console-menu>=0.5.1
PyGithub
jira

View File

@ -106,6 +106,8 @@ Other
* LUCENE-8861: Script to find open Github PRs that needs attention (janhoy)
* LUCENE-8852: ReleaseWizard tool for release managers (janhoy)
======================= Lucene 8.1.1 =======================
(No Changes)