| 1 | #!/usr/bin/env python
|
|---|
| 2 |
|
|---|
| 3 | APPNAME = 'tdb'
|
|---|
| 4 | VERSION = '1.3.8'
|
|---|
| 5 |
|
|---|
| 6 | blddir = 'bin'
|
|---|
| 7 |
|
|---|
| 8 | import sys, os
|
|---|
| 9 |
|
|---|
| 10 | # find the buildtools directory
|
|---|
| 11 | srcdir = '.'
|
|---|
| 12 | while not os.path.exists(srcdir+'/buildtools') and len(srcdir.split('/')) < 5:
|
|---|
| 13 | srcdir = srcdir + '/..'
|
|---|
| 14 | sys.path.insert(0, srcdir + '/buildtools/wafsamba')
|
|---|
| 15 |
|
|---|
| 16 | import wafsamba, samba_dist, Options, Logs
|
|---|
| 17 |
|
|---|
| 18 | samba_dist.DIST_DIRS('lib/tdb:. lib/replace:lib/replace buildtools:buildtools third_party/waf:third_party/waf')
|
|---|
| 19 |
|
|---|
| 20 | tdb1_unit_tests = [
|
|---|
| 21 | 'run-3G-file',
|
|---|
| 22 | 'run-bad-tdb-header',
|
|---|
| 23 | 'run',
|
|---|
| 24 | 'run-check',
|
|---|
| 25 | 'run-corrupt',
|
|---|
| 26 | 'run-die-during-transaction',
|
|---|
| 27 | 'run-endian',
|
|---|
| 28 | 'run-incompatible',
|
|---|
| 29 | 'run-nested-transactions',
|
|---|
| 30 | 'run-nested-traverse',
|
|---|
| 31 | 'run-no-lock-during-traverse',
|
|---|
| 32 | 'run-oldhash',
|
|---|
| 33 | 'run-open-during-transaction',
|
|---|
| 34 | 'run-readonly-check',
|
|---|
| 35 | 'run-rescue',
|
|---|
| 36 | 'run-rescue-find_entry',
|
|---|
| 37 | 'run-rwlock-check',
|
|---|
| 38 | 'run-summary',
|
|---|
| 39 | 'run-transaction-expand',
|
|---|
| 40 | 'run-traverse-in-transaction',
|
|---|
| 41 | 'run-wronghash-fail',
|
|---|
| 42 | 'run-zero-append',
|
|---|
| 43 | 'run-marklock-deadlock',
|
|---|
| 44 | 'run-allrecord-traverse-deadlock',
|
|---|
| 45 | 'run-mutex-openflags2',
|
|---|
| 46 | 'run-mutex-trylock',
|
|---|
| 47 | 'run-mutex-allrecord-bench',
|
|---|
| 48 | 'run-mutex-allrecord-trylock',
|
|---|
| 49 | 'run-mutex-allrecord-block',
|
|---|
| 50 | 'run-mutex-transaction1',
|
|---|
| 51 | 'run-mutex-die',
|
|---|
| 52 | 'run-mutex1',
|
|---|
| 53 | ]
|
|---|
| 54 |
|
|---|
| 55 | def set_options(opt):
|
|---|
| 56 | opt.BUILTIN_DEFAULT('replace')
|
|---|
| 57 | opt.PRIVATE_EXTENSION_DEFAULT('tdb', noextension='tdb')
|
|---|
| 58 | opt.RECURSE('lib/replace')
|
|---|
| 59 | opt.add_option('--disable-tdb-mutex-locking',
|
|---|
| 60 | help=("Disable the use of pthread robust mutexes"),
|
|---|
| 61 | action="store_true", dest='disable_tdb_mutex_locking',
|
|---|
| 62 | default=False)
|
|---|
| 63 | if opt.IN_LAUNCH_DIR():
|
|---|
| 64 | opt.add_option('--disable-python',
|
|---|
| 65 | help=("disable the pytdb module"),
|
|---|
| 66 | action="store_true", dest='disable_python', default=False)
|
|---|
| 67 |
|
|---|
| 68 |
|
|---|
| 69 | def configure(conf):
|
|---|
| 70 | conf.env.disable_tdb_mutex_locking = getattr(Options.options,
|
|---|
| 71 | 'disable_tdb_mutex_locking',
|
|---|
| 72 | False)
|
|---|
| 73 | if not conf.env.disable_tdb_mutex_locking:
|
|---|
| 74 | conf.env.replace_add_global_pthread = True
|
|---|
| 75 | conf.RECURSE('lib/replace')
|
|---|
| 76 |
|
|---|
| 77 | conf.env.standalone_tdb = conf.IN_LAUNCH_DIR()
|
|---|
| 78 | conf.env.building_tdb = True
|
|---|
| 79 |
|
|---|
| 80 | if not conf.env.standalone_tdb:
|
|---|
| 81 | if conf.CHECK_BUNDLED_SYSTEM_PKG('tdb', minversion=VERSION,
|
|---|
| 82 | implied_deps='replace'):
|
|---|
| 83 | conf.define('USING_SYSTEM_TDB', 1)
|
|---|
| 84 | conf.env.building_tdb = False
|
|---|
| 85 | if conf.CHECK_BUNDLED_SYSTEM_PYTHON('pytdb', 'tdb', minversion=VERSION):
|
|---|
| 86 | conf.define('USING_SYSTEM_PYTDB', 1)
|
|---|
| 87 |
|
|---|
| 88 | conf.env.disable_python = getattr(Options.options, 'disable_python', False)
|
|---|
| 89 |
|
|---|
| 90 | if (conf.CONFIG_SET('HAVE_ROBUST_MUTEXES') and
|
|---|
| 91 | conf.env.building_tdb and
|
|---|
| 92 | not conf.env.disable_tdb_mutex_locking):
|
|---|
| 93 | conf.define('USE_TDB_MUTEX_LOCKING', 1)
|
|---|
| 94 |
|
|---|
| 95 | conf.CHECK_XSLTPROC_MANPAGES()
|
|---|
| 96 |
|
|---|
| 97 | if not conf.env.disable_python:
|
|---|
| 98 | # also disable if we don't have the python libs installed
|
|---|
| 99 | conf.SAMBA_CHECK_PYTHON(mandatory=False)
|
|---|
| 100 | conf.check_python_version((2,4,2))
|
|---|
| 101 | conf.SAMBA_CHECK_PYTHON_HEADERS(mandatory=False)
|
|---|
| 102 | if not conf.env.HAVE_PYTHON_H:
|
|---|
| 103 | Logs.warn('Disabling pytdb as python devel libs not found')
|
|---|
| 104 | conf.env.disable_python = True
|
|---|
| 105 |
|
|---|
| 106 | conf.SAMBA_CONFIG_H()
|
|---|
| 107 |
|
|---|
| 108 | conf.SAMBA_CHECK_UNDEFINED_SYMBOL_FLAGS()
|
|---|
| 109 |
|
|---|
| 110 | def build(bld):
|
|---|
| 111 | bld.RECURSE('lib/replace')
|
|---|
| 112 |
|
|---|
| 113 | COMMON_FILES='''check.c error.c tdb.c traverse.c
|
|---|
| 114 | freelistcheck.c lock.c dump.c freelist.c
|
|---|
| 115 | io.c open.c transaction.c hash.c summary.c rescue.c
|
|---|
| 116 | mutex.c'''
|
|---|
| 117 |
|
|---|
| 118 | COMMON_SRC = bld.SUBDIR('common', COMMON_FILES)
|
|---|
| 119 |
|
|---|
| 120 | if bld.env.standalone_tdb:
|
|---|
| 121 | bld.env.PKGCONFIGDIR = '${LIBDIR}/pkgconfig'
|
|---|
| 122 | private_library = False
|
|---|
| 123 | else:
|
|---|
| 124 | private_library = True
|
|---|
| 125 |
|
|---|
| 126 | if not bld.CONFIG_SET('USING_SYSTEM_TDB'):
|
|---|
| 127 |
|
|---|
| 128 | tdb_deps = 'replace'
|
|---|
| 129 |
|
|---|
| 130 | if bld.CONFIG_SET('USE_TDB_MUTEX_LOCKING'):
|
|---|
| 131 | tdb_deps += ' pthread'
|
|---|
| 132 |
|
|---|
| 133 | bld.SAMBA_LIBRARY('tdb',
|
|---|
| 134 | COMMON_SRC,
|
|---|
| 135 | deps=tdb_deps,
|
|---|
| 136 | includes='include',
|
|---|
| 137 | abi_directory='ABI',
|
|---|
| 138 | abi_match='tdb_*',
|
|---|
| 139 | hide_symbols=True,
|
|---|
| 140 | vnum=VERSION,
|
|---|
| 141 | public_headers=('' if private_library else 'include/tdb.h'),
|
|---|
| 142 | public_headers_install=not private_library,
|
|---|
| 143 | pc_files='tdb.pc',
|
|---|
| 144 | private_library=private_library)
|
|---|
| 145 |
|
|---|
| 146 | bld.SAMBA_BINARY('tdbtorture',
|
|---|
| 147 | 'tools/tdbtorture.c',
|
|---|
| 148 | 'tdb',
|
|---|
| 149 | install=False)
|
|---|
| 150 |
|
|---|
| 151 | bld.SAMBA_BINARY('tdbrestore',
|
|---|
| 152 | 'tools/tdbrestore.c',
|
|---|
| 153 | 'tdb', manpages='man/tdbrestore.8')
|
|---|
| 154 |
|
|---|
| 155 | bld.SAMBA_BINARY('tdbdump',
|
|---|
| 156 | 'tools/tdbdump.c',
|
|---|
| 157 | 'tdb', manpages='man/tdbdump.8')
|
|---|
| 158 |
|
|---|
| 159 | bld.SAMBA_BINARY('tdbbackup',
|
|---|
| 160 | 'tools/tdbbackup.c',
|
|---|
| 161 | 'tdb',
|
|---|
| 162 | manpages='man/tdbbackup.8')
|
|---|
| 163 |
|
|---|
| 164 | bld.SAMBA_BINARY('tdbtool',
|
|---|
| 165 | 'tools/tdbtool.c',
|
|---|
| 166 | 'tdb', manpages='man/tdbtool.8')
|
|---|
| 167 |
|
|---|
| 168 | if bld.env.standalone_tdb:
|
|---|
| 169 | # FIXME: This hardcoded list is stupid, stupid, stupid.
|
|---|
| 170 | bld.SAMBA_SUBSYSTEM('tdb-test-helpers',
|
|---|
| 171 | 'test/external-agent.c test/lock-tracking.c test/logging.c',
|
|---|
| 172 | tdb_deps,
|
|---|
| 173 | includes='include')
|
|---|
| 174 |
|
|---|
| 175 | for t in tdb1_unit_tests:
|
|---|
| 176 | b = "tdb1-" + t
|
|---|
| 177 | s = "test/" + t + ".c"
|
|---|
| 178 | bld.SAMBA_BINARY(b, s, 'replace tdb-test-helpers',
|
|---|
| 179 | includes='include', install=False)
|
|---|
| 180 |
|
|---|
| 181 | if not bld.CONFIG_SET('USING_SYSTEM_PYTDB'):
|
|---|
| 182 | for env in bld.gen_python_environments(['PKGCONFIGDIR']):
|
|---|
| 183 | bld.SAMBA_PYTHON('pytdb',
|
|---|
| 184 | 'pytdb.c',
|
|---|
| 185 | deps='tdb',
|
|---|
| 186 | enabled=not bld.env.disable_python,
|
|---|
| 187 | realname='tdb.so',
|
|---|
| 188 | cflags='-DPACKAGE_VERSION=\"%s\"' % VERSION)
|
|---|
| 189 |
|
|---|
| 190 | if not bld.env.disable_python:
|
|---|
| 191 | for env in bld.gen_python_environments(['PKGCONFIGDIR']):
|
|---|
| 192 | bld.SAMBA_SCRIPT('_tdb_text.py',
|
|---|
| 193 | pattern='_tdb_text.py',
|
|---|
| 194 | installdir='python')
|
|---|
| 195 |
|
|---|
| 196 | bld.INSTALL_FILES('${PYTHONARCHDIR}', '_tdb_text.py')
|
|---|
| 197 |
|
|---|
| 198 | def testonly(ctx):
|
|---|
| 199 | '''run tdb testsuite'''
|
|---|
| 200 | import Utils, samba_utils, shutil
|
|---|
| 201 | ecode = 0
|
|---|
| 202 |
|
|---|
| 203 | test_prefix = "%s/st" % (Utils.g_module.blddir)
|
|---|
| 204 | shutil.rmtree(test_prefix, ignore_errors=True)
|
|---|
| 205 | os.makedirs(test_prefix)
|
|---|
| 206 | os.environ['TEST_DATA_PREFIX'] = test_prefix
|
|---|
| 207 |
|
|---|
| 208 | env = samba_utils.LOAD_ENVIRONMENT()
|
|---|
| 209 | # FIXME: This is horrible :(
|
|---|
| 210 | if env.building_tdb:
|
|---|
| 211 | # Create scratch directory for tests.
|
|---|
| 212 | testdir = os.path.join(test_prefix, 'tdb-tests')
|
|---|
| 213 | samba_utils.mkdir_p(testdir)
|
|---|
| 214 | # Symlink back to source dir so it can find tests in test/
|
|---|
| 215 | link = os.path.join(testdir, 'test')
|
|---|
| 216 | if not os.path.exists(link):
|
|---|
| 217 | os.symlink(os.path.abspath(os.path.join(env.cwd, 'test')), link)
|
|---|
| 218 |
|
|---|
| 219 | for t in tdb1_unit_tests:
|
|---|
| 220 | f = "tdb1-" + t
|
|---|
| 221 | cmd = "cd " + testdir + " && " + os.path.abspath(os.path.join(Utils.g_module.blddir, f)) + " > test-output 2>&1"
|
|---|
| 222 | print("..." + f)
|
|---|
| 223 | ret = samba_utils.RUN_COMMAND(cmd)
|
|---|
| 224 | if ret != 0:
|
|---|
| 225 | print("%s failed:" % f)
|
|---|
| 226 | samba_utils.RUN_COMMAND("cat " + os.path.join(testdir, 'test-output'))
|
|---|
| 227 | ecode = ret
|
|---|
| 228 | break
|
|---|
| 229 |
|
|---|
| 230 | if ecode == 0:
|
|---|
| 231 | cmd = os.path.join(Utils.g_module.blddir, 'tdbtorture')
|
|---|
| 232 | ret = samba_utils.RUN_COMMAND(cmd)
|
|---|
| 233 | print("testsuite returned %d" % ret)
|
|---|
| 234 | if ret != 0:
|
|---|
| 235 | ecode = ret
|
|---|
| 236 |
|
|---|
| 237 | pyret = samba_utils.RUN_PYTHON_TESTS(['python/tests/simple.py'])
|
|---|
| 238 | print("python testsuite returned %d" % pyret)
|
|---|
| 239 | sys.exit(ecode or pyret)
|
|---|
| 240 |
|
|---|
| 241 | # WAF doesn't build the unit tests for this, maybe because they don't link with tdb?
|
|---|
| 242 | # This forces it
|
|---|
| 243 | def test(ctx):
|
|---|
| 244 | import Scripting
|
|---|
| 245 | Scripting.commands.append('build')
|
|---|
| 246 | Scripting.commands.append('testonly')
|
|---|
| 247 |
|
|---|
| 248 | def dist():
|
|---|
| 249 | '''makes a tarball for distribution'''
|
|---|
| 250 | samba_dist.dist()
|
|---|
| 251 |
|
|---|
| 252 | def reconfigure(ctx):
|
|---|
| 253 | '''reconfigure if config scripts have changed'''
|
|---|
| 254 | import samba_utils
|
|---|
| 255 | samba_utils.reconfigure(ctx)
|
|---|