-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_solr_for_unit_tests.py
executable file
·122 lines (98 loc) · 4.91 KB
/
run_solr_for_unit_tests.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#!/usr/bin/env python
#
# Set it up so we can painless run the python nose tests against the localhost 8983.
# Summary:
#
# ./run_solr_for_unit_tests.py [--debug] [--debug-port=9999] [--port=8983]
#
# Add the argument "--debug" to start the Jetty server in debug mode. Specify the port with "--debug-port=XXXX".
# Assumes you're running this on a *nix machine.
#
import sys, os, shutil, urllib, xml.dom.minidom, tarfile, getopt
args = {'--debug-port' : 9999, '--port' : 8983}
args.update(dict(getopt.getopt(sys.argv[1:], '', ['debug', 'debug-port=', 'port='])[0]))
os.system("mvn clean package")
shutil.rmtree('target/webapp', ignore_errors=True)
os.mkdir('target/webapp')
def find_solr_version():
pom = xml.dom.minidom.parse('pom.xml')
def isSolrCoreDep(dep):
return filter((lambda artifact : artifact.lastChild.data == 'solr-core'), dep.getElementsByTagName('artifactId'))
solrCoreDep = filter(isSolrCoreDep, pom.getElementsByTagName('dependency'))[0]
return solrCoreDep.getElementsByTagName('version')[0].lastChild.data
# compare major.minor.patch-style versions, e.g. 1.2 vs 1.2.1 vs 1.2.3 etc.
def version_compare(ver1, ver2):
def listify(str):
return map(lambda x:int(x), str.split('.'))
(list1, list2) = (listify(ver1), listify(ver2))
# lexicographical comparison
return -1 if list1 < list2 else (1 if list2 > list1 else 0)
solr_version = find_solr_version()
# they changed their naming convention in v 4.1.0
tgz_filename = ('solr-%s' if (version_compare(solr_version, '4.1.0') >= 0) else 'apache-solr-%s') % solr_version
local_filename = 'target/webapp/solr.tgz'
mvn_filename = os.environ['HOME'] + \
('/.m2/repository/org/healthonnet/hon-lucene-synonyms-solrdep/%s/hon-lucene-synonyms-solrdep-%s.tgz' \
% (solr_version, solr_version))
if not os.path.isfile(mvn_filename):
# download the tgz file
print "Downloading solr tgz file version %s (I'll only have to do this once)" % solr_version
tgz_url = 'http://archive.apache.org/dist/lucene/solr/%s/%s.tgz' % (solr_version, tgz_filename)
def reporthook(a,b,c):
print "% 3.1f%% of %d bytes\r" % (min(100, float(a * b) / c * 100), c),
sys.stdout.flush()
urllib.urlretrieve(tgz_url, local_filename, reporthook)
# use maven to store the file locally in the future
install_cmd = """mvn install:install-file \
-DgroupId=org.healthonnet \
-DartifactId=hon-lucene-synonyms-solrdep \
-Dversion=%s \
-Dfile=%s \
-Dpackaging=tgz""" % (solr_version, local_filename)
os.system(install_cmd)
else:
shutil.copy(mvn_filename, local_filename)
solrdir = 'target/webapp/' + tgz_filename
tar = tarfile.open(local_filename)
tar.extractall(path='target/webapp/')
os.mkdir(solrdir + '/example/myjar')
if version_compare(solr_version, '5.0.0') >= 0:
if version_compare(solr_version, '5.3.1') >= 0:
os.system('cp target/hon-lucene-synonyms-*.jar %s/server/solr-webapp/webapp/WEB-INF/lib' % solrdir)
else:
os.system('cd %s/example/myjar; jar -xf ../../server/webapps/solr.war; cd -' % solrdir)
os.system('cp target/hon-lucene-synonyms-*.jar %s/example/myjar/WEB-INF/lib' % solrdir)
os.system('cd %s/example/myjar; jar -cf ../../server/webapps/solr.war *; cd -' % solrdir)
else:
os.system('cd %s/example/myjar; jar -xf ../webapps/solr.war; cd -' % solrdir)
os.system('cp target/hon-lucene-synonyms-*.jar %s/example/myjar/WEB-INF/lib' % solrdir)
os.system('cd %s/example/myjar; jar -cf ../webapps/solr.war *; cd -' % solrdir)
# they changed the location of the example conf dir in solr 4.0.0
if version_compare(solr_version, '5.0.0') >= 0:
confdir = 'sample_techproducts_configs/conf'
solrexamplepath = '/server/solr/configsets/'
shutil.copy('examples/example_synonym_file.txt', solrdir + solrexamplepath + confdir)
else:
if version_compare(solr_version, '4.0.0') >= 0:
confdir = 'collection1/conf'
else:
confdir = 'conf'
solrexamplepath = '/example/solr/'
shutil.copy('examples/example_synonym_file.txt', solrdir + solrexamplepath + confdir)
# add the config to the config file
conf_to_add = open('examples/example_config.xml', 'r').read()
conf_filename = solrdir + solrexamplepath + confdir + '/solrconfig.xml'
filein = open(conf_filename,'r')
filetext = filein.read()
filein.close()
fileout = open(conf_filename,'w')
fileout.write(filetext.replace('</config>', conf_to_add + '</config>'))
fileout.close()
debug = ('-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=%s' % args['--debug-port']) if '--debug' in args else ''
if version_compare(solr_version, '5.0.0') >= 0:
cmd = 'cd %(solrdir)s; bin/solr -e techproducts; bin/solr stop; bin/solr start -f -p 8983 -s "example/techproducts/solr"' % {'solrdir': solrdir}
else:
cmd = 'cd %(solrdir)s/example; java %(debug)s -Dwhatever=techproducts -Djetty.port=%(port)s -jar start.jar' % \
{'debug' : debug, 'solrdir' : solrdir, 'port' : args['--port']}
print "Running jetty with command: " + cmd
os.system(cmd)