From 5515982d66b377ee40b680384691469a0791ab9d Mon Sep 17 00:00:00 2001 From: Lars Lauger Date: Wed, 30 Oct 2024 17:15:27 +0100 Subject: [PATCH 1/2] feat: Add workflow for unit tests --- .github/workflows/unittests.yml | 60 +++++++++++++++++++++++++++++++++ phpunit.xml.dist | 30 +++++++++++++++++ 2 files changed, 90 insertions(+) create mode 100644 .github/workflows/unittests.yml create mode 100644 phpunit.xml.dist diff --git a/.github/workflows/unittests.yml b/.github/workflows/unittests.yml new file mode 100644 index 0000000..c834fe6 --- /dev/null +++ b/.github/workflows/unittests.yml @@ -0,0 +1,60 @@ +name: unittests + +on: [ push, pull_request ] + +jobs: + unittests: + name: '[PHP ${{ matrix.php-version }} | DBAL ${{ matrix.dbal-version }}] Unit Tests' + runs-on: ubuntu-latest + + strategy: + fail-fast: false + matrix: + php-version: [ 8.1, 8.2, 8.3 ] + dbal-version: [ 2.13, 3.8 ] + + env: + APP_ENV: true + TEST_DIR: test-dir + + steps: + - uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php-version }} + extensions: mbstring, xml, json, zlib, iconv, intl, pdo_sqlite + ini-values: opcache.fast_shutdown=0 + + - name: Checkout code + uses: actions/checkout@v4 + with: + path: ${{ env.TEST_DIR }}/dist/upsert + + - name: "Create composer.json" + run: | + echo '{ + "name": "netlogix/upsert-test", + "description": "", + "license": "GPL-3.0-or-later", + "require": { + "netlogix/doctrine-upsert": "@dev", + "doctrine/dbal": "^${{ matrix.dbal-version }}" + }, + "require-dev": { + "phpunit/phpunit": "^10.5" + }, + "repositories": [ + { + "type": "path", + "url": "dist/upsert" + } + ] + }' > composer.json + working-directory: ${{ env.TEST_DIR }} + + - name: "Install project" + run: composer install + working-directory: ${{ env.TEST_DIR }} + + - name: Run tests + run: vendor/bin/phpunit -c dist/upsert/phpunit.xml.dist --testsuite="Unit" + working-directory: ${{ env.TEST_DIR }} diff --git a/phpunit.xml.dist b/phpunit.xml.dist new file mode 100644 index 0000000..b698162 --- /dev/null +++ b/phpunit.xml.dist @@ -0,0 +1,30 @@ + + + + + ./test/ + + + + + ./Classes + + + + + + + + + + + + + + From 6c77002e3084d51a10035c3804184fb85ecd827e Mon Sep 17 00:00:00 2001 From: Lars Lauger Date: Wed, 30 Oct 2024 17:29:45 +0100 Subject: [PATCH 2/2] fix: Repair tests for dbal 3.8+ --- test/UpsertTest.php | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/test/UpsertTest.php b/test/UpsertTest.php index 9e7cb30..77c03b4 100644 --- a/test/UpsertTest.php +++ b/test/UpsertTest.php @@ -6,7 +6,7 @@ use Doctrine\DBAL\Connection; use Doctrine\DBAL\DriverManager; use Doctrine\DBAL\Exception as DBALException; -use Doctrine\DBAL\ForwardCompatibility\DriverResultStatement; +use Doctrine\DBAL\Result; use Doctrine\DBAL\ParameterType; use Doctrine\DBAL\Platforms\SqlitePlatform; use Doctrine\DBAL\Platforms\AbstractPlatform; @@ -211,7 +211,7 @@ public function Table_Name_is_used_in_Query(): void public function Insert_works(): void { $connection = $this->getSQLiteConnection(); - $connection->exec('CREATE TABLE foo_table(bar TEXT PRIMARY KEY, count INT);'); + $connection->executeStatement('CREATE TABLE foo_table(bar TEXT PRIMARY KEY, count INT);'); Upsert::fromConnection($connection) ->forTable('foo_table') @@ -219,12 +219,12 @@ public function Insert_works(): void ->withField('count', 1) ->execute(); - $values = $connection->fetchAll('SELECT * FROM foo_table'); + $values = $connection->fetchAllAssociative('SELECT * FROM foo_table'); self::assertCount(1, $values); self::assertSame( [ 'bar' => 'baz', - 'count' => '1' + 'count' => 1 ], $values[0] ); @@ -236,8 +236,8 @@ public function Insert_works(): void public function Upsert_works(): void { $connection = $this->getSQLiteConnection(); - $connection->exec('CREATE TABLE foo_table(bar TEXT PRIMARY KEY, count INT);'); - $connection->exec('INSERT INTO foo_table (bar, count) VALUES ("baz", 1)'); + $connection->executeStatement('CREATE TABLE foo_table(bar TEXT PRIMARY KEY, count INT);'); + $connection->executeStatement('INSERT INTO foo_table (bar, count) VALUES ("baz", 1)'); Upsert::fromConnection($connection) ->forTable('foo_table') @@ -245,12 +245,12 @@ public function Upsert_works(): void ->withField('count', 2) ->execute(); - $values = $connection->fetchAll('SELECT * FROM foo_table'); + $values = $connection->fetchAllAssociative('SELECT * FROM foo_table'); self::assertCount(1, $values); self::assertSame( [ 'bar' => 'baz', - 'count' => '2' + 'count' => 2 ], $values[0] ); @@ -258,7 +258,7 @@ public function Upsert_works(): void private function getSQLiteConnection(): Connection { - if (!extension_loaded('sqlite')) { + if (!extension_loaded('sqlite3')) { self::markTestSkipped('ext-sqlite3 is required for tests'); } @@ -294,9 +294,10 @@ private function getMockConnection() return $connection; } - private function getMockResult(int $rowCount): DriverResultStatement + private function getMockResult(int $rowCount): Result { - $result = $this->getMockBuilder(DriverResultStatement::class) + $result = $this->getMockBuilder(Result::class) + ->disableOriginalConstructor() ->getMock(); $result