Skip to content

Commit f7bfac4

Browse files
[3.11] gh-109396: Fix test_socket.test_hmac_sha1() in FIPS mode (GH-109423) (#109427)
gh-109396: Fix test_socket.test_hmac_sha1() in FIPS mode (GH-109423) Use a longer key: FIPS mode requires at least of at least 112 bits. The previous key was only 32 bits. (cherry picked from commit e091b9f) Co-authored-by: Victor Stinner <[email protected]>
1 parent 8e23cd0 commit f7bfac4

File tree

2 files changed

+10
-3
lines changed

2 files changed

+10
-3
lines changed

Lib/test/test_socket.py

+7-3
Original file line numberDiff line numberDiff line change
@@ -6357,12 +6357,16 @@ def test_sha256(self):
63576357
self.assertEqual(op.recv(512), expected)
63586358

63596359
def test_hmac_sha1(self):
6360-
expected = bytes.fromhex("effcdf6ae5eb2fa2d27416d5f184df9c259a7c79")
6360+
# gh-109396: In FIPS mode, Linux 6.5 requires a key
6361+
# of at least 112 bits. Use a key of 152 bits.
6362+
key = b"Python loves AF_ALG"
6363+
data = b"what do ya want for nothing?"
6364+
expected = bytes.fromhex("193dbb43c6297b47ea6277ec0ce67119a3f3aa66")
63616365
with self.create_alg('hash', 'hmac(sha1)') as algo:
6362-
algo.setsockopt(socket.SOL_ALG, socket.ALG_SET_KEY, b"Jefe")
6366+
algo.setsockopt(socket.SOL_ALG, socket.ALG_SET_KEY, key)
63636367
op, _ = algo.accept()
63646368
with op:
6365-
op.sendall(b"what do ya want for nothing?")
6369+
op.sendall(data)
63666370
self.assertEqual(op.recv(512), expected)
63676371

63686372
# Although it should work with 3.19 and newer the test blocks on
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
Fix ``test_socket.test_hmac_sha1()`` in FIPS mode. Use a longer key: FIPS
2+
mode requires at least of at least 112 bits. The previous key was only 32
3+
bits. Patch by Victor Stinner.

0 commit comments

Comments
 (0)