diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 0000000..c9932b6 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,72 @@ +name: CI + +on: + push: + pull_request: + +env: + PSALM_PHP_VERSION: "8.3" + COVERAGE_PHP_VERSION: "8.3" + +jobs: + + phpunit: + name: PHPUnit + runs-on: ubuntu-22.04 + + strategy: + matrix: + php-version: + - "8.1" + deps: + - "highest" + + services: + mysql: + image: "mysql:8.0" + ports: + - "3306:3306" + options: >- + --health-cmd "mysqladmin ping --silent" + -e MYSQL_ROOT_PASSWORD=password + + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Setup PHP + uses: shivammathur/setup-php@v2 + with: + php-version: ${{ matrix.php-version }} + coverage: pcov + + - name: Install composer dependencies + uses: ramsey/composer-install@v3 + with: + dependency-versions: ${{ matrix.deps }} + + - name: Run PHPUnit + run: vendor/bin/phpunit --fail-on-skipped + if: ${{ matrix.php-version != env.COVERAGE_PHP_VERSION }} + env: + DB_HOST: 127.0.0.1 + DB_PORT: 3306 + DB_USERNAME: root + DB_PASSWORD: password + + - name: Run PHPUnit with coverage + run: | + mkdir -p build/logs + vendor/bin/phpunit --fail-on-skipped --coverage-clover build/logs/clover.xml + if: ${{ matrix.php-version == env.COVERAGE_PHP_VERSION }} + env: + DB_HOST: localhost + DB_PORT: 3306 + DB_USERNAME: root + DB_PASSWORD: password + + - name: Upload coverage report to Coveralls + run: vendor/bin/php-coveralls --coverage_clover=build/logs/clover.xml -v + env: + COVERALLS_REPO_TOKEN: ${{ secrets.GITHUB_TOKEN }} + if: ${{ matrix.php-version == env.COVERAGE_PHP_VERSION }} diff --git a/tests/AbstractTestCase.php b/tests/AbstractTestCase.php index 86cd118..b8d78ff 100644 --- a/tests/AbstractTestCase.php +++ b/tests/AbstractTestCase.php @@ -59,9 +59,25 @@ public static function setUpBeforeClass() : void { self::$logger = new DebugLogger(); - $pdo = new \PDO('mysql:host=localhost;dbname=test', 'root', ''); + $dbHost = getenv('DB_HOST'); + $dbPort = getenv('DB_PORT'); + $dbUsername = getenv('DB_USERNAME'); + $dbPassword = getenv('DB_PASSWORD'); + + self::assertNotFalse($dbHost, 'Environment variable DB_HOST is not set'); + self::assertNotFalse($dbPort, 'Environment variable DB_PORT is not set'); + self::assertNotFalse($dbUsername, 'Environment variable DB_USERNAME is not set'); + self::assertNotFalse($dbPassword, 'Environment variable DB_PASSWORD is not set'); + + $dsn = sprintf('mysql:host=%s;port=%s', $dbHost, $dbPort); + $pdo = new \PDO($dsn, $dbUsername, $dbPassword); $driverConnection = new PDOConnection($pdo); $connection = new Connection($driverConnection, self::$logger); + + $connection->exec('DROP DATABASE IF EXISTS orm_tests'); + $connection->exec('CREATE DATABASE orm_tests'); + $connection->exec('USE orm_tests'); + $classMetadata = require __DIR__ . '/Generated/ClassMetadata.php'; self::$connection = $connection;