| 12
 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)]
[]
 |