fetchField(); if (Environment::checkMemoryLimit($max_allowed_packet + (16 * 1024 * 1024))) { $long_name = str_repeat('a', $max_allowed_packet + 1); try { db_query('SELECT name FROM {test} WHERE name = :name', [':name' => $long_name]); $this->fail("An exception should be thrown for queries larger than 'max_allowed_packet'"); } catch (DatabaseException $e) { // Close and re-open the connection. Otherwise we will run into error // 2006 "MySQL server had gone away" afterwards. Database::closeConnection(); Database::getConnection(); $this->assertEqual($e->getPrevious()->errorInfo[1], 1153, "Got a packet bigger than 'max_allowed_packet' bytes exception thrown."); // Use strlen() to count the bytes exactly, not the unicode chars. $this->assertTrue(strlen($e->getMessage()) <= $max_allowed_packet, "'max_allowed_packet' exception message truncated."); } } else { $this->verbose('The configured max_allowed_packet exceeds the php memory limit. Therefore the test is skipped.'); } } else { $this->verbose('The test requires MySQL. Therefore the test is skipped.'); } } }