2019-06-20 08:45:17 -04:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# -*- coding: utf-8 -*-
|
2014-09-24 16:48:57 -04:00
|
|
|
# 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.
|
|
|
|
# The ASF licenses this file to You under the Apache License, Version 2.0
|
|
|
|
# (the "License"); you may not use this file except in compliance with
|
|
|
|
# the License. You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
2015-04-15 17:36:00 -04:00
|
|
|
|
|
|
|
# For usage information, see:
|
|
|
|
#
|
|
|
|
# http://wiki.apache.org/lucene-java/ReleaseTodo#Generate_Backcompat_Indexes
|
|
|
|
|
|
|
|
|
2014-09-24 16:48:57 -04:00
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
sys.path.append(os.path.dirname(__file__))
|
|
|
|
import scriptutil
|
|
|
|
|
|
|
|
import argparse
|
|
|
|
import urllib.error
|
|
|
|
import urllib.request
|
|
|
|
import re
|
|
|
|
import shutil
|
|
|
|
|
2016-06-25 14:26:42 -04:00
|
|
|
def create_and_add_index(source, indextype, index_version, current_version, temp_dir):
|
2017-09-30 20:44:01 -04:00
|
|
|
if not current_version.is_back_compat_with(index_version):
|
|
|
|
prefix = 'unsupported'
|
|
|
|
else:
|
|
|
|
prefix = {
|
|
|
|
'cfs': 'index',
|
|
|
|
'nocfs': 'index',
|
|
|
|
'sorted': 'sorted',
|
2024-10-15 07:39:47 -04:00
|
|
|
'int7_hnsw': 'int7_hnsw',
|
2017-09-30 20:44:01 -04:00
|
|
|
'moreterms': 'moreterms',
|
|
|
|
'dvupdates': 'dvupdates',
|
|
|
|
'emptyIndex': 'empty'
|
|
|
|
}[indextype]
|
2014-09-24 16:48:57 -04:00
|
|
|
if indextype in ('cfs', 'nocfs'):
|
2017-09-30 20:44:01 -04:00
|
|
|
filename = '%s.%s-%s.zip' % (prefix, index_version, indextype)
|
2014-09-24 16:48:57 -04:00
|
|
|
else:
|
2017-09-30 20:44:01 -04:00
|
|
|
filename = '%s.%s.zip' % (prefix, index_version)
|
|
|
|
|
2014-09-24 16:48:57 -04:00
|
|
|
print(' creating %s...' % filename, end='', flush=True)
|
2015-02-23 01:50:47 -05:00
|
|
|
module = 'backward-codecs'
|
2021-02-17 02:29:05 -05:00
|
|
|
index_dir = os.path.join('lucene', module, 'src/test/org/apache/lucene/backward_index')
|
2014-09-24 16:48:57 -04:00
|
|
|
if os.path.exists(os.path.join(index_dir, filename)):
|
|
|
|
print('uptodate')
|
|
|
|
return
|
|
|
|
|
|
|
|
test = {
|
|
|
|
'cfs': 'testCreateCFS',
|
2017-09-30 20:44:01 -04:00
|
|
|
'nocfs': 'testCreateNoCFS',
|
|
|
|
'sorted': 'testCreateSortedIndex',
|
2024-10-15 07:39:47 -04:00
|
|
|
'int7_hnsw': 'testCreateInt7HNSWIndices',
|
2017-09-30 20:44:01 -04:00
|
|
|
'moreterms': 'testCreateMoreTermsIndex',
|
|
|
|
'dvupdates': 'testCreateIndexWithDocValuesUpdates',
|
|
|
|
'emptyIndex': 'testCreateEmptyIndex'
|
2014-09-24 16:48:57 -04:00
|
|
|
}[indextype]
|
2022-01-12 12:55:59 -05:00
|
|
|
gradle_args = ' '.join([
|
|
|
|
'-Ptests.useSecurityManager=false',
|
|
|
|
'-p lucene/%s' % module,
|
|
|
|
'test',
|
2024-01-31 09:27:56 -05:00
|
|
|
'--tests TestGenerateBwcIndices.%s' % test,
|
2014-09-24 16:48:57 -04:00
|
|
|
'-Dtests.bwcdir=%s' % temp_dir,
|
2022-01-12 12:55:59 -05:00
|
|
|
'-Dtests.codec=default'
|
2014-09-24 16:48:57 -04:00
|
|
|
])
|
|
|
|
base_dir = os.getcwd()
|
2024-02-20 16:10:01 -05:00
|
|
|
bc_index_file = os.path.join(temp_dir, filename)
|
2014-09-24 16:48:57 -04:00
|
|
|
|
|
|
|
if os.path.exists(bc_index_file):
|
|
|
|
print('alreadyexists')
|
|
|
|
else:
|
2022-01-12 12:55:59 -05:00
|
|
|
os.chdir(source)
|
|
|
|
scriptutil.run('./gradlew %s' % gradle_args)
|
2024-02-20 16:10:01 -05:00
|
|
|
if not os.path.exists(bc_index_file):
|
|
|
|
raise Exception("Expected file can't be found: %s" %bc_index_file)
|
2014-09-24 16:48:57 -04:00
|
|
|
print('done')
|
|
|
|
|
|
|
|
print(' adding %s...' % filename, end='', flush=True)
|
|
|
|
scriptutil.run('cp %s %s' % (bc_index_file, os.path.join(base_dir, index_dir)))
|
|
|
|
os.chdir(base_dir)
|
|
|
|
print('done')
|
|
|
|
|
2024-02-14 15:43:17 -05:00
|
|
|
def update_backcompat_tests(index_version, current_version):
|
|
|
|
print(' adding new indexes to backcompat tests...', end='', flush=True)
|
2014-09-24 16:48:57 -04:00
|
|
|
module = 'lucene/backward-codecs'
|
2024-02-14 15:43:17 -05:00
|
|
|
|
|
|
|
filename = None
|
2017-09-30 20:44:01 -04:00
|
|
|
if not current_version.is_back_compat_with(index_version):
|
2024-02-14 15:43:17 -05:00
|
|
|
filename = '%s/src/test/org/apache/lucene/backward_index/unsupported_versions.txt' % module
|
2017-09-30 20:44:01 -04:00
|
|
|
else:
|
2024-02-14 15:43:17 -05:00
|
|
|
filename = '%s/src/test/org/apache/lucene/backward_index/versions.txt' % module
|
2017-09-30 20:44:01 -04:00
|
|
|
|
|
|
|
strip_dash_suffix_re = re.compile(r'-.*')
|
2014-09-24 16:48:57 -04:00
|
|
|
|
|
|
|
def find_version(x):
|
|
|
|
x = x.strip()
|
2017-09-30 20:44:01 -04:00
|
|
|
x = re.sub(strip_dash_suffix_re, '', x) # remove the -suffix if any
|
|
|
|
return scriptutil.Version.parse(x)
|
2014-09-24 16:48:57 -04:00
|
|
|
|
2024-02-14 15:43:17 -05:00
|
|
|
def edit(buffer, match, line):
|
|
|
|
v = find_version(line)
|
|
|
|
changed = False
|
|
|
|
if v.on_or_after(index_version):
|
|
|
|
if not index_version.on_or_after(v):
|
|
|
|
buffer.append(('%s\n') % index_version)
|
|
|
|
changed = True
|
|
|
|
buffer.append(line)
|
|
|
|
return changed
|
|
|
|
|
|
|
|
def append(buffer, changed):
|
|
|
|
if changed:
|
|
|
|
return changed
|
|
|
|
if not buffer[len(buffer)-1].endswith('\n'):
|
|
|
|
buffer.append('\n')
|
|
|
|
buffer.append(('%s\n') % index_version)
|
|
|
|
return True
|
2014-09-24 16:48:57 -04:00
|
|
|
|
2024-02-14 15:43:17 -05:00
|
|
|
changed = scriptutil.update_file(filename, re.compile(r'.*'), edit, append)
|
2014-09-24 16:48:57 -04:00
|
|
|
print('done' if changed else 'uptodate')
|
|
|
|
|
|
|
|
def check_backcompat_tests():
|
|
|
|
print(' checking backcompat tests...', end='', flush=True)
|
2024-01-31 09:27:56 -05:00
|
|
|
scriptutil.run('./gradlew -p lucene/backward-codecs test --tests TestGenerateBwcIndices')
|
2014-09-24 16:48:57 -04:00
|
|
|
print('ok')
|
|
|
|
|
2022-01-05 09:54:33 -05:00
|
|
|
def download_from_cdn(version, remotename, localname):
|
|
|
|
url = 'http://dlcdn.apache.org/lucene/java/%s/%s' % (version, remotename)
|
2014-09-24 16:48:57 -04:00
|
|
|
try:
|
|
|
|
urllib.request.urlretrieve(url, localname)
|
|
|
|
return True
|
|
|
|
except urllib.error.URLError as e:
|
|
|
|
if e.code == 404:
|
|
|
|
return False
|
|
|
|
raise e
|
|
|
|
|
|
|
|
def download_from_archives(version, remotename, localname):
|
|
|
|
url = 'http://archive.apache.org/dist/lucene/java/%s/%s' % (version, remotename)
|
|
|
|
try:
|
|
|
|
urllib.request.urlretrieve(url, localname)
|
|
|
|
return True
|
|
|
|
except urllib.error.URLError as e:
|
|
|
|
if e.code == 404:
|
|
|
|
return False
|
|
|
|
raise e
|
|
|
|
|
|
|
|
def download_release(version, temp_dir, force):
|
|
|
|
print(' downloading %s source release...' % version, end='', flush=True)
|
|
|
|
source = os.path.join(temp_dir, 'lucene-%s' % version)
|
|
|
|
if os.path.exists(source):
|
|
|
|
if force:
|
|
|
|
shutil.rmtree(source)
|
|
|
|
else:
|
|
|
|
print('uptodate')
|
|
|
|
return source
|
|
|
|
|
|
|
|
filename = 'lucene-%s-src.tgz' % version
|
|
|
|
source_tgz = os.path.join(temp_dir, filename)
|
2022-01-05 09:54:33 -05:00
|
|
|
if not download_from_cdn(version, filename, source_tgz) and \
|
2014-09-24 16:48:57 -04:00
|
|
|
not download_from_archives(version, filename, source_tgz):
|
2022-01-05 09:54:33 -05:00
|
|
|
raise Exception('Could not find version %s in apache CDN or archives' % version)
|
2014-09-24 16:48:57 -04:00
|
|
|
|
|
|
|
olddir = os.getcwd()
|
|
|
|
os.chdir(temp_dir)
|
|
|
|
scriptutil.run('tar -xvzf %s' % source_tgz)
|
|
|
|
os.chdir(olddir)
|
|
|
|
print('done')
|
|
|
|
return source
|
|
|
|
|
|
|
|
def read_config():
|
2015-04-15 17:36:00 -04:00
|
|
|
parser = argparse.ArgumentParser(formatter_class=argparse.RawDescriptionHelpFormatter,
|
|
|
|
description='''\
|
|
|
|
Add backcompat index and test for new version. See:
|
|
|
|
http://wiki.apache.org/lucene-java/ReleaseTodo#Generate_Backcompat_Indexes
|
|
|
|
''')
|
2014-09-24 16:48:57 -04:00
|
|
|
parser.add_argument('--force', action='store_true', default=False,
|
|
|
|
help='Redownload the version and rebuild, even if it already exists')
|
|
|
|
parser.add_argument('--no-cleanup', dest='cleanup', action='store_false', default=True,
|
|
|
|
help='Do not cleanup the built indexes, so that they can be reused ' +
|
|
|
|
'for adding to another branch')
|
|
|
|
parser.add_argument('--temp-dir', metavar='DIR', default='/tmp/lucenebwc',
|
|
|
|
help='Temp directory to build backcompat indexes within')
|
|
|
|
parser.add_argument('version', type=scriptutil.Version.parse,
|
|
|
|
help='Version to add, of the form X.Y.Z')
|
|
|
|
c = parser.parse_args()
|
|
|
|
|
|
|
|
return c
|
|
|
|
|
|
|
|
def main():
|
|
|
|
c = read_config()
|
|
|
|
if not os.path.exists(c.temp_dir):
|
|
|
|
os.makedirs(c.temp_dir)
|
|
|
|
|
|
|
|
print('\nCreating backwards compatibility indexes')
|
|
|
|
source = download_release(c.version, c.temp_dir, c.force)
|
2016-06-25 14:26:42 -04:00
|
|
|
current_version = scriptutil.Version.parse(scriptutil.find_current_version())
|
|
|
|
create_and_add_index(source, 'cfs', c.version, current_version, c.temp_dir)
|
|
|
|
create_and_add_index(source, 'nocfs', c.version, current_version, c.temp_dir)
|
2024-10-15 07:39:47 -04:00
|
|
|
create_and_add_index(source, 'int7_hnsw', c.version, current_version, c.temp_dir)
|
2017-10-26 17:11:54 -04:00
|
|
|
should_make_sorted = current_version.is_back_compat_with(c.version) \
|
|
|
|
and (c.version.major > 6 or (c.version.major == 6 and c.version.minor >= 2))
|
|
|
|
if should_make_sorted:
|
2017-10-24 12:27:55 -04:00
|
|
|
create_and_add_index(source, 'sorted', c.version, current_version, c.temp_dir)
|
2022-01-12 12:55:59 -05:00
|
|
|
if c.version.minor == 0 and c.version.bugfix == 0 and current_version.is_back_compat_with(c.version):
|
2017-09-30 20:44:01 -04:00
|
|
|
create_and_add_index(source, 'moreterms', c.version, current_version, c.temp_dir)
|
|
|
|
create_and_add_index(source, 'dvupdates', c.version, current_version, c.temp_dir)
|
|
|
|
create_and_add_index(source, 'emptyIndex', c.version, current_version, c.temp_dir)
|
2024-01-31 09:27:56 -05:00
|
|
|
print ('\nMANUAL UPDATE REQUIRED: edit TestGenerateBwcIndices to enable moreterms, dvupdates, and empty index testing')
|
2014-09-24 16:48:57 -04:00
|
|
|
|
|
|
|
print('\nAdding backwards compatibility tests')
|
2024-02-14 15:43:17 -05:00
|
|
|
update_backcompat_tests(c.version, current_version)
|
|
|
|
|
2014-09-24 16:48:57 -04:00
|
|
|
|
|
|
|
print('\nTesting changes')
|
|
|
|
check_backcompat_tests()
|
|
|
|
|
|
|
|
if c.cleanup:
|
|
|
|
print('\nCleaning up')
|
|
|
|
print(' deleting %s...' % c.temp_dir, end='', flush=True)
|
|
|
|
shutil.rmtree(c.temp_dir)
|
|
|
|
print('done')
|
|
|
|
|
|
|
|
print()
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
try:
|
|
|
|
main()
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
print('\nRecieved Ctrl-C, exiting early')
|