#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:
Ezio Melotti 2012-11-29 02:15:18 +02:00
parent d654dedbbb
commit 057bcb4c6c
4 changed files with 84 additions and 9 deletions

View File

@ -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__':

View File

@ -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'')

View File

@ -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

View File

@ -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.