1
1
mirror of https://github.com/henrydcase/pqc.git synced 2024-11-27 09:51:30 +00:00
pqcrypto/.circleci/config.yml
Thom Wiggers b3f9d4f8d6
Classic McEliece (#259)
* Add McEliece reference implementations

* Add Vec implementations of McEliece

* Add sse implementations

* Add AVX2 implementations

* Get rid of stuff not supported by Mac ABI

* restrict to two cores

* Ditch .data files

* Remove .hidden from all .S files

* speed up duplicate consistency tests by batching

* make cpuinfo more robust

* Hope to stabilize macos cpuinfo without ccache

* Revert "Hope to stabilize macos cpuinfo without ccache"

This reverts commit 6129c3cabe1abbc8b956bc87e902a698e32bf322.

* Just hardcode what's available at travis

* Fixed-size types in api.h

* namespace all header files in mceliece

* Ditch operations.h

* Get rid of static inline functions

* fixup! Ditch operations.h
2020-02-05 13:09:56 +01:00

363 lines
10 KiB
YAML

version: 2.1
.emulated_job: &defaultjob
machine: true
steps:
- checkout
- run: &checkouttask
name: Pull submodules
command: |
git submodule init
git submodule update
git checkout $CIRCLECI_BRANCH
git reset --hard $CIRCLECI_SHA1
- run:
name: Install the emulation handlers
command: docker run --rm --privileged multiarch/qemu-user-static:register --reset
- restore_cache:
keys:
- v1-ccache-{{ .Environment.CIRCLE_JOB }}
- run:
name: Run the tests in a container
command: |
docker run -e CI=true -e PQCLEAN_ONLY_TYPES -e PQCLEAN_ONLY_DIFF=1 -e PQCLEAN_SKIP_SCHEMES=sphincs-haraka-128f-robust,sphincs-haraka-192s-robust,sphincs-sha256-128f-robust,sphincs-sha256-192s-robust,sphincs-shake256-128f-robust,sphincs-shake256-192s-robust,sphincs-haraka-128f-simple,sphincs-haraka-192s-simple,sphincs-sha256-128f-simple,sphincs-sha256-192s-simple,sphincs-shake256-128f-simple,sphincs-shake256-192s-simple,sphincs-haraka-128s-robust,sphincs-haraka-256f-robust,sphincs-sha256-128s-robust,sphincs-sha256-256f-robust,sphincs-shake256-128s-robust,sphincs-shake256-256f-robust,sphincs-haraka-128s-simple,sphincs-haraka-256f-simple,sphincs-sha256-128s-simple,sphincs-sha256-256f-simple,sphincs-shake256-128s-simple,sphincs-shake256-256f-simple,sphincs-haraka-192f-robust,sphincs-haraka-256s-robust,sphincs-sha256-192f-robust,sphincs-sha256-256s-robust,sphincs-shake256-192f-robust,sphincs-shake256-256s-robust,sphincs-haraka-192f-simple,sphincs-haraka-256s-simple,sphincs-sha256-192f-simple,sphincs-sha256-256s-simple,sphincs-shake256-192f-simple,sphincs-shake256-256s-simple --rm -v `pwd`:`pwd` -w `pwd` -v ~/ccache:/ccache "pqclean/ci-container:$ARCH" /bin/bash -c "
uname -a &&
export CCACHE_NOSTATS=1 &&
export CCACHE_DIR=/ccache &&
export CCACHE_SLOPPINESS=include_file_mtime &&
export CC=\"ccache ${CC}\" &&
pip3 install -r requirements.txt &&
mkdir test-results &&
cd test && python3 -m pytest --verbose --junitxml=test-results/pytest/results.xml --numprocesses=2"
no_output_timeout: 2h
- save_cache:
key: v1-ccache-{{ .Environment.CIRCLE_JOB }}
paths:
- ~/ccache
- store_test_results:
path: test/test-results
.native_job: &nativejob
docker:
- image: pqclean/ci-container:$ARCH
steps:
- checkout
- run:
<<: *checkouttask
- restore_cache:
keys:
- v1-ccache-{{ .Environment.CIRCLE_JOB }}
- run:
name: Run tests
command: |
export CCACHE_NOSTATS=1
export CCACHE_DIR=/ccache
export CCACHE_SLOPPINESS=include_file_mtime
export CC="ccache ${CC}"
export PQCLEAN_ONLY_DIFF=1
export PQCLEAN_SKIP_SCHEMES=sphincs-haraka-128f-robust,sphincs-haraka-192s-robust,sphincs-sha256-128f-robust,sphincs-sha256-192s-robust,sphincs-shake256-128f-robust,sphincs-shake256-192s-robust,sphincs-haraka-128f-simple,sphincs-haraka-192s-simple,sphincs-sha256-128f-simple,sphincs-sha256-192s-simple,sphincs-shake256-128f-simple,sphincs-shake256-192s-simple,sphincs-haraka-128s-robust,sphincs-haraka-256f-robust,sphincs-sha256-128s-robust,sphincs-sha256-256f-robust,sphincs-shake256-128s-robust,sphincs-shake256-256f-robust,sphincs-haraka-128s-simple,sphincs-haraka-256f-simple,sphincs-sha256-128s-simple,sphincs-sha256-256f-simple,sphincs-shake256-128s-simple,sphincs-shake256-256f-simple,sphincs-haraka-192f-robust,sphincs-haraka-256s-robust,sphincs-sha256-192f-robust,sphincs-sha256-256s-robust,sphincs-shake256-192f-robust,sphincs-shake256-256s-robust,sphincs-haraka-192f-simple,sphincs-haraka-256s-simple,sphincs-sha256-192f-simple,sphincs-sha256-256s-simple,sphincs-shake256-192f-simple,sphincs-shake256-256s-simple
pip3 install -r requirements.txt
mkdir test-results
cd test
python3 -m pytest --verbose --junitxml=test-results/pytest/results.xml --numprocesses=2
no_output_timeout: 2h
- store_test_results:
path: test/test-results
- store_artifacts:
path: test/test-results
- save_cache:
key: v1-ccache-{{ .Environment.CIRCLE_JOB }}
paths:
- /ccache
jobs:
# First the KEM jobs
arm32-gcc-kem:
<<: *defaultjob
environment:
CC: gcc
ARCH: armhf
PQCLEAN_ONLY_TYPES: kem
arm32-clang-kem:
<<: *defaultjob
environment:
CC: clang
ARCH: armhf
PQCLEAN_ONLY_TYPES: kem
ppc-clang-kem:
<<: *defaultjob
environment:
CC: clang
ARCH: unstable-ppc
PQCLEAN_ONLY_TYPES: kem
ppc-gcc-kem:
<<: *defaultjob
environment:
CC: gcc
ARCH: unstable-ppc
PQCLEAN_ONLY_TYPES: kem
amd64-gcc-kem:
<<: *nativejob
environment:
CC: gcc
ARCH: amd64
PQCLEAN_ONLY_TYPES: kem
amd64-clang-kem:
<<: *nativejob
environment:
CC: clang
ARCH: amd64
PQCLEAN_ONLY_TYPES: kem
i386-gcc-kem:
<<: *nativejob
environment:
CC: gcc
ARCH: i386
PQCLEAN_ONLY_TYPES: kem
i386-clang-kem:
<<: *nativejob
environment:
CC: clang
ARCH: i386
PQCLEAN_ONLY_TYPES: kem
# These are for the scheduled builds
arm32-gcc-slow-kem:
<<: *defaultjob
environment:
CC: gcc
ARCH: armhf
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
arm32-clang-slow-kem:
<<: *defaultjob
environment:
CC: clang
ARCH: armhf
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
ppc-clang-slow-kem:
<<: *defaultjob
environment:
CC: clang
ARCH: unstable-ppc
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
ppc-gcc-slow-kem:
<<: *defaultjob
environment:
CC: gcc
ARCH: unstable-ppc
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
amd64-gcc-slow-kem:
<<: *nativejob
environment:
CC: gcc
ARCH: amd64
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
amd64-clang-slow-kem:
<<: *nativejob
environment:
CC: clang
ARCH: amd64
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
i386-gcc-slow-kem:
<<: *nativejob
environment:
CC: gcc
ARCH: i386
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
i386-clang-slow-kem:
<<: *nativejob
environment:
CC: clang
ARCH: i386
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: kem
# the Sign jobs
arm32-gcc-sign:
<<: *defaultjob
environment:
CC: gcc
ARCH: armhf
PQCLEAN_ONLY_TYPES: sign
arm32-clang-sign:
<<: *defaultjob
environment:
CC: clang
ARCH: armhf
PQCLEAN_ONLY_TYPES: sign
ppc-clang-sign:
<<: *defaultjob
environment:
CC: clang
ARCH: unstable-ppc
PQCLEAN_ONLY_TYPES: sign
ppc-gcc-sign:
<<: *defaultjob
environment:
CC: gcc
ARCH: unstable-ppc
PQCLEAN_ONLY_TYPES: sign
amd64-gcc-sign:
<<: *nativejob
environment:
CC: gcc
ARCH: amd64
PQCLEAN_ONLY_TYPES: sign
amd64-clang-sign:
<<: *nativejob
environment:
CC: clang
ARCH: amd64
PQCLEAN_ONLY_TYPES: sign
i386-gcc-sign:
<<: *nativejob
environment:
CC: gcc
ARCH: i386
PQCLEAN_ONLY_TYPES: sign
i386-clang-sign:
<<: *nativejob
environment:
CC: clang
ARCH: i386
PQCLEAN_ONLY_TYPES: sign
# These are for the scheduled builds
arm32-gcc-slow-sign:
<<: *defaultjob
environment:
CC: gcc
ARCH: armhf
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
arm32-clang-slow-sign:
<<: *defaultjob
environment:
CC: clang
ARCH: armhf
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
ppc-clang-slow-sign:
<<: *defaultjob
environment:
CC: clang
ARCH: unstable-ppc
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
ppc-gcc-slow-sign:
<<: *defaultjob
environment:
CC: gcc
ARCH: unstable-ppc
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
amd64-gcc-slow-sign:
<<: *nativejob
environment:
CC: gcc
ARCH: amd64
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
amd64-clang-slow-sign:
<<: *nativejob
environment:
CC: clang
ARCH: amd64
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
i386-gcc-slow-sign:
<<: *nativejob
environment:
CC: gcc
ARCH: i386
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
i386-clang-slow-sign:
<<: *nativejob
environment:
CC: clang
ARCH: i386
RUN_SLOW: 1
PQCLEAN_ONLY_TYPES: sign
workflows:
version: 2
build:
jobs:
# AMD64
- amd64-gcc-kem
- amd64-clang-kem
- amd64-gcc-sign
- amd64-clang-sign
# i386
- i386-gcc-kem: &i386
requires:
- amd64-gcc-kem
- amd64-gcc-sign
- amd64-clang-kem
- amd64-clang-sign
- i386-clang-kem:
<<: *i386
- i386-gcc-sign:
<<: *i386
- i386-clang-sign:
<<: *i386
# ARM 32 bit
- arm32-gcc-kem: &arm32
requires:
- i386-gcc-kem
- i386-gcc-sign
- i386-clang-kem
- i386-clang-sign
- arm32-clang-kem:
<<: *arm32
- arm32-gcc-sign:
<<: *arm32
- arm32-clang-sign:
<<: *arm32
# PPC
- ppc-gcc-kem: &ppc
requires:
- arm32-gcc-kem
- arm32-clang-kem
- arm32-gcc-sign
- arm32-clang-sign
- ppc-clang-kem:
<<: *ppc
- ppc-gcc-sign:
<<: *ppc
- ppc-clang-sign:
<<: *ppc
scheduled:
triggers:
- schedule:
cron: "0 5 * * 6"
filters:
branches:
only: master
jobs:
- amd64-clang-slow-kem
- amd64-clang-slow-sign
- amd64-gcc-slow-kem
- amd64-gcc-slow-sign
- arm32-clang-slow-kem
- arm32-clang-slow-sign
- arm32-gcc-slow-kem
- arm32-gcc-slow-sign
- i386-clang-slow-kem
- i386-clang-slow-sign
- i386-gcc-slow-kem
- i386-gcc-slow-sign
- ppc-clang-slow-kem
- ppc-clang-slow-sign
- ppc-gcc-slow-kem
- ppc-gcc-slow-sign
# vim: set ft=yaml ts=2 sw=2 tw=0 et :
# vim: set ft=yaml ts=2 sw=2 tw=0 et :