#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
|
||||
outfile = sys.stdout
|
||||
elif len(sys.argv) == 2:
|
||||
infile = open(sys.argv[1], 'rb')
|
||||
infile = open(sys.argv[1], 'r')
|
||||
outfile = sys.stdout
|
||||
elif len(sys.argv) == 3:
|
||||
infile = open(sys.argv[1], 'rb')
|
||||
outfile = open(sys.argv[2], 'wb')
|
||||
infile = open(sys.argv[1], 'r')
|
||||
outfile = open(sys.argv[2], 'w')
|
||||
else:
|
||||
raise SystemExit(sys.argv[0] + " [infile [outfile]]")
|
||||
try:
|
||||
obj = json.load(infile)
|
||||
except ValueError as e:
|
||||
raise SystemExit(e)
|
||||
json.dump(obj, outfile, sort_keys=True, indent=4)
|
||||
outfile.write('\n')
|
||||
with infile:
|
||||
try:
|
||||
obj = json.load(infile)
|
||||
except ValueError as e:
|
||||
raise SystemExit(e)
|
||||
with outfile:
|
||||
json.dump(obj, outfile, sort_keys=True, indent=4)
|
||||
outfile.write('\n')
|
||||
|
||||
|
||||
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
|
||||
William Park
|
||||
Harri Pasanen
|
||||
Berker Peksag
|
||||
Bo Peng
|
||||
Joe Peterson
|
||||
Randy Pausch
|
||||
|
|
|
@ -167,6 +167,9 @@ Core and Builtins
|
|||
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
|
||||
lengths as unsigned 32-bit integers, like the C implementation does.
|
||||
Patch by Serhiy Storchaka.
|
||||
|
|
Loading…
Reference in New Issue