Merge pull request #60 from PQClean/format-check-in-python

Add formatting tests to the python-based testing framework.
This commit is contained in:
Matthias J. Kannwischer 2019-03-01 11:27:37 +01:00 committed by GitHub
commit 7a36262f6a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 41 additions and 9 deletions

View File

@ -8,6 +8,10 @@ matrix:
- pip3 install -r requirements.txt
script:
- "cd test && python3 -m nose --rednose --verbose"
addons:
homebrew:
packages:
- astyle
- name: "MacOS + GCC8"
os: osx
osx_image: xcode10.1
@ -15,6 +19,7 @@ matrix:
addons:
homebrew:
packages:
- astyle
- gcc@8
before_install:
- pip3 install -r requirements.txt

View File

@ -13,14 +13,6 @@ endif
clean:
rm -rf bin
.PHONY: format
format:
astyle --project crypto_*/*/*/*.[ch] common/*.[ch]
.PHONY: check-format
check-format:
astyle --dry-run --project crypto_*/*/*/*.[ch] common/*.[ch] | grep Formatted && exit 1 || exit 0
.PHONY: tidy
tidy:
$(MAKE) do-tidy
@ -40,7 +32,6 @@ apply-tidy:
.PHONY: help
help:
@echo "make clean Clean up the bin/ folder"
@echo "make format Automatically formats all the source code"
@echo "make tidy SCHEME=scheme Runs the clang-tidy linter against SCHEME"
@echo "make apply-tidy SCHEME=scheme Tries to automatically fix the issues found by clang-tidy in SCHEME"
@echo "make tidy-all Runs the clang-tidy linter against all schemes"

View File

@ -92,6 +92,12 @@ class Implementation:
return '{}{}_'.format(self.scheme.namespace_prefix(),
self.name.upper()).replace('-', '')
def __str__(self):
return "{} implementation of {}".format(self.name, self.scheme.name)
def __repr__(self):
return "<Implementation({}, {})>".format(self.name, self.scheme.name)
class KEM(Scheme):

30
test/test_format.py Normal file
View File

@ -0,0 +1,30 @@
import os
from glob import glob
import pqclean
from helpers import run_subprocess
def test_formatting():
for scheme in pqclean.Scheme.all_schemes():
for implementation in scheme.implementations:
yield check_format, implementation
def check_format(implementation: pqclean.Implementation):
cfiles = glob(os.path.join(implementation.path(), '*.c'))
hfiles = glob(os.path.join(implementation.path(), '*.h'))
run_subprocess(['astyle',
'--dry-run',
'--options=../.astylerc',
*cfiles,
*hfiles])
if __name__ == "__main__":
try:
import nose2
nose2.main()
except ImportError:
import nose
nose.runmodule()