summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_json/test_tool.py
diff options
context:
space:
mode:
authorBerker Peksag <berker.peksag@gmail.com>2014-11-10 07:56:54 (GMT)
committerBerker Peksag <berker.peksag@gmail.com>2014-11-10 07:56:54 (GMT)
commit39e4c4d873927b902c53aeb0e2e15c12d2678e1b (patch)
tree8fc68f205c657f36ec637d658cc1b1a1aeae38fd /Lib/test/test_json/test_tool.py
parentffd842e1d6736d48d45e741e2006a181c9ad4272 (diff)
downloadcpython-39e4c4d873927b902c53aeb0e2e15c12d2678e1b.zip
cpython-39e4c4d873927b902c53aeb0e2e15c12d2678e1b.tar.gz
cpython-39e4c4d873927b902c53aeb0e2e15c12d2678e1b.tar.bz2
Issue #21650: Add an `--sort-keys` option to json.tool CLI.
Diffstat (limited to 'Lib/test/test_json/test_tool.py')
-rw-r--r--Lib/test/test_json/test_tool.py33
1 files changed, 32 insertions, 1 deletions
diff --git a/Lib/test/test_json/test_tool.py b/Lib/test/test_json/test_tool.py
index 5484a8a..bd63e2b 100644
--- a/Lib/test/test_json/test_tool.py
+++ b/Lib/test/test_json/test_tool.py
@@ -6,6 +6,7 @@ import subprocess
from test import support
from test.script_helper import assert_python_ok
+
class TestTool(unittest.TestCase):
data = """
@@ -15,7 +16,7 @@ class TestTool(unittest.TestCase):
:"yes"} ]
"""
- expect = textwrap.dedent("""\
+ expect_without_sort_keys = textwrap.dedent("""\
[
[
"blorpie"
@@ -37,6 +38,28 @@ class TestTool(unittest.TestCase):
]
""")
+ expect = textwrap.dedent("""\
+ [
+ [
+ "blorpie"
+ ],
+ [
+ "whoops"
+ ],
+ [],
+ "d-shtaeou",
+ "d-nthiouh",
+ "i-vhbjkhnth",
+ {
+ "nifty": 87
+ },
+ {
+ "morefield": false,
+ "field": "yes"
+ }
+ ]
+ """)
+
def test_stdin_stdout(self):
with subprocess.Popen(
(sys.executable, '-m', 'json.tool'),
@@ -75,3 +98,11 @@ class TestTool(unittest.TestCase):
self.assertEqual(rc, 0)
self.assertTrue(out.startswith(b'usage: '))
self.assertEqual(err, b'')
+
+ def test_sort_keys_flag(self):
+ infile = self._create_infile()
+ rc, out, err = assert_python_ok('-m', 'json.tool', '--sort-keys', infile)
+ self.assertEqual(rc, 0)
+ self.assertEqual(out.splitlines(),
+ self.expect_without_sort_keys.encode().splitlines())
+ self.assertEqual(err, b'')