#16549: Make json.tool work again on Python 3 and add tests. Initial patch by Berker Peksag and Serhiy Storchaka.
This commit is contained in:
parent
d654dedbbb
commit
057bcb4c6c
|
@ -18,19 +18,21 @@ def main():
|
||||||
infile = sys.stdin
|
infile = sys.stdin
|
||||||
outfile = sys.stdout
|
outfile = sys.stdout
|
||||||
elif len(sys.argv) == 2:
|
elif len(sys.argv) == 2:
|
||||||
infile = open(sys.argv[1], 'rb')
|
infile = open(sys.argv[1], 'r')
|
||||||
outfile = sys.stdout
|
outfile = sys.stdout
|
||||||
elif len(sys.argv) == 3:
|
elif len(sys.argv) == 3:
|
||||||
infile = open(sys.argv[1], 'rb')
|
infile = open(sys.argv[1], 'r')
|
||||||
outfile = open(sys.argv[2], 'wb')
|
outfile = open(sys.argv[2], 'w')
|
||||||
else:
|
else:
|
||||||
raise SystemExit(sys.argv[0] + " [infile [outfile]]")
|
raise SystemExit(sys.argv[0] + " [infile [outfile]]")
|
||||||
try:
|
with infile:
|
||||||
obj = json.load(infile)
|
try:
|
||||||
except ValueError as e:
|
obj = json.load(infile)
|
||||||
raise SystemExit(e)
|
except ValueError as e:
|
||||||
json.dump(obj, outfile, sort_keys=True, indent=4)
|
raise SystemExit(e)
|
||||||
outfile.write('\n')
|
with outfile:
|
||||||
|
json.dump(obj, outfile, sort_keys=True, indent=4)
|
||||||
|
outfile.write('\n')
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
|
@ -0,0 +1,69 @@
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import textwrap
|
||||||
|
import unittest
|
||||||
|
import subprocess
|
||||||
|
from test import support
|
||||||
|
from test.script_helper import assert_python_ok
|
||||||
|
|
||||||
|
class TestTool(unittest.TestCase):
|
||||||
|
data = """
|
||||||
|
|
||||||
|
[["blorpie"],[ "whoops" ] , [
|
||||||
|
],\t"d-shtaeou",\r"d-nthiouh",
|
||||||
|
"i-vhbjkhnth", {"nifty":87}, {"morefield" :\tfalse,"field"
|
||||||
|
:"yes"} ]
|
||||||
|
"""
|
||||||
|
|
||||||
|
expect = textwrap.dedent("""\
|
||||||
|
[
|
||||||
|
[
|
||||||
|
"blorpie"
|
||||||
|
],
|
||||||
|
[
|
||||||
|
"whoops"
|
||||||
|
],
|
||||||
|
[],
|
||||||
|
"d-shtaeou",
|
||||||
|
"d-nthiouh",
|
||||||
|
"i-vhbjkhnth",
|
||||||
|
{
|
||||||
|
"nifty": 87
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"field": "yes",
|
||||||
|
"morefield": false
|
||||||
|
}
|
||||||
|
]
|
||||||
|
""")
|
||||||
|
|
||||||
|
def test_stdin_stdout(self):
|
||||||
|
with subprocess.Popen(
|
||||||
|
(sys.executable, '-m', 'json.tool'),
|
||||||
|
stdin=subprocess.PIPE, stdout=subprocess.PIPE) as proc:
|
||||||
|
out, err = proc.communicate(self.data.encode())
|
||||||
|
self.assertEqual(out, self.expect.encode())
|
||||||
|
self.assertEqual(err, None)
|
||||||
|
|
||||||
|
def _create_infile(self):
|
||||||
|
infile = support.TESTFN
|
||||||
|
with open(infile, "w") as fp:
|
||||||
|
self.addCleanup(os.remove, infile)
|
||||||
|
fp.write(self.data)
|
||||||
|
return infile
|
||||||
|
|
||||||
|
def test_infile_stdout(self):
|
||||||
|
infile = self._create_infile()
|
||||||
|
rc, out, err = assert_python_ok('-m', 'json.tool', infile)
|
||||||
|
self.assertEqual(out, self.expect.encode())
|
||||||
|
self.assertEqual(err, b'')
|
||||||
|
|
||||||
|
def test_infile_outfile(self):
|
||||||
|
infile = self._create_infile()
|
||||||
|
outfile = support.TESTFN + '.out'
|
||||||
|
rc, out, err = assert_python_ok('-m', 'json.tool', infile, outfile)
|
||||||
|
self.addCleanup(os.remove, outfile)
|
||||||
|
with open(outfile, "r") as fp:
|
||||||
|
self.assertEqual(fp.read(), self.expect)
|
||||||
|
self.assertEqual(out, b'')
|
||||||
|
self.assertEqual(err, b'')
|
|
@ -807,6 +807,7 @@ Alexandre Parenteau
|
||||||
Dan Parisien
|
Dan Parisien
|
||||||
William Park
|
William Park
|
||||||
Harri Pasanen
|
Harri Pasanen
|
||||||
|
Berker Peksag
|
||||||
Bo Peng
|
Bo Peng
|
||||||
Joe Peterson
|
Joe Peterson
|
||||||
Randy Pausch
|
Randy Pausch
|
||||||
|
|
|
@ -167,6 +167,9 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #16549: Make json.tool work again on Python 3 and add tests.
|
||||||
|
Initial patch by Berker Peksag and Serhiy Storchaka.
|
||||||
|
|
||||||
- Issue #12848: The pure Python pickle implementation now treats object
|
- Issue #12848: The pure Python pickle implementation now treats object
|
||||||
lengths as unsigned 32-bit integers, like the C implementation does.
|
lengths as unsigned 32-bit integers, like the C implementation does.
|
||||||
Patch by Serhiy Storchaka.
|
Patch by Serhiy Storchaka.
|
||||||
|
|
Loading…
Reference in New Issue