|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- import argparse
- import os
- import sys
- import pytest
- from pathlib import Path
- from typing import Sequence, NamedTuple
- import subprocess
- import urllib.request
- import shutil
-
- from self_build import self_build
- from self_deps_get import self_deps_get
- from self_deps_build import self_deps_build
- from dds_ci import paths, proc
-
-
- class CIOptions(NamedTuple):
- toolchain: str
- skip_deps: bool
-
-
- def _do_bootstrap_build(opts: CIOptions) -> None:
- print('Bootstrapping by a local build of prior versions...')
- subprocess.check_call([
- sys.executable,
- '-u',
- str(paths.TOOLS_DIR / 'bootstrap.py'),
- ])
-
-
- def _do_bootstrap_download() -> None:
- filename = {
- 'win32': 'dds-win-x64.exe',
- 'linux': 'dds-linux-x64',
- 'darwin': 'dds-macos-x64',
- }.get(sys.platform)
- if filename is None:
- raise RuntimeError(f'We do not have a prebuilt DDS binary for '
- f'the "{sys.platform}" platform')
- url = f'https://github.com/vector-of-bool/dds/releases/download/bootstrap-p4/{filename}'
-
- print(f'Downloading prebuilt DDS executable: {url}')
- stream = urllib.request.urlopen(url)
- paths.PREBUILT_DDS.parent.mkdir(exist_ok=True, parents=True)
- with paths.PREBUILT_DDS.open('wb') as fd:
- while True:
- buf = stream.read(1024 * 4)
- if not buf:
- break
- fd.write(buf)
-
- if os.name != 'nt':
- # Mark the binary executable. By default it won't be
- mode = paths.PREBUILT_DDS.stat().st_mode
- mode |= 0b001_001_001
- paths.PREBUILT_DDS.chmod(mode)
-
-
- def main(argv: Sequence[str]) -> int:
- parser = argparse.ArgumentParser()
- parser.add_argument(
- '-B',
- '--bootstrap-with',
- help='How are we to obtain a bootstrapped DDS executable?',
- choices=('download', 'build', 'skip'),
- required=True,
- )
- parser.add_argument(
- '--toolchain',
- '-T',
- help='The toolchain to use for the CI process',
- required=True)
- parser.add_argument(
- '--skip-deps',
- action='store_true',
- help='If specified, will skip getting and building '
- 'dependencies. (They must already be present)')
- args = parser.parse_args(argv)
-
- opts = CIOptions(toolchain=args.toolchain, skip_deps=args.skip_deps)
-
- if args.bootstrap_with == 'build':
- _do_bootstrap_build(opts)
- elif args.bootstrap_with == 'download':
- _do_bootstrap_download()
- elif args.bootstrap_with == 'skip':
- pass
- else:
- assert False, 'impossible'
-
- cat_path = paths.BUILD_DIR / 'catalog.db'
- ci_repo_dir = paths.BUILD_DIR / '_ci-repo'
- if ci_repo_dir.exists():
- shutil.rmtree(ci_repo_dir)
-
- proc.check_run([
- paths.PREBUILT_DDS,
- 'catalog',
- 'import',
- ('--catalog', cat_path),
- ('--json', paths.PROJECT_ROOT / 'catalog.json'),
- ])
- self_build(
- paths.PREBUILT_DDS,
- toolchain=opts.toolchain,
- dds_flags=[
- ('--catalog', cat_path),
- ('--repo-dir', ci_repo_dir),
- ])
- print('Main build PASSED!')
-
- proc.check_run([
- paths.CUR_BUILT_DDS,
- 'catalog',
- 'import',
- ('--catalog', cat_path),
- ('--json', paths.PROJECT_ROOT / 'catalog.json'),
- ])
- self_build(
- paths.CUR_BUILT_DDS,
- toolchain=opts.toolchain,
- dds_flags=[f'--repo-dir={ci_repo_dir}', f'--catalog={cat_path}'])
- print('Bootstrap test PASSED!')
-
- return pytest.main([
- '-v',
- '--durations=10',
- f'--basetemp={paths.BUILD_DIR / "_tmp"}',
- '-n4',
- 'tests/',
- ])
-
-
- if __name__ == "__main__":
- sys.exit(main(sys.argv[1:]))
|