summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2023-08-29 18:30:23 (GMT)
committerGitHub <noreply@github.com>2023-08-29 18:30:23 (GMT)
commit4afc5d87161c7f079600380b3ef4579d9102ba97 (patch)
tree223aa064ad396b21f1b3c9a311dbac63339bc65e
parent1478a386e6540a7db46a20a45dd6b137bd30b585 (diff)
downloadcpython-4afc5d87161c7f079600380b3ef4579d9102ba97.zip
cpython-4afc5d87161c7f079600380b3ef4579d9102ba97.tar.gz
cpython-4afc5d87161c7f079600380b3ef4579d9102ba97.tar.bz2
[3.12] gh-108617: Extend interactive session tests for sqlite3 (GH-108556) (#108626)
gh-108617: Extend interactive session tests for sqlite3 (GH-108556) (cherry picked from commit ecb2bf02a4a564b638f756ce6e644ec17b6edf16) Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
-rw-r--r--Lib/test/test_sqlite3/test_cli.py38
1 files changed, 32 insertions, 6 deletions
diff --git a/Lib/test/test_sqlite3/test_cli.py b/Lib/test/test_sqlite3/test_cli.py
index e681f5c..303f9e0 100644
--- a/Lib/test/test_sqlite3/test_cli.py
+++ b/Lib/test/test_sqlite3/test_cli.py
@@ -87,42 +87,68 @@ class InteractiveSession(unittest.TestCase):
def test_interact(self):
out, err = self.run_cli()
self.assertIn(self.MEMORY_DB_MSG, err)
- self.assertIn(self.PS1, out)
+ self.assertIn(self.MEMORY_DB_MSG, err)
+ self.assertTrue(out.endswith(self.PS1))
+ self.assertEqual(out.count(self.PS1), 1)
+ self.assertEqual(out.count(self.PS2), 0)
def test_interact_quit(self):
out, err = self.run_cli(commands=(".quit",))
- self.assertIn(self.PS1, out)
+ self.assertIn(self.MEMORY_DB_MSG, err)
+ self.assertTrue(out.endswith(self.PS1))
+ self.assertEqual(out.count(self.PS1), 1)
+ self.assertEqual(out.count(self.PS2), 0)
def test_interact_version(self):
out, err = self.run_cli(commands=(".version",))
self.assertIn(self.MEMORY_DB_MSG, err)
+ self.assertIn(sqlite3.sqlite_version + "\n", out)
+ self.assertTrue(out.endswith(self.PS1))
+ self.assertEqual(out.count(self.PS1), 2)
+ self.assertEqual(out.count(self.PS2), 0)
self.assertIn(sqlite3.sqlite_version, out)
def test_interact_valid_sql(self):
out, err = self.run_cli(commands=("SELECT 1;",))
self.assertIn(self.MEMORY_DB_MSG, err)
- self.assertIn("(1,)", out)
+ self.assertIn("(1,)\n", out)
+ self.assertTrue(out.endswith(self.PS1))
+ self.assertEqual(out.count(self.PS1), 2)
+ self.assertEqual(out.count(self.PS2), 0)
+
+ def test_interact_incomplete_multiline_sql(self):
+ out, err = self.run_cli(commands=("SELECT 1",))
+ self.assertIn(self.MEMORY_DB_MSG, err)
+ self.assertTrue(out.endswith(self.PS2))
+ self.assertEqual(out.count(self.PS1), 1)
+ self.assertEqual(out.count(self.PS2), 1)
def test_interact_valid_multiline_sql(self):
out, err = self.run_cli(commands=("SELECT 1\n;",))
self.assertIn(self.MEMORY_DB_MSG, err)
self.assertIn(self.PS2, out)
- self.assertIn("(1,)", out)
+ self.assertIn("(1,)\n", out)
+ self.assertTrue(out.endswith(self.PS1))
+ self.assertEqual(out.count(self.PS1), 2)
+ self.assertEqual(out.count(self.PS2), 1)
def test_interact_invalid_sql(self):
out, err = self.run_cli(commands=("sel;",))
self.assertIn(self.MEMORY_DB_MSG, err)
self.assertIn("OperationalError (SQLITE_ERROR)", err)
+ self.assertTrue(out.endswith(self.PS1))
+ self.assertEqual(out.count(self.PS1), 2)
+ self.assertEqual(out.count(self.PS2), 0)
def test_interact_on_disk_file(self):
self.addCleanup(unlink, TESTFN)
out, err = self.run_cli(TESTFN, commands=("CREATE TABLE t(t);",))
self.assertIn(TESTFN, err)
- self.assertIn(self.PS1, out)
+ self.assertTrue(out.endswith(self.PS1))
out, _ = self.run_cli(TESTFN, commands=("SELECT count(t) FROM t;",))
- self.assertIn("(0,)", out)
+ self.assertIn("(0,)\n", out)
if __name__ == "__main__":