File: test_credentials.py

package info (click to toggle)
aiocoap 0.4.14-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 1,756 kB
  • sloc: python: 16,846; makefile: 23; sh: 9
file content (71 lines) | stat: -rw-r--r-- 2,450 bytes parent folder | download | duplicates (2)
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
# SPDX-FileCopyrightText: Christian Amsüss and the aiocoap contributors
#
# SPDX-License-Identifier: MIT

"""Tests for the aiocoap.credentials module. This does not test the
functionality of the ciphers, just the syntax of loading them."""

import unittest

from aiocoap import Message, GET
from aiocoap.credentials import CredentialsMap, DTLS
import aiocoap.defaults


class TestCredentialsLoad(unittest.TestCase):
    def test_load_empty(self):
        raw = {}
        m = CredentialsMap()
        m.load_from_dict(raw)
        self.assertEqual(type(m), CredentialsMap)
        self.assertEqual(len(m), 0)

    def test_dtls(self):
        raw = {
            "coaps://some-dtls-host/*": {
                "dtls": {
                    "psk": {"hex": "73-65-63-72-65-74-50-53-4b"},
                    "client-identity": b"Client_identity",
                }
            }
        }

        m = CredentialsMap()
        m.load_from_dict(raw)
        # note we can use the slash-free version here and still get the result
        # for //some-host/* due to the URI normalization rules
        message = Message(code=GET, uri="coaps://some-dtls-host")
        secmatch = m.credentials_from_request(message)
        self.assertEqual(type(secmatch), DTLS)
        self.assertEqual(secmatch.psk, b"secretPSK")
        self.assertEqual(secmatch.client_identity, b"Client_identity")

    @unittest.skipIf(
        aiocoap.defaults.oscore_missing_modules(),
        "Modules missing for loading OSCORE contexts: %s"
        % (aiocoap.defaults.oscore_missing_modules(),),
    )
    def test_oscore_filebased(self):
        from aiocoap.oscore import FilesystemSecurityContext

        raw = {
            "coap://some-oscore-host/*": {
                "oscore": {
                    "basedir": __file__.replace(
                        "test_credentials.py", "test_credentials_oscore_context/"
                    )
                }
            },
            "coaps://some-dtls-host/*": {
                "dtls": {
                    "psk": {"hex": "73-65-63-72-65-74-50-53-4b"},
                    "client-identity": b"Client_identity",
                }
            },
        }

        m = CredentialsMap()
        m.load_from_dict(raw)
        message = Message(code=GET, uri="coap://some-oscore-host/.well-known/core")
        secmatch = m.credentials_from_request(message)
        self.assertEqual(type(secmatch), FilesystemSecurityContext)