mirror of
https://github.com/wolfSSL/wolfssl.git
synced 2026-07-05 14:50:49 +02:00
Extend Ada bindings
Add Ada bindings for SHA-256, RSA sign/verify, and AES-CBC from wolfCrypt. Use XMALLOC/XFREE for dynamic allocation and add GNATprove ownership annotations to enable static leak detection. Refactor the Ada wrapper into a base package (wolfssl.ads) and a child package (wolfssl-full_runtime) to separate code that depends on Interfaces.C.Strings and GNAT.Sockets from zero-footprint-compatible code. Add standalone examples for SHA-256 hashing, RSA signature verification, and AES encryption under wrapper/Ada/examples/. Add AUnit test suites for SHA-256, RSA, and AES bindings under wrapper/Ada/tests/ with Valgrind suppressions and Alire integration. Move TLS client/server examples into wrapper/Ada/examples/src/ and update build files (default.gpr, examples.gpr, include.am) accordingly. Update CI (ada.yml) to build default.gpr, run AUnit tests, run the client-server examples, and run GNATprove. Co-authored-by: Joakim Strandberg <joakim@mequinox.se>
This commit is contained in:
+52
-13
@@ -15,20 +15,59 @@ jobs:
|
||||
steps:
|
||||
- uses: actions/checkout@master
|
||||
|
||||
- name: Install gnat
|
||||
- name: Install alire
|
||||
uses: alire-project/setup-alire@v5
|
||||
|
||||
- name: Install wolfssl Ada
|
||||
working-directory: ./wrapper/Ada
|
||||
run: alr install
|
||||
|
||||
- name: Build default.gpr
|
||||
working-directory: ./wrapper/Ada
|
||||
run: alr exec -- gprbuild default.gpr -j$(nproc)
|
||||
|
||||
- name: Run Ada wrapper tests
|
||||
working-directory: ./wrapper/Ada/tests
|
||||
run: alr run
|
||||
|
||||
- name: Run Ada examples
|
||||
id: examples
|
||||
working-directory: ./wrapper/Ada/examples
|
||||
run: |
|
||||
alr build
|
||||
|
||||
echo "Running sha256_main example..."
|
||||
alr run sha256_main
|
||||
|
||||
echo "Running aes_verify_main example..."
|
||||
alr run aes_verify_main
|
||||
|
||||
echo "Running rsa_verify_main example..."
|
||||
alr run rsa_verify_main
|
||||
|
||||
echo "Running TLS server/client example..."
|
||||
alr run tls_server_main &> server.log &
|
||||
SERVER_PID=$!
|
||||
sleep 1
|
||||
echo "test message" | alr run tls_client_main --args=127.0.0.1
|
||||
kill $SERVER_PID || true
|
||||
|
||||
- name: show errors
|
||||
if: ${{ failure() && steps.examples.outcome == 'failure' }}
|
||||
run: cat ./wrapper/Ada/examples/server.log
|
||||
|
||||
- name: Run Ada wrapper tests (valgrind)
|
||||
working-directory: ./wrapper/Ada/tests
|
||||
run: |
|
||||
sudo apt-get update
|
||||
sudo apt-get install -y gnat gprbuild
|
||||
sudo apt-get install -y valgrind
|
||||
valgrind --leak-check=full --error-exitcode=1 \
|
||||
--suppressions=valgrind.supp ./bin/tests
|
||||
|
||||
- name: Checkout wolfssl
|
||||
uses: actions/checkout@master
|
||||
with:
|
||||
repository: wolfssl/wolfssl
|
||||
path: wolfssl
|
||||
- name: Run gnatprove on wolfssl
|
||||
working-directory: ./wrapper/Ada
|
||||
run: alr gnatprove --level=4 -P wolfssl.gpr -j 0 --warnings=error --checks-as-errors --proof-warnings -U
|
||||
|
||||
- name: Build wolfssl Ada
|
||||
working-directory: ./wolfssl/wrapper/Ada
|
||||
run: |
|
||||
mkdir obj
|
||||
gprbuild default.gpr
|
||||
gprbuild examples.gpr
|
||||
- name: Run gnatprove on examples
|
||||
working-directory: ./wrapper/Ada/examples
|
||||
run: alr gnatprove --level=4 -P examples.gpr -j 0 --warnings=error --checks-as-errors --proof-warnings -U
|
||||
|
||||
Reference in New Issue
Block a user