From 1f02310da922ec47537a1d648e9afb1d0828cfb3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Samuel=20=C5=A0tancl?= Date: Mon, 30 Nov 2020 16:14:08 +0100 Subject: [PATCH] PHP 8 support, test workflow syntax --- .github/workflows/ci.yml | 11 ++++-- Dockerfile | 34 +++++++++---------- docker-compose.yml | 3 ++ .../FilesystemTenancyBootstrapper.php | 6 +++- src/Concerns/CreatesDatabaseUsers.php | 12 +++---- 5 files changed, 38 insertions(+), 28 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a7cbc338..bbd04852 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -15,16 +15,23 @@ jobs: strategy: matrix: + php: + "7.4": + - target=php:7.4-cli + - version=7.4 + "8.0": + - target=php:8.0.0RC5-cli + - version=8.0 laravel: [ "^6.0", "^7.0", "^8.0" ] - + steps: - uses: actions/checkout@v2 - name: Start docker containers - run: docker-compose up -d + run: PHP_TARGET=${{ matrix.php.target}} PHP_VESRSION=${{ matrix.php.version }} docker-compose up -d - name: Install dependencies run: docker-compose exec -T test composer require --no-interaction "laravel/framework:${{ matrix.laravel }}" - name: Run tests diff --git a/Dockerfile b/Dockerfile index 6a468038..06d97aea 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,9 +1,8 @@ -ARG PHP_TARGET=7.4 +ARG PHP_VERSION=7.4 +ARG PHP_TARGET=php:${PHP_VERSION}-cli -FROM php:${PHP_TARGET}-cli +FROM ${PHP_TARGET} -# We need to do this again as the FROM line seems to clear the ARG -ARG PHP_TARGET=7.4 ARG COMPOSER_TARGET=2.0.3 WORKDIR /var/www/html @@ -11,8 +10,8 @@ WORKDIR /var/www/html LABEL org.opencontainers.image.source=https://github.com/stancl/tenancy \ org.opencontainers.image.vendor="Samuel Ć tancl" \ org.opencontainers.image.licenses="MIT" \ - org.opencontainers.image.title="PHP ${PHP_TARGET} with modules for laravel support" \ - org.opencontainers.image.description="PHP ${PHP_TARGET} with a set of php/os packages suitable for running Laravel apps" + org.opencontainers.image.title="PHP ${PHP_VERSION} with modules for laravel support" \ + org.opencontainers.image.description="PHP ${PHP_VERSION} with a set of php/os packages suitable for running Laravel apps" # our default timezone and langauge ENV TZ=Europe/London @@ -23,28 +22,29 @@ ENV LANG=en_GB.UTF-8 # Dockerfile _and pin the versions_! Eg: # RUN pecl install memcached-2.2.0 && docker-php-ext-enable memcached -RUN apt-get update \ - # install some OS packages we need - && apt-get install -y --no-install-recommends libfreetype6-dev libjpeg62-turbo-dev libpng-dev libgmp-dev libldap2-dev netcat curl sqlite3 libsqlite3-dev libpq-dev libzip-dev unzip vim-tiny gosu git \ +# install some OS packages we need +RUN apt-get update +RUN apt-get install -y --no-install-recommends libfreetype6-dev libjpeg62-turbo-dev libpng-dev libgmp-dev libldap2-dev netcat curl sqlite3 libsqlite3-dev libpq-dev libzip-dev unzip vim-tiny gosu git # install php extensions - && if [ "${PHP_TARGET}" = "7.4" ]; then docker-php-ext-configure gd --with-freetype --with-jpeg; else docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/; fi \ - && docker-php-ext-configure pgsql -with-pgsql=/usr/local/pgsql \ +RUN docker-php-ext-configure pgsql -with-pgsql=/usr/local/pgsql \ + # && if [ "${PHP_VERSION}" = "7.4" ]; then docker-php-ext-configure gd --with-freetype --with-jpeg; else docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/; fi \ && docker-php-ext-install -j$(nproc) gd pdo pdo_mysql pdo_pgsql pdo_sqlite pgsql zip gmp bcmath pcntl ldap sysvmsg exif \ # install the redis php extension - && pecl install redis-5.0.2 \ + && pecl install redis-5.3.2 \ && docker-php-ext-enable redis \ # install the pcov extention && pecl install pcov \ && docker-php-ext-enable pcov \ - && echo "pcov.enabled = 1" > /usr/local/etc/php/conf.d/pcov.ini \ - # clear the apt cache + && echo "pcov.enabled = 1" > /usr/local/etc/php/conf.d/pcov.ini +# clear the apt cache +RUN rm -rf /var/lib/apt/lists/* \ && rm -rf /var/lib/apt/lists/* \ # install composer && curl -o /tmp/composer-setup.php https://getcomposer.org/installer \ && curl -o /tmp/composer-setup.sig https://composer.github.io/installer.sig \ && php -r "if (hash('SHA384', file_get_contents('/tmp/composer-setup.php')) !== trim(file_get_contents('/tmp/composer-setup.sig'))) { unlink('/tmp/composer-setup.php'); echo 'Invalid installer' . PHP_EOL; exit(1); }" \ && php /tmp/composer-setup.php --version=${COMPOSER_TARGET} --no-ansi --install-dir=/usr/local/bin --filename=composer --snapshot \ - && rm -f /tmp/composer-setup.* \ - # set the system timezone - && ln -snf /usr/share/zoneinfo/$TZ /etc/localtime \ + && rm -f /tmp/composer-setup.* +# set the system timezone +RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime \ && echo $TZ > /etc/timezone diff --git a/docker-compose.yml b/docker-compose.yml index a1e89c18..ffb141e8 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -3,6 +3,9 @@ services: test: build: context: . + args: + PHP_VERSION: ${PHP_VERSION} + PHP_TARGET: ${PHP_TARGET} depends_on: mysql: condition: service_healthy diff --git a/src/Bootstrappers/FilesystemTenancyBootstrapper.php b/src/Bootstrappers/FilesystemTenancyBootstrapper.php index 17fb130d..d5ae2d50 100644 --- a/src/Bootstrappers/FilesystemTenancyBootstrapper.php +++ b/src/Bootstrappers/FilesystemTenancyBootstrapper.php @@ -59,7 +59,11 @@ class FilesystemTenancyBootstrapper implements TenancyBootstrapper $filesystemDisk = Storage::disk($disk); $this->originalPaths['disks'][$disk] = $filesystemDisk->getAdapter()->getPathPrefix(); - if ($root = str_replace('%storage_path%', storage_path(), $this->app['config']["tenancy.filesystem.root_override.{$disk}"])) { + if ($root = str_replace( + '%storage_path%', + storage_path(), + $this->app['config']["tenancy.filesystem.root_override.{$disk}"] ?? '' + )) { $filesystemDisk->getAdapter()->setPathPrefix($finalPrefix = $root); } else { $root = $this->app['config']["filesystems.disks.{$disk}.root"]; diff --git a/src/Concerns/CreatesDatabaseUsers.php b/src/Concerns/CreatesDatabaseUsers.php index b9d4e344..863dd4a7 100644 --- a/src/Concerns/CreatesDatabaseUsers.php +++ b/src/Concerns/CreatesDatabaseUsers.php @@ -10,19 +10,15 @@ trait CreatesDatabaseUsers { public function createDatabase(TenantWithDatabase $tenant): bool { - return $this->database()->transaction(function () use ($tenant) { - parent::createDatabase($tenant); + parent::createDatabase($tenant); - return $this->createUser($tenant->database()); - }); + return $this->createUser($tenant->database()); } public function deleteDatabase(TenantWithDatabase $tenant): bool { - return $this->database()->transaction(function () use ($tenant) { - parent::deleteDatabase($tenant); + parent::deleteDatabase($tenant); - return $this->deleteUser($tenant->database()); - }); + return $this->deleteUser($tenant->database()); } }