1
0
Fork 0

Update clang version

apt.llvm.org signature has changed, we also should use debian:stable
(=buster) as a base image to correctly install packages.

Removed jdk from the base image as it was used only by Jenkins.

Log packages version for every build.

Related issues: #112
This commit is contained in:
Mikhail Goncharov 2020-06-18 10:54:57 +02:00
parent 89e3f73689
commit fb830daebe
5 changed files with 63 additions and 39 deletions

View file

@ -1,18 +1,34 @@
FROM debian:testing FROM debian:buster
RUN echo 'intall build dependencies'; \ RUN echo 'intall build dependencies'; \
echo "deb [trusted=yes] http://apt.llvm.org/buster/ llvm-toolchain-buster-10 main\n$(cat /etc/apt/sources.list)" > /etc/apt/sources.list ;\
apt-get update ;\ apt-get update ;\
apt-get install -y --no-install-recommends \ apt-get install -y --no-install-recommends \
locales openssh-client\ locales openssh-client gnupg ca-certificates \
cmake ninja-build git ca-certificates clang lld ccache python3 build-essential gdb \ zip wget git \
clang-tidy clang-format \ cmake gdb build-essential \
python3-psutil zip wget \ ninja-build \
openjdk-11-jdk \ ccache \
python3 python3-psutil \
python3-pip python3-setuptools \ python3-pip python3-setuptools \
swig python3-dev libedit-dev libncurses5-dev libxml2-dev liblzma-dev golang rsync jq; \ swig python3-dev libedit-dev libncurses5-dev libxml2-dev liblzma-dev golang rsync jq;
apt-get clean; \ RUN wget -O - https://apt.llvm.org/llvm-snapshot.gpg.key | apt-key add - ;\
echo 'configure locale'; \ echo "deb http://apt.llvm.org/buster/ llvm-toolchain-buster-10 main\ndeb-src http://apt.llvm.org/buster/ llvm-toolchain-buster-10 main\n$(cat /etc/apt/sources.list)" > /etc/apt/sources.list ;\
cat /etc/apt/sources.list; \
apt-get update ;\
apt-get upgrade -y ;\
apt-get install -y \
clang-10 lld-10 clang-tidy-10 clang-format-10 \
;\
ln -s /usr/bin/clang-10 /usr/bin/clang;\
ln -s /usr/bin/clang++-10 /usr/bin/clang++;\
ln -s /usr/bin/clang-tidy-10 /usr/bin/clang-tidy;\
ln -s /usr/bin/clang-tidy-diff-10 /usr/bin/clang-tidy-diff;\
ln -s /usr/bin/clang-format-10 /usr/bin/clang-format;\
ln -s /usr/bin/clang-format-diff-10 /usr/bin/clang-format-diff;\
ln -s /usr/bin/lld-10 /usr/bin/lld;\
apt-get clean;
RUN echo 'configure locale'; \
sed --in-place '/en_US.UTF-8/s/^#//' /etc/locale.gen ;\ sed --in-place '/en_US.UTF-8/s/^#//' /etc/locale.gen ;\
locale-gen ;\ locale-gen ;\
echo 'make python 3 default'; \ echo 'make python 3 default'; \

View file

@ -25,6 +25,7 @@ if __name__ == '__main__':
'label': ':linux: build and test linux', 'label': ':linux: build and test linux',
'key': 'linux', 'key': 'linux',
'commands': [ 'commands': [
'dpkg -l >> artifacts/packages.txt',
'export SRC=${BUILDKITE_BUILD_PATH}/llvm-premerge-checks', 'export SRC=${BUILDKITE_BUILD_PATH}/llvm-premerge-checks',
'rm -rf ${SRC}', 'rm -rf ${SRC}',
'git clone --depth 1 --branch ${scripts_branch} https://github.com/google/llvm-premerge-checks.git ${SRC}', 'git clone --depth 1 --branch ${scripts_branch} https://github.com/google/llvm-premerge-checks.git ${SRC}',

View file

@ -25,6 +25,7 @@ if __name__ == '__main__':
'label': ':linux: build and test linux', 'label': ':linux: build and test linux',
'key': 'linux', 'key': 'linux',
'commands': [ 'commands': [
'dpkg -l >> artifacts/packages.txt',
'export SRC=${BUILDKITE_BUILD_PATH}/llvm-premerge-checks', 'export SRC=${BUILDKITE_BUILD_PATH}/llvm-premerge-checks',
'rm -rf ${SRC}', 'rm -rf ${SRC}',
'git clone --depth 1 --branch ${scripts_branch} https://github.com/google/llvm-premerge-checks.git ${SRC}', 'git clone --depth 1 --branch ${scripts_branch} https://github.com/google/llvm-premerge-checks.git ${SRC}',

View file

@ -34,17 +34,17 @@ from phabtalk.phabtalk import Report, PhabTalk, Step
def ninja_all_report(step: Step, _: Report): def ninja_all_report(step: Step, _: Report):
print('Full will be available in Artifacts "ninja-all.log"', flush=True) print('Full log will be available in Artifacts "ninja-all.log"', flush=True)
r = subprocess.run(f'ninja all | ' r = subprocess.run(f'ninja all | '
f'tee {artifacts_dir}/ninja-all.log | ' f'tee {artifacts_dir}/ninja-all.log | '
f'grep -vE "\\[.*] (Building|Linking|Copying|Generating|Creating)"', f'grep -vE "\\[.*] (Building|Linking|Linting|Copying|Generating|Creating)"',
shell=True, cwd=build_dir) shell=True, cwd=build_dir)
logging.debug(f'ninja all: returned {r.returncode}, stderr: "{r.stderr}"') logging.debug(f'ninja all: returned {r.returncode}, stderr: "{r.stderr}"')
step.set_status_from_exit_code(r.returncode) step.set_status_from_exit_code(r.returncode)
def ninja_check_all_report(step: Step, _: Report): def ninja_check_all_report(step: Step, _: Report):
print('Full will be available in Artifacts "ninja-check-all.log"', flush=True) print('Full log will be available in Artifacts "ninja-check-all.log"', flush=True)
r = subprocess.run(f'ninja check-all | tee {artifacts_dir}/ninja-check-all.log | ' r = subprocess.run(f'ninja check-all | tee {artifacts_dir}/ninja-check-all.log | '
f'grep -vE "^\\[.*] (Building|Linking)" | ' f'grep -vE "^\\[.*] (Building|Linking)" | '
f'grep -vE "^(PASS|XFAIL|UNSUPPORTED):"', shell=True, cwd=build_dir) f'grep -vE "^(PASS|XFAIL|UNSUPPORTED):"', shell=True, cwd=build_dir)

View file

@ -33,34 +33,40 @@ def run(working_dir: str, test_results: str, step: Optional[Step], report: Optio
step.messages.append(f'test report "{path}" is not found') step.messages.append(f'test report "{path}" is not found')
return return
report.add_artifact(working_dir, test_results, 'test results') report.add_artifact(working_dir, test_results, 'test results')
success = True try:
root_node = etree.parse(path) success = True
for test_case in root_node.xpath('//testcase'): root_node = etree.parse(path)
test_result = 'pass' for test_case in root_node.xpath('//testcase'):
if test_case.find('failure') is not None: test_result = 'pass'
test_result = 'fail' if test_case.find('failure') is not None:
if test_case.find('skipped') is not None: test_result = 'fail'
test_result = 'skip' if test_case.find('skipped') is not None:
report.test_stats[test_result] += 1 test_result = 'skip'
if test_result == 'fail': report.test_stats[test_result] += 1
success = False if test_result == 'fail':
failure = test_case.find('failure') success = False
test_result = { failure = test_case.find('failure')
'name': test_case.attrib['name'], test_result = {
'namespace': test_case.attrib['classname'], 'name': test_case.attrib['name'],
'result': test_result, 'namespace': test_case.attrib['classname'],
'duration': float(test_case.attrib['time']), 'result': test_result,
'details': failure.text 'duration': float(test_case.attrib['time']),
} 'details': failure.text
report.unit.append(test_result) }
report.unit.append(test_result)
msg = f'{report.test_stats["pass"]} tests passed, {report.test_stats["fail"]} failed and ' \ msg = f'{report.test_stats["pass"]} tests passed, {report.test_stats["fail"]} failed and ' \
f'{report.test_stats["skip"]} were skipped.\n' f'{report.test_stats["skip"]} were skipped.\n'
if not success: if not success:
step.success = False
for test_case in report.unit:
if test_case['result'] == 'fail':
msg += f'{test_case["namespace"]}/{test_case["name"]}\n'
except Exception as e:
logging.error(e)
step.messages.append('Parsing of test results failed')
step.success = False step.success = False
for test_case in report.unit:
if test_case['result'] == 'fail':
msg += f'{test_case["namespace"]}/{test_case["name"]}\n'
logging.debug(f'report: {report}') logging.debug(f'report: {report}')
logging.debug(f'step: {step}') logging.debug(f'step: {step}')