-
Notifications
You must be signed in to change notification settings - Fork 89
119 lines (105 loc) · 3.45 KB
/
kyber.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
name: Kyber Tests
on:
push:
branches: [ '*' ]
pull_request:
branches: [ '*' ]
jobs:
build_liboqs:
name: Build liboqs
runs-on: ubuntu-latest
timeout-minutes: 4
steps:
- name: Checking cache for liboqs
uses: actions/cache/restore@v4
id: cache
with:
path: ${{ github.workspace }}/opt/liboqs/
key: wolfssh-liboqs-${{ runner.os }}
lookup-only: true
- name: Checkout liboqs
if: steps.cache.output.cache-hit != 'true'
uses: actions/checkout@v4
with:
repository: open-quantum-safe/liboqs
ref: 0.10.0
path: liboqs
- name: Build and install liboqs
if: steps.cache.output.cache-hit != 'true'
working-directory: liboqs
run: |
mkdir build
cd build
cmake -DCMAKE_INSTALL_PREFIX=${{ github.workspace }}/opt/liboqs -DOQS_MINIMAL_BUILD=KEM_kyber_512 -DOQS_USE_OPENSSL=0 ..
make
make install
- name: Stash liboqs in cache
if: steps.cache.output.cache-hit != 'true'
uses: actions/cache/save@v4
with:
path: ${{ github.workspace }}/opt/liboqs/
key: wolfssh-liboqs-${{ runner.os }}
build_wolfssl:
name: Build wolfssl
runs-on: ubuntu-latest
timeout-minutes: 4
steps:
- name: Checking cache for wolfssl
uses: actions/cache/restore@v4
id: cache
with:
path: ${{ github.workspace }}/opt/wolfssl/
key: wolfssh-wolfssl-${{ runner.os }}
lookup-only: true
- name: Checkout wolfssl
if: steps.cache.output.cache-hit != 'true'
uses: actions/checkout@v4
with:
repository: wolfssl/wolfssl
ref: 5.7.0-stable
path: wolfssl
- name: Build and install wolfssl
if: steps.cache.output.cache-hit != 'true'
working-directory: wolfssl
run: |
autoreconf -ivf
./configure --prefix=${{ github.workspace }}/opt/wolfssl --enable-wolfssh --enable-cryptonly --disable-examples --disable-crypttests
make
make install
- name: Stash wolfssl in cache
if: steps.cache.output.cache-hit != 'true'
uses: actions/cache/save@v3
with:
path: ${{ github.workspace }}/opt/wolfssl/
key: wolfssh-wolfssl-${{ runner.os }}
build_wolfssh:
name: Build wolfssh
runs-on: ubuntu-latest
timeout-minutes: 4
needs: [build_wolfssl, build_liboqs]
steps:
- name: Checking cache for liboqs
uses: actions/cache/restore@v4
id: cache
with:
path: opt/liboqs
key: wolfssh-liboqs-${{ runner.os }}
fail-on-cache-miss: true
- name: Checking cache for wolfssl
uses: actions/cache/restore@v4
id: cache
with:
path: opt/wolfssl
key: wolfssh-wolfssl-${{ runner.os }}
fail-on-cache-miss: true
- name: Install wolfSSH
run: git clone --depth 1 "https://github.com/wolfssl/wolfssh"
- name: Build wolfSSH
working-directory: wolfssh
run: |
autoreconf -ivf
./configure --with-liboqs LDFLAGS="-L${{ github.workspace }}/opt/liboqs/lib -L${{ github.workspace }}/opt/wolfssl/lib CPPFLAGS="-I${{ github.workspace }}/opt/liboqs/include -I${{ github.workspace }}/opt/wolfssl/include"
make
- name: Run wolfssh tests
working-directory: wolfssh
run: make check