123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- <?php
- namespace EasySwoole\ORM\Tests;
- use EasySwoole\Mysqli\QueryBuilder;
- use EasySwoole\ORM\Db\Config;
- use EasySwoole\ORM\Db\Connection;
- use EasySwoole\ORM\DbManager;
- use EasySwoole\ORM\Utility\Schema\Table;
- use PHPUnit\Framework\TestCase;
- use EasySwoole\ORM\Tests\models\TestUserModel;
- class ModelTest extends TestCase
- {
-
- protected $connection;
- protected $tableName = 'test_user_model';
- protected function setUp(): void
- {
- parent::setUp();
- $config = new Config(MYSQL_CONFIG);
- $this->connection = new Connection($config);
- DbManager::getInstance()->addConnection($this->connection);
- $connection = DbManager::getInstance()->getConnection();
- $this->assertTrue($connection === $this->connection);
- $this->createTestTable();
- }
- function createTestTable()
- {
- $query = new QueryBuilder();
- $tableDDL = new Table($this->tableName);
- $tableDDL->colInt('id', 11)->setIsPrimaryKey()->setIsAutoIncrement();
- $tableDDL->colVarChar('name', 255);
- $tableDDL->colTinyInt('age', 1);
- $tableDDL->colDateTime('addTime');
- $tableDDL->colTinyInt('state', 1);
- $tableDDL->setIfNotExists();
- $sql = $tableDDL->__createDDL();
- $query->raw($sql);
- $data = $this->connection->defer()->query($query);
- $this->assertTrue($data->getResult());
- }
- function testGetSchemaInfo()
- {
- $testUserModel = new TestUserModel();
- $schemaInfo = $testUserModel->schemaInfo();
- $this->assertTrue($schemaInfo instanceof Table);
- }
- function testAdd()
- {
- $testUserModel = new TestUserModel();
- $testUserModel->state = 1;
- $testUserModel->name = '仙士可';
- $testUserModel->age = 100;
- $testUserModel->addTime = date('Y-m-d H:i:s');
- $data = $testUserModel->save();
- $this->assertIsInt($data);
- }
-
- function testUpdate()
- {
- $testUserModel = new TestUserModel();
-
- $user = $testUserModel->get();
- $user->name = '仙士可2号';
- $result = $user->update();
- $this->assertTrue($result);
- $user = $testUserModel->get(['id' => $user->id]);
- $this->assertEquals('仙士可2号', $user->name);
- $user = $testUserModel->where(function (QueryBuilder $builder)use ($user){
- $builder->where('id', $user->id);
- })->get();
- $this->assertEquals('仙士可2号', $user->name);
- }
-
- function testUpdateWithLimit()
- {
- $testUserModel = new TestUserModel();
-
-
- $user = $testUserModel->get();
- $user->name = 'XueSi-1号';
- $result = $user->limit(1)->update([], null, true);
- $this->assertEquals("UPDATE `test_user_model` SET `name` = 'XueSi-1号' LIMIT 1", $user->lastQuery()->getLastQuery());
- $this->assertTrue($result);
-
-
- $user = $testUserModel->get();
- $user->name = 'XueSi-2号';
- $result = $user->limit(2, 3)->update([], null, true);
- $this->assertEquals("UPDATE `test_user_model` SET `name` = 'XueSi-2号' LIMIT 2", $user->lastQuery()->getLastQuery());
- $this->assertTrue($result);
-
- $result = $testUserModel->limit(3)->update(['name' => 'XueSi-1号-1'], null, true);
- $this->assertEquals("UPDATE `test_user_model` SET `name` = 'XueSi-1号-1' LIMIT 3", $testUserModel->lastQuery()->getLastQuery());
- $this->assertTrue($result);
-
- $testUserModel = new TestUserModel();
- $result = $testUserModel->limit(4, 5)->update(['name' => 'XueSi-2号-2'], null, true);
- $this->assertEquals("UPDATE `test_user_model` SET `name` = 'XueSi-2号-2' LIMIT 4", $testUserModel->lastQuery()->getLastQuery());
- $this->assertTrue($result);
-
- $testUserModel = new TestUserModel();
- $result = $testUserModel->limit(1)->update(['name' => 'XueSi-3号'], ['id' => 1]);
- $this->assertEquals("UPDATE `test_user_model` SET `name` = 'XueSi-3号' WHERE `id` = 1 LIMIT 1", $testUserModel->lastQuery()->getLastQuery());
- $this->assertTrue($result);
- }
- function testGetAll()
- {
- $testUserModel = new TestUserModel();
- $data = $testUserModel->all();
- $this->assertIsArray($data);
- }
- function testDelete()
- {
- $testUserModel = new TestUserModel();
-
- $user = $testUserModel->get();
- $result = $user->destroy();
- $this->assertEquals(1, $result);
- $user = $user->get(['id' => $user->id]);
- $this->assertNull($user);
- }
- }
|