Commit b644bd6
authored
Make the project buildable again & enable multiplatform tests (#202)
For context: I'm the maintainer of
[pyHanko](https://github.com/MatthiasValvekens/pyHanko), which has had
an optional dependency on python-pkcs11 for PKCS#11 support for 4+ years
at this point.
I was led down this rabbit hole by a user report complaining about the
fact that the current latest release (from 2020, prior to this project
moving to the pyauth org) isn't installable on Windows with Python 3.12
or greater (MatthiasValvekens/pyHanko#558, #197).
While I'm not much of a Windows dev, this issue seemed fairly obvious to
fix, so I set out to do so, only to discover that the isolation enforced
by the typical modern Python build flow (in particular, when running `uv
build`) is fundamentally at odds with the way this project was
historically structured/built. So besides fixing #197, I also addressed
a number of other issues:
- Restructured the Cython build to actually work when executed from a
build frontend (this included fixing the source distribution post-`uv`
migration)
- Refactored the Cython layer to remove deprecated constructs
(conditional compilation, Cython-level `include`s, ...).
- The only platform-dependent logic was in the code that loads the
PKCS#11 library, so I moved that to a `load_module.c` file that exposes
a common C interface with platform-dependent implementations.
- I had to consolidate the Cython files a bit to be compliant with the
"include-free" style while still building everything as a single C
extension.
- Eliminated the dependency on `oscrypto` in the tests, which in turn
gets rid of the hard dependency on OpenSSL 1.1.x, which in turn also
means that all the hacks in the GitHub workflow for tests could be
removed as well.
I'm upstreaming my changes in the hope that it'll get this project into
a state where new releases can be cut more easily again, since I rely on
this library quite heavily. I'd like to avoid having to fork it if
that's at all avoidable...
-----
PS: Unsolicited opinion about testing: For a project like this, IMO
there's also no way around setting up a multiplatform test matrix
(including at least one linux/windows/macOS variant each). Ideally that
would include testing against actual HSMs, but operating a hardware test
bench isn't exactly trivial or cheap for an OSS project, so the fact
that this isn't being done is certainly understandable. Funnily enough
the readme still claims that there is CI running against real hardware,
but that hasn't been the case for several years at this point ;). I have
several devices lying around at home that I can test with, but I'm
currently limited to manual testing on that front.
PPS: With these changes, the `cibuildwheel` action appears to work, by
the way.
---
EDIT: I added `windows-latest` and `macos-latest` to the CI test matrix
now :).1 parent f330501 commit b644bd6
File tree
14 files changed
+1240
-956
lines changed- .github/workflows
- extern
- pkcs11
- tests
14 files changed
+1240
-956
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
| 3 | + | |
| 4 | + | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
10 | 11 | | |
11 | | - | |
12 | | - | |
13 | | - | |
14 | | - | |
15 | | - | |
| 12 | + | |
16 | 13 | | |
17 | 14 | | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
18 | 19 | | |
19 | 20 | | |
20 | 21 | | |
21 | 22 | | |
22 | 23 | | |
23 | | - | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
24 | 27 | | |
25 | 28 | | |
26 | 29 | | |
| |||
30 | 33 | | |
31 | 34 | | |
32 | 35 | | |
33 | | - | |
34 | | - | |
| 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 | + | |
35 | 64 | | |
36 | 65 | | |
37 | 66 | | |
38 | 67 | | |
39 | 68 | | |
40 | | - | |
41 | 69 | | |
42 | 70 | | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
48 | | - | |
49 | | - | |
50 | | - | |
51 | | - | |
52 | | - | |
53 | | - | |
54 | | - | |
55 | | - | |
56 | 71 | | |
57 | 72 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 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 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
This file was deleted.
0 commit comments