mirror of
https://github.com/macintoshplus/mongo-php-driver.git
synced 2026-03-26 09:52:07 +01:00
* Introduce MongoDB\Driver\ServerApi * Accept serverApi driver option * Introduce create_test_manager factory to create manager A centralised entry point is required to inject the API_VERSION env variable later. * Add build variant to test with requireApiVersion=true * Fix wrong configuration for auth variable This changed when migrating from our own scripts to drivers-evergreen-tools and was not updated properly, causing all tests to run with auth disabled. * Declare ZEND_PARSE_PARAMETERS_NONE macro This macro is missing on PHP < 7.3 * Remove duplicated API param storage * Add missing semicolons * Add ZEND_PARSE_PARAMETERS_NON_EX macro * Extract error handling functionality to separate macros * Throw if internal mongoc_server_api_t is already initialised * Use imported namespaces in tools file * Fix type info for reflection * Use American English spelling * Only use typed serialize signature on PHP 8+ * Update PHONGO_PARSE_PARAMETERS_NONE macro for PHP < 7.3 * Remove usage of ZEND_STRL within zend_hash_str_add This causes compile failures on PHP < 7.3 that I have yet to understand. * Fix errors in new PHONGO_PARSE_PARAMETERS macros
83 lines
3.1 KiB
PHP
83 lines
3.1 KiB
PHP
--TEST--
|
|
MongoDB\Driver\Session::endSession() Calling methods after session has been ended
|
|
--SKIPIF--
|
|
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
|
|
<?php skip_if_not_libmongoc_crypto(); ?>
|
|
<?php skip_if_no_transactions(); ?>
|
|
--FILE--
|
|
<?php
|
|
require_once __DIR__ . "/../utils/basic.inc";
|
|
|
|
$manager = create_test_manager();
|
|
|
|
$sessionA = $manager->startSession();
|
|
$sessionA->endSession();
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->startTransaction();
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->abortTransaction();
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
/* The reason that startTransaction is in here twice is that this script can run without exception
|
|
* if the endSession() call is taken out. */
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->startTransaction();
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->commitTransaction();
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->advanceOperationTime(new \MongoDB\BSON\Timestamp(1900123000, 1900123000));
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->advanceClusterTime([]);
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
var_dump($sessionA->getClusterTime());
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
var_dump($sessionA->getLogicalSessionId());
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
var_dump($sessionA->getOperationTime());
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
echo throws(function() use ($sessionA) {
|
|
$sessionA->isInTransaction();
|
|
}, 'MongoDB\Driver\Exception\LogicException'), "\n";
|
|
|
|
?>
|
|
===DONE===
|
|
<?php exit(0); ?>
|
|
--EXPECT--
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'startTransaction', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'abortTransaction', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'startTransaction', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'commitTransaction', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'advanceOperationTime', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'advanceClusterTime', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'getClusterTime', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'getLogicalSessionId', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'getOperationTime', as the session has already been ended.
|
|
OK: Got MongoDB\Driver\Exception\LogicException
|
|
Cannot call 'isInTransaction', as the session has already been ended.
|
|
===DONE===
|