Arthur de Jong

Open Source / Free Software developer

summaryrefslogtreecommitdiffstats
path: root/tests/test_se_personnummer.doctest
blob: 6c4932205f9571f6d6c9b0a941e161801bb47587 (plain)
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
test_se_personnummer.doctest - more detailed doctests for stdnum.se.personnummer module

Copyright (C) 2018 Ilya Vihtinsky
Copyright (C) 2018-2020 Arthur de Jong

This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.

This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Lesser General Public License for more details.

You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA


This file contains more detailed doctests for the stdnum.se.personnummer
module. It tries to cover more corner cases and detailed functionality that
is not really useful as module documentation.

>>> from stdnum.se import personnummer


Test for various formats and corner cases.

>>> personnummer.validate('8803200016')
'880320-0016'
>>> personnummer.validate('19670-19-9535')
Traceback (most recent call last):
    ...
InvalidLength: ...
>>> personnummer.validate('8803-20-0016')
'880320-0016'
>>> personnummer.validate('a' * 10)
Traceback (most recent call last):
    ...
InvalidFormat: ...
>>> personnummer.validate('a' * 11)
Traceback (most recent call last):
    ...
InvalidFormat: ...


These numbers should be detected as male or female.

>>> personnummer.get_gender('670919-9530')
'M'
>>> personnummer.get_gender('8803200420')
'F'


The birth date can be extracted from the number and invalid dates are
rejected.

>>> personnummer.get_birth_date('8803200420')
datetime.date(1988, 3, 20)
>>> personnummer.get_birth_date('191705120424')
datetime.date(1917, 5, 12)
>>> personnummer.get_birth_date('121212-1212')
datetime.date(2012, 12, 12)
>>> personnummer.get_birth_date('121212+1212')
datetime.date(1912, 12, 12)
>>> personnummer.get_birth_date('400606+5827')
datetime.date(1840, 6, 6)
>>> personnummer.validate('8899200425')
Traceback (most recent call last):
    ...
InvalidComponent: ...


These have been found online and should all be valid numbers.

>>> numbers = '''
...
... 670919-9530
... 811228-9874
... 880320-0016
... 880320-0057
... 8803200073
... 8803200099
... 8803200115
... 8803200131
... 8803200156
... 8803200172
... 8803200198
... 8803200420
...
... '''
>>> [x for x in numbers.splitlines() if x and not personnummer.is_valid(x)]
[]