Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
82276964
Commit
82276964
authored
Jun 23, 2013
by
Łukasz Langa
Browse files
Options
Browse Files
Download
Plain Diff
Merged fix for issue #18260 from 3.3
parents
fcce2024
f9b4eb4d
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
65 additions
and
13 deletions
+65
-13
Lib/configparser.py
Lib/configparser.py
+2
-2
Lib/test/test_configparser.py
Lib/test/test_configparser.py
+63
-11
No files found.
Lib/configparser.py
View file @
82276964
...
...
@@ -191,7 +191,7 @@ class DuplicateSectionError(Error):
def
__init__
(
self
,
section
,
source
=
None
,
lineno
=
None
):
msg
=
[
repr
(
section
),
" already exists"
]
if
source
is
not
None
:
message
=
[
"While reading from "
,
source
]
message
=
[
"While reading from "
,
repr
(
source
)
]
if
lineno
is
not
None
:
message
.
append
(
" [line {0:2d}]"
.
format
(
lineno
))
message
.
append
(
": section "
)
...
...
@@ -217,7 +217,7 @@ class DuplicateOptionError(Error):
msg
=
[
repr
(
option
),
" in section "
,
repr
(
section
),
" already exists"
]
if
source
is
not
None
:
message
=
[
"While reading from "
,
source
]
message
=
[
"While reading from "
,
repr
(
source
)
]
if
lineno
is
not
None
:
message
.
append
(
" [line {0:2d}]"
.
format
(
lineno
))
message
.
append
(
": option "
)
...
...
Lib/test/test_configparser.py
View file @
82276964
...
...
@@ -626,15 +626,15 @@ boolean {0[0]} NO
oops{equals}this won't
"""
.
format
(
equals
=
self
.
delimiters
[
0
])),
source
=
'<foo-bar>'
)
e
=
cm
.
exception
self
.
assertEqual
(
str
(
e
),
"While reading from
<foo-bar> [line 5]:
"
"section 'Foo' already exists"
)
self
.
assertEqual
(
str
(
e
),
"While reading from
'<foo-bar>'
"
"
[line 5]:
section 'Foo' already exists"
)
self
.
assertEqual
(
e
.
args
,
(
"Foo"
,
'<foo-bar>'
,
5
))
with
self
.
assertRaises
(
configparser
.
DuplicateOptionError
)
as
cm
:
cf
.
read_dict
({
'Bar'
:
{
'opt'
:
'val'
,
'OPT'
:
'is really `opt`'
}})
e
=
cm
.
exception
self
.
assertEqual
(
str
(
e
),
"While reading from
<dict>: option 'opt'
"
"in section 'Bar' already exists"
)
self
.
assertEqual
(
str
(
e
),
"While reading from
'<dict>': option
"
"
'opt'
in section 'Bar' already exists"
)
self
.
assertEqual
(
e
.
args
,
(
"Bar"
,
"opt"
,
"<dict>"
,
None
))
def
test_write
(
self
):
...
...
@@ -1419,13 +1419,18 @@ def readline_generator(f):
class
ReadFileTestCase
(
unittest
.
TestCase
):
def
test_file
(
self
):
file_path
=
support
.
findfile
(
"cfgparser.1"
)
parser
=
configparser
.
ConfigParser
()
with
open
(
file_path
)
as
f
:
parser
.
read_file
(
f
)
self
.
assertIn
(
"Foo Bar"
,
parser
)
self
.
assertIn
(
"foo"
,
parser
[
"Foo Bar"
])
self
.
assertEqual
(
parser
[
"Foo Bar"
][
"foo"
],
"newbar"
)
file_paths
=
[
support
.
findfile
(
"cfgparser.1"
)]
try
:
file_paths
.
append
(
file_paths
[
0
].
encode
(
'utf8'
))
except
UnicodeEncodeError
:
pass
# unfortunately we can't test bytes on this path
for
file_path
in
file_paths
:
parser
=
configparser
.
ConfigParser
()
with
open
(
file_path
)
as
f
:
parser
.
read_file
(
f
)
self
.
assertIn
(
"Foo Bar"
,
parser
)
self
.
assertIn
(
"foo"
,
parser
[
"Foo Bar"
])
self
.
assertEqual
(
parser
[
"Foo Bar"
][
"foo"
],
"newbar"
)
def
test_iterable
(
self
):
lines
=
textwrap
.
dedent
(
"""
...
...
@@ -1447,6 +1452,53 @@ class ReadFileTestCase(unittest.TestCase):
self
.
assertIn
(
"foo"
,
parser
[
"Foo Bar"
])
self
.
assertEqual
(
parser
[
"Foo Bar"
][
"foo"
],
"newbar"
)
def
test_source_as_bytes
(
self
):
"""Issue #18260."""
lines
=
textwrap
.
dedent
(
"""
[badbad]
[badbad]"""
).
strip
().
split
(
'
\
n
'
)
parser
=
configparser
.
ConfigParser
()
with
self
.
assertRaises
(
configparser
.
DuplicateSectionError
)
as
dse
:
parser
.
read_file
(
lines
,
source
=
b"badbad"
)
self
.
assertEqual
(
str
(
dse
.
exception
),
"While reading from b'badbad' [line 2]: section 'badbad' "
"already exists"
)
lines
=
textwrap
.
dedent
(
"""
[badbad]
bad = bad
bad = bad"""
).
strip
().
split
(
'
\
n
'
)
parser
=
configparser
.
ConfigParser
()
with
self
.
assertRaises
(
configparser
.
DuplicateOptionError
)
as
dse
:
parser
.
read_file
(
lines
,
source
=
b"badbad"
)
self
.
assertEqual
(
str
(
dse
.
exception
),
"While reading from b'badbad' [line 3]: option 'bad' in section "
"'badbad' already exists"
)
lines
=
textwrap
.
dedent
(
"""
[badbad]
= bad"""
).
strip
().
split
(
'
\
n
'
)
parser
=
configparser
.
ConfigParser
()
with
self
.
assertRaises
(
configparser
.
ParsingError
)
as
dse
:
parser
.
read_file
(
lines
,
source
=
b"badbad"
)
self
.
assertEqual
(
str
(
dse
.
exception
),
"Source contains parsing errors: b'badbad'
\
n
\
t
[line 2]: '= bad'"
)
lines
=
textwrap
.
dedent
(
"""
[badbad
bad = bad"""
).
strip
().
split
(
'
\
n
'
)
parser
=
configparser
.
ConfigParser
()
with
self
.
assertRaises
(
configparser
.
MissingSectionHeaderError
)
as
dse
:
parser
.
read_file
(
lines
,
source
=
b"badbad"
)
self
.
assertEqual
(
str
(
dse
.
exception
),
"File contains no section headers.
\
n
file: b'badbad', line: 1
\
n
"
"'[badbad'"
)
class
CoverageOneHundredTestCase
(
unittest
.
TestCase
):
"""Covers edge cases in the codebase."""
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment