123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- <?php
- namespace EasySwoole\ORM\Tests;
- use EasySwoole\Mysqli\QueryBuilder;
- use EasySwoole\ORM\Db\ClientInterface;
- use PHPUnit\Framework\TestCase;
- use EasySwoole\ORM\Db\Config;
- use EasySwoole\ORM\Db\Connection;
- use EasySwoole\ORM\DbManager;
- use EasySwoole\ORM\Tests\models\TestTimeStampModel;
- class TransactionTest extends TestCase
- {
-
- protected $connection;
- protected $tableName = 'user_test_list';
- protected function setUp(): void
- {
- parent::setUp();
- $config = new Config(MYSQL_CONFIG);
- $config->setMinObjectNum(1);
- $config->setMaxObjectNum(5);
- $this->connection = new Connection($config);
- DbManager::getInstance()->addConnection($this->connection);
- $connection = DbManager::getInstance()->getConnection();
- $this->assertTrue($connection === $this->connection);
- }
-
- public function testInvoke()
- {
- TestTimeStampModel::create()->destroy([], true);
- DbManager::getInstance()->invoke(function ($client) {
- DbManager::getInstance()->startTransaction($client);
- $model = TestTimeStampModel::invoke($client);
- $model->name = 'siam';
- $model->age = 21;
- $model->save();
- $this->assertIsInt($model->id);
- DbManager::getInstance()->rollback($client);
-
- $has = TestTimeStampModel::invoke($client)->get([
- 'name' => 'siam'
- ]);
- $this->assertNull($has);
- });
- TestTimeStampModel::create()->destroy([], true);
- }
- public function testWhileCommit()
- {
- TestTimeStampModel::create()->destroy([], true);
- $i = $count = 10;
- $ids = [];
- while ($i--) {
- DbManager::getInstance()->startTransaction();
- $model = TestTimeStampModel::create();
- $model->name = 'siam';
- $model->age = 21;
- $model->save();
- $ids[] = $model->id;
- DbManager::getInstance()->commit();
- }
- $ret = TestTimeStampModel::create()->where('id', $ids, 'IN')->all();
- $this->assertEquals($count, count($ret));
- TestTimeStampModel::create()->destroy([], true);
- }
- public function testWhileCommitInvoke()
- {
- TestTimeStampModel::create()->destroy([], true);
- $i = $count = 10;
- while ($i--) {
- DbManager::getInstance()->invoke(function (ClientInterface $client) use (&$ids) {
- DbManager::getInstance()->startTransaction($client);
- $model = TestTimeStampModel::invoke($client);
- $model->name = 'siam';
- $model->age = 21;
- $model->save();
- $ids[] = $model->id;
- DbManager::getInstance()->commit($client);
- });
- }
- $ret = TestTimeStampModel::create()->where('id', $ids, 'IN')->all();
- $this->assertEquals($count, count($ret));
- TestTimeStampModel::create()->destroy([], true);
- }
- public function testWhileRollback()
- {
- TestTimeStampModel::create()->destroy([], true);
- $i = $count = 10;
- $ids = [];
- while ($i--) {
- try {
- DbManager::getInstance()->startTransaction();
- $model = TestTimeStampModel::create();
- $model->name = 'siam';
- $model->age = 21;
- $model->save();
- $ids[] = $model->id;
- $builder = new QueryBuilder();
- $builder->insert('tiamstamp_test', ['a' => 1]);
- DbManager::getInstance()->query($builder, true);
- DbManager::getInstance()->commit();
- } catch (\Throwable $throwable) {
- try {
- DbManager::getInstance()->rollback();
- } catch (\Throwable $throwable) {
- }
- }
- }
- $ret = TestTimeStampModel::create()->where('id', $ids, 'IN')->all();
- $this->assertEquals(0, count($ret));
- TestTimeStampModel::create()->destroy([], true);
- }
- public function testWhileRollbackInvoke()
- {
- $i = $count = 10;
- while ($i--) {
- DbManager::getInstance()->invoke(function ($client) use (&$ids) {
- try {
- DbManager::getInstance()->startTransaction($client);
- $model = TestTimeStampModel::invoke($client);
- $model->name = 'siam';
- $model->age = 21;
- $model->save();
- $ids[] = $model->id;
- $builder = new QueryBuilder();
- $builder->insert('tiamstamp_test', ['a' => 1]);
- DbManager::getInstance()->query($builder, true, $client);
- DbManager::getInstance()->commit($client);
- } catch (\Throwable $throwable) {
- try {
- DbManager::getInstance()->rollback($client);
- } catch (\Throwable $throwable) {
- }
- }
- });
- }
- $ret = TestTimeStampModel::create()->where('id', $ids, 'IN')->all();
- $this->assertEquals(0, count($ret));
- TestTimeStampModel::create()->destroy([], true);
- }
- }
|