mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 18:22:59 +02:00 
			
		
		
		
	* fix(Data::AbstracSessionImpl): protect autocommit feature handlers #4261 * chore(CI): re-enable mysql * MySQL SessionImpl: make sure autocommit mode is on when session is openend or reset. * PostgreSQL SessionImpl: reuse autocommit flag of AbstractSessionImpl. * Github workflow: re-activated linux-gcc-make-postgres * Fixed indentation in ci.yml * Fix for DataTest SQLExecutor: use connector * Data::Session: when parser is not used and autocommit mode is off, assume any SQL statement begins a transaction. * PostgreSQL: don't use SQL parser (it currently cannot handle placeholders). * PostgreSQL: added test sessionTransactionNoAutoCommit * PostgreSQL test suite: removed reference to generic SQLExecutor * PostgreSQL: fixes for sessionTransactionNoAutoCommit. * MySQL: added test sessionPoolAndUnicode (from #2801) * Fixed #define in sql-parser * Data generic testsuite: support numbered placeholders * PostgreSQL test suite: added missing include directory to Makefile. * Attempt to fix PostgreSQL Makefiles * PostgreSQL testsuite: added include path to Makefile * PostgreSQL testsuite: added PocoDataTest library to Makefile * DataTest SQLExecutor::formatSQL: don't use string_view * PostgreSQL test suite: delegated most tests to Poco::Data::Test * Makefile: added dependencies on Data-Tests * Weaken assumptions about async in generic transaction tests * Makefile: added dependency for Prometheus samples * Fix deadlock in DataTest SQLExecutor * PostgreSQL tests SQLExecutor: cleanup * feat(Data::AbstractSessionImpl): add autoCommit property and tests #4261 * Brought MySQL backend in line with _autoCommit flag of AbstractSessionImpl. --------- Co-authored-by: Friedrich Wilckens <frwilckens@gmail.com> Co-authored-by: Friedrich Wilckens <friedrich.wilckens@ingramcontent.com>
This commit is contained in:
		 Aleksandar Fabijanic
					Aleksandar Fabijanic
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							80cde9e3e6
						
					
				
				
					commit
					86084cb7b2
				
			| @@ -727,6 +727,15 @@ void MySQLTest::testTupleWithNullable() | ||||
| } | ||||
|  | ||||
|  | ||||
| void MySQLTest::testSessionPoolAndUnicode() | ||||
| { | ||||
| 	if (!_pSession) fail ("Test not available."); | ||||
|  | ||||
| 	recreateStringsTable(); | ||||
| 	_pExecutor->sessionPoolAndUnicode(_dbConnString); | ||||
| } | ||||
|  | ||||
|  | ||||
| void MySQLTest::dropTable(const std::string& tableName) | ||||
| { | ||||
| 	try { *_pSession << format("DROP TABLE IF EXISTS %s", tableName), now; } | ||||
| @@ -993,6 +1002,6 @@ CppUnit::Test* MySQLTest::suite() | ||||
| 	CppUnit_addTest(pSuite, MySQLTest, testSessionTransaction); | ||||
| 	CppUnit_addTest(pSuite, MySQLTest, testTransaction); | ||||
| 	CppUnit_addTest(pSuite, MySQLTest, testReconnect); | ||||
|  | ||||
| 	CppUnit_addTest(pSuite, MySQLTest, testSessionPoolAndUnicode); | ||||
| 	return pSuite; | ||||
| } | ||||
|   | ||||
| @@ -107,6 +107,7 @@ public: | ||||
| 	void testTransaction(); | ||||
|  | ||||
| 	void testReconnect(); | ||||
| 	void testSessionPoolAndUnicode(); | ||||
|  | ||||
| 	void setUp(); | ||||
| 	void tearDown(); | ||||
|   | ||||
| @@ -21,6 +21,7 @@ | ||||
| #include "Poco/Data/Time.h" | ||||
| #include "Poco/Data/StatementImpl.h" | ||||
| #include "Poco/Data/RecordSet.h" | ||||
| #include "Poco/Data/SessionPool.h" | ||||
| #include "Poco/Data/Transaction.h" | ||||
| #include "Poco/Data/MySQL/Connector.h" | ||||
| #include "Poco/Data/MySQL/MySQLException.h" | ||||
| @@ -1372,7 +1373,7 @@ void SQLExecutor::timestamp() | ||||
| 	std::string firstName("Simpson"); | ||||
| 	std::string address("Springfield"); | ||||
| 	DateTime birthday(1980, 4, 1, 5, 45, 12, 354, 879); | ||||
| 	 | ||||
|  | ||||
| 	int count = 0; | ||||
| 	try { *_pSession << "INSERT INTO Person VALUES (?,?,?,?)", use(lastName), use(firstName), use(address), use(birthday), now; } | ||||
| 	catch(ConnectionException& ce){ std::cout << ce.displayText() << std::endl; fail (funct); } | ||||
| @@ -1381,14 +1382,14 @@ void SQLExecutor::timestamp() | ||||
| 	catch(ConnectionException& ce){ std::cout << ce.displayText() << std::endl; fail (funct); } | ||||
| 	catch(StatementException& se){ std::cout << se.displayText() << std::endl; fail (funct); } | ||||
| 	assertTrue (count == 1); | ||||
| 	 | ||||
|  | ||||
| 	DateTime bd; | ||||
| 	assertTrue (bd != birthday); | ||||
| 	try { *_pSession << "SELECT Birthday FROM Person", into(bd), now; } | ||||
| 	catch(ConnectionException& ce){ std::cout << ce.displayText() << std::endl; fail (funct); } | ||||
| 	catch(StatementException& se){ std::cout << se.displayText() << std::endl; fail (funct); } | ||||
| 	assertTrue (bd == birthday); | ||||
| 	 | ||||
|  | ||||
| 	std::cout << std::endl << RecordSet(*_pSession, "SELECT * FROM Person"); | ||||
| } | ||||
|  | ||||
| @@ -2066,3 +2067,31 @@ void SQLExecutor::reconnect() | ||||
| 	assertTrue (count == age); | ||||
| 	assertTrue (_pSession->isConnected()); | ||||
| } | ||||
|  | ||||
|  | ||||
| void SQLExecutor::sessionPoolAndUnicode(const std::string& connString) | ||||
| { | ||||
| 	std::string funct = "unicode()"; | ||||
| 	std::string text = "ěščřžťďůň"; | ||||
| 	std::string text2; | ||||
|  | ||||
| 	// Test uses session from SessionPool instead of _pSession to prove session | ||||
| 	// obtained and returned into pool is valid. | ||||
|  | ||||
| 	// Min/Max 1 session - ensures that when get() is called, same session should be returned | ||||
| 	Poco::SharedPtr<Poco::Data::SessionPool> sp = new Poco::Data::SessionPool(MySQL::Connector::KEY, connString, 1, 1); | ||||
|  | ||||
| 	{ | ||||
| 		Poco::Data::Session session = sp->get(); | ||||
| 		try { session << "INSERT INTO Strings VALUES (?)", use(text), now; } | ||||
| 		catch(ConnectionException& ce){ std::cout << ce.displayText() << std::endl; fail (funct); } | ||||
| 		catch(StatementException& se){ std::cout << se.displayText() << std::endl; fail (funct); } | ||||
| 	} // parentheses to ensure session is returned into pool | ||||
|  | ||||
| 	Poco::Data::Session session2 = sp->get(); | ||||
| 	try { session2 << "SELECT str FROM Strings", into(text2), now; } | ||||
| 	catch(ConnectionException& ce){ std::cout << ce.displayText() << std::endl; fail (funct); } | ||||
| 	catch(StatementException& se){ std::cout << se.displayText() << std::endl; fail (funct); } | ||||
|  | ||||
| 	assertTrue (text == text2); | ||||
| } | ||||
|   | ||||
| @@ -88,7 +88,7 @@ public: | ||||
| 	void longText(); | ||||
| #ifdef POCO_MYSQL_JSON | ||||
| 	void json(); | ||||
| #endif	 | ||||
| #endif | ||||
| 	void unsignedInts(); | ||||
| 	void floats(); | ||||
| 	void doubles(); | ||||
| @@ -103,6 +103,7 @@ public: | ||||
| 	void transaction(const std::string& connect); | ||||
|  | ||||
| 	void reconnect(); | ||||
| 	void sessionPoolAndUnicode(const std::string& connString); | ||||
|  | ||||
| private: | ||||
| 	void setTransactionIsolation(Poco::Data::Session& session, Poco::UInt32 ti); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user