changeset: 102918:685f32972c11 parent: 102916:1c38457da5a1 parent: 102917:81f614dd8136 user: Berker Peksag date: Fri Aug 26 22:08:51 2016 +0300 files: Misc/NEWS Modules/_sqlite/connection.c description: Issue #10513: Merge from 3.5 diff -r 1c38457da5a1 -r 685f32972c11 Lib/sqlite3/test/regression.py --- a/Lib/sqlite3/test/regression.py Thu Aug 25 21:12:16 2016 -0700 +++ b/Lib/sqlite3/test/regression.py Fri Aug 26 22:08:51 2016 +0300 @@ -322,6 +322,37 @@ self.assertRaises(ValueError, cur.execute, " \0select 2") self.assertRaises(ValueError, cur.execute, "select 2\0") + def CheckCommitCursorReset(self): + """ + Connection.commit() did reset cursors, which made sqlite3 + to return rows multiple times when fetched from cursors + after commit. See issues 10513 and 23129 for details. + """ + con = sqlite.connect(":memory:") + con.executescript(""" + create table t(c); + create table t2(c); + insert into t values(0); + insert into t values(1); + insert into t values(2); + """) + + self.assertEqual(con.isolation_level, "") + + counter = 0 + for i, row in enumerate(con.execute("select c from t")): + with self.subTest(i=i, row=row): + con.execute("insert into t2(c) values (?)", (i,)) + con.commit() + if counter == 0: + self.assertEqual(row[0], 0) + elif counter == 1: + self.assertEqual(row[0], 1) + elif counter == 2: + self.assertEqual(row[0], 2) + counter += 1 + self.assertEqual(counter, 3, "should have returned exactly three rows") + def suite(): regression_suite = unittest.makeSuite(RegressionTests, "Check") diff -r 1c38457da5a1 -r 685f32972c11 Misc/NEWS --- a/Misc/NEWS Thu Aug 25 21:12:16 2016 -0700 +++ b/Misc/NEWS Fri Aug 26 22:08:51 2016 +0300 @@ -46,6 +46,9 @@ Library ------- +- Issue #10513: Fix a regression in Connection.commit(). Statements should + not be reset after a commit. + - Issue #12319: Chunked transfer encoding support added to http.client.HTTPConnection requests. The urllib.request.AbstractHTTPHandler class does not enforce a Content-Length diff -r 1c38457da5a1 -r 685f32972c11 Modules/_sqlite/connection.c --- a/Modules/_sqlite/connection.c Thu Aug 25 21:12:16 2016 -0700 +++ b/Modules/_sqlite/connection.c Fri Aug 26 22:08:51 2016 +0300 @@ -425,7 +425,6 @@ } if (self->inTransaction) { - pysqlite_do_all_statements(self, ACTION_RESET, 0); Py_BEGIN_ALLOW_THREADS rc = sqlite3_prepare(self->db, "COMMIT", -1, &statement, &tail);