From 5deff761d05a6e0ca943f3fd39a2db3bd95cbb8e Mon Sep 17 00:00:00 2001 From: Vlad Varlamov Date: Thu, 7 Nov 2024 10:46:05 +0400 Subject: [PATCH] Add a test case when an exception is expected when setting a private field --- .../Common/Integration/Case6/CaseTest.php | 50 +++++++++++++++++++ .../Common/Integration/Case6/Entity/User.php | 26 ++++++++++ .../Common/Integration/Case6/schema.php | 31 ++++++++++++ .../MySQL/Integration/Case6/CaseTest.php | 17 +++++++ .../Postgres/Integration/Case6/CaseTest.php | 17 +++++++ .../SQLServer/Integration/Case6/CaseTest.php | 17 +++++++ .../SQLite/Integration/Case6/CaseTest.php | 17 +++++++ 7 files changed, 175 insertions(+) create mode 100644 tests/ORM/Functional/Driver/Common/Integration/Case6/CaseTest.php create mode 100644 tests/ORM/Functional/Driver/Common/Integration/Case6/Entity/User.php create mode 100644 tests/ORM/Functional/Driver/Common/Integration/Case6/schema.php create mode 100644 tests/ORM/Functional/Driver/MySQL/Integration/Case6/CaseTest.php create mode 100644 tests/ORM/Functional/Driver/Postgres/Integration/Case6/CaseTest.php create mode 100644 tests/ORM/Functional/Driver/SQLServer/Integration/Case6/CaseTest.php create mode 100644 tests/ORM/Functional/Driver/SQLite/Integration/Case6/CaseTest.php diff --git a/tests/ORM/Functional/Driver/Common/Integration/Case6/CaseTest.php b/tests/ORM/Functional/Driver/Common/Integration/Case6/CaseTest.php new file mode 100644 index 00000000..d2bcf8e0 --- /dev/null +++ b/tests/ORM/Functional/Driver/Common/Integration/Case6/CaseTest.php @@ -0,0 +1,50 @@ +makeTable('users', [ + 'id' => 'int,primary', + 'login' => 'string', + ]); + + $this->loadSchema(__DIR__ . '/schema.php'); + + $this->getDatabase()->table('users')->insertMultiple( + ['id', 'login'], + [ + [1, 'foo'], + ], + ); + } + + public function testSelect(): void + { + /** @var User $model */ + $model = (new Select($this->orm,User::class)) + ->wherePK(1) + ->fetchOne(); + + $this->assertSame('foo', $model->getLogin()); + $this->expectException(\Exception::class); + $model->login = 'new login'; + } +} diff --git a/tests/ORM/Functional/Driver/Common/Integration/Case6/Entity/User.php b/tests/ORM/Functional/Driver/Common/Integration/Case6/Entity/User.php new file mode 100644 index 00000000..44095601 --- /dev/null +++ b/tests/ORM/Functional/Driver/Common/Integration/Case6/Entity/User.php @@ -0,0 +1,26 @@ +login = $login; + } + + public function getId(): ?string + { + return $this->id === null ? null : (string)$this->id; + } + + public function getLogin(): string + { + return $this->login; + } +} diff --git a/tests/ORM/Functional/Driver/Common/Integration/Case6/schema.php b/tests/ORM/Functional/Driver/Common/Integration/Case6/schema.php new file mode 100644 index 00000000..cc0dd8c8 --- /dev/null +++ b/tests/ORM/Functional/Driver/Common/Integration/Case6/schema.php @@ -0,0 +1,31 @@ + [ + Schema::ENTITY => User::class, + Schema::MAPPER => Mapper::class, + Schema::SOURCE => Source::class, + Schema::REPOSITORY => Repository::class, + Schema::DATABASE => 'default', + Schema::TABLE => 'users', + Schema::PRIMARY_KEY => ['id'], + Schema::FIND_BY_KEYS => ['id'], + Schema::COLUMNS => [ + 'id' => 'id', + 'login' => 'login', + ], + Schema::RELATIONS => [], + Schema::TYPECAST => [ + 'id' => 'int', + 'login' => 'string', + ], + ], +]; diff --git a/tests/ORM/Functional/Driver/MySQL/Integration/Case6/CaseTest.php b/tests/ORM/Functional/Driver/MySQL/Integration/Case6/CaseTest.php new file mode 100644 index 00000000..f96d12bc --- /dev/null +++ b/tests/ORM/Functional/Driver/MySQL/Integration/Case6/CaseTest.php @@ -0,0 +1,17 @@ +