- CodeIgniter 4 framework setup with SQL Server database config - Models: Control, Test, Dept, Result, Daily/ Monthly entry models - Controllers: Dashboard, Control, Test, Dept, Entry, Report, API endpoints - Views: CRUD pages with modal dialogs, dashboard, reports - Database: Migrations for control test and daily/monthly result tables - Legacy v1 PHP application preserved in /v1 directory - Documentation: AGENTS.md, VIEWS_RULES.md for development guidelines
47 lines
1.2 KiB
PHP
47 lines
1.2 KiB
PHP
<?php
|
|
|
|
use CodeIgniter\Test\CIUnitTestCase;
|
|
use CodeIgniter\Test\DatabaseTestTrait;
|
|
use Tests\Support\Database\Seeds\ExampleSeeder;
|
|
use Tests\Support\Models\ExampleModel;
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
final class ExampleDatabaseTest extends CIUnitTestCase
|
|
{
|
|
use DatabaseTestTrait;
|
|
|
|
protected $seed = ExampleSeeder::class;
|
|
|
|
public function testModelFindAll(): void
|
|
{
|
|
$model = new ExampleModel();
|
|
|
|
// Get every row created by ExampleSeeder
|
|
$objects = $model->findAll();
|
|
|
|
// Make sure the count is as expected
|
|
$this->assertCount(3, $objects);
|
|
}
|
|
|
|
public function testSoftDeleteLeavesRow(): void
|
|
{
|
|
$model = new ExampleModel();
|
|
$this->setPrivateProperty($model, 'useSoftDeletes', true);
|
|
$this->setPrivateProperty($model, 'tempUseSoftDeletes', true);
|
|
|
|
/** @var stdClass $object */
|
|
$object = $model->first();
|
|
$model->delete($object->id);
|
|
|
|
// The model should no longer find it
|
|
$this->assertNull($model->find($object->id));
|
|
|
|
// ... but it should still be in the database
|
|
$result = $model->builder()->where('id', $object->id)->get()->getResult();
|
|
|
|
$this->assertCount(1, $result);
|
|
}
|
|
}
|