Skip to content

Commit

Permalink
use api php8.1 version (#1059)
Browse files Browse the repository at this point in the history
* ISSUE-337: use api php8.1 version

* ISSUE-337: ci

* do not fail on experimental versions

---------

Co-authored-by: Tatevik <[email protected]>
  • Loading branch information
TatevikGr and tatevikg1 authored Jan 15, 2025
1 parent edbdc4f commit 708c648
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 53 deletions.
32 changes: 15 additions & 17 deletions .github/workflows/build-release.yml
Original file line number Diff line number Diff line change
@@ -1,24 +1,22 @@

name: Build Release

on:
push:
tags: v[1-9]+.[0-9]+.*


jobs:
test:
runs-on: ubuntu-22.04
continue-on-error: ${{ matrix.experimental }}

strategy:
fail-fast: false
matrix:
fail-fast: false
matrix:
php-version: ['8.2']
experimental: [false]

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- name: Find the version
run: echo "RELEASE_VERSION=${GITHUB_REF#refs/*/v}" >> $GITHUB_ENV
Expand All @@ -43,7 +41,7 @@ jobs:
sudo apt update && sudo apt install -y rsync
- name: Cache Composer dependencies
uses: actions/cache@v2
uses: actions/cache@v3
with:
path: /tmp/composer-cache
key: ${{ matrix.php-version }}-${{ env.RELEASE_VERSION }}-${{ hashFiles('**/composer.lock') }}
Expand All @@ -54,7 +52,7 @@ jobs:
dev: yes
args: --prefer-dist --no-interaction
php_version: ${{ matrix.php-version }}
php_extensions: xml
php_extensions: xml
version: 2

- name: Install Plugins and Themes
Expand All @@ -67,10 +65,10 @@ jobs:
run: |
cd $GITHUB_WORKSPACE
cd public_html/lists
wget https://github.com/phpList/base-distribution/archive/refs/heads/phplist3.zip
unzip phplist3.zip
rm phplist3.zip
mv base-distribution-phplist3 base
wget https://github.com/phpList/base-distribution/archive/refs/heads/main.zip
unzip main.zip
rm main.zip
mv base-distribution-main base
cd base
composer update --no-dev
Expand All @@ -97,7 +95,7 @@ jobs:
with:
path: ./public_html
options: --exclude=base/vendor

- name: Report Versions
run: |
google-chrome --version
Expand All @@ -121,7 +119,7 @@ jobs:
- name: Upload the screenshots
if: always()
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v3
with:
path: "output"
name: "behat output"
Expand Down Expand Up @@ -220,24 +218,24 @@ jobs:
- name: Upload the package as artifact
if: always()
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v3
with:
path: "phplist-*.tgz"
name: "phpList Release File"
retention-days: 3

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
uses: docker/setup-buildx-action@v2

- name: Login to DockerHub
uses: docker/login-action@v1
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}

- name: Build and push
id: docker_build
uses: docker/build-push-action@v2
uses: docker/build-push-action@v3
with:
context: .
push: true
Expand Down
69 changes: 34 additions & 35 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,16 +9,16 @@ jobs:
continue-on-error: ${{ matrix.experimental }}

strategy:
fail-fast: false
matrix:
php-version: ['7.4', '8.0', '8.1','8.2']
fail-fast: false
matrix:
php-version: ['7.4', '8.0', '8.1', '8.2']
experimental: [false]
include:
- php-version: 8.3
- php-version: '8.3'
experimental: true

steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- name: Set up PHP ${{ matrix.php-version }}
uses: shivammathur/setup-php@v2
Expand All @@ -29,24 +29,17 @@ jobs:

- name: Setup Packages
run: |
cd $GITHUB_WORKSPACE
sudo apt update
sudo apt install rsync
# - name: Cache Composer dependencies
# uses: actions/cache@v2
# with:
# path: /tmp/composer-cache
# key: ${{ matrix.php-version }}-${{ hashFiles('**/composer.lock') }}
sudo apt install -y rsync
- name: Install dependencies
uses: php-actions/composer@v6
with:
dev: yes
args: --prefer-dist --no-interaction
php_version: ${{ matrix.php-version }}
php_extensions: xml
version: 2
php_extensions: xml
continue-on-error: ${{ matrix.experimental }}

- name: Report Versions
run: |
Expand All @@ -61,69 +54,75 @@ jobs:
vendor/bin/behat -V
mysql --version
mysqladmin --version
continue-on-error: ${{ matrix.experimental }}

- name: Create Database
run: |
sudo systemctl start mysql.service
sudo mysql -proot -e 'drop database if exists phplistdb'
sudo mysql -proot -e 'DROP DATABASE IF EXISTS phplistdb'
sudo mysqladmin -proot create phplistdb
sudo mysql -proot -e 'create user phplist@"%" identified by "phplist"; grant all on phplistdb.* to phplist@"%"'
sudo mysql -proot -e 'CREATE USER phplist@"%" IDENTIFIED BY "phplist"; GRANT ALL ON phplistdb.* TO phplist@"%"'
continue-on-error: ${{ matrix.experimental }}

- name: Set bootlist theme
- name: Set Bootlist Theme
run: |
cd $GITHUB_WORKSPACE/public_html/lists/admin/ui/
cd public_html/lists/admin/ui/
wget https://github.com/phpList/phplist-ui-bootlist/archive/master.tar.gz
tar -xzf master.tar.gz
mv phplist-ui-bootlist-master phplist-ui-bootlist
rm master.tar.gz
continue-on-error: ${{ matrix.experimental }}

- name: Start Test Server
run: |
cd $GITHUB_WORKSPACE
cp -fv tests/ci/behat.yml tests/behat.yml
cp -fv tests/ci/config.php public_html/lists/config/config.php
mkdir -p output/screenshots
touch output/screenshots/README.md
mkdir -p build/mails
./bin/start-selenium > output/selenium.log 2>&1 &
sleep 5
sudo php -S 0.0.0.0:80 -t public_html > /dev/null 2>&1 &
continue-on-error: ${{ matrix.experimental }}

- name: Check PHP syntax errors
uses: overtrue/[email protected]
with:
path: ./public_html

continue-on-error: ${{ matrix.experimental }}

- name: Run BDD Tests UI
run: |
cd $GITHUB_WORKSPACE/tests
cd tests
../vendor/bin/behat -p chrome -f progress --stop-on-failure --tags=@initialise
../vendor/bin/behat -p chrome -f progress --tags="~@initialise && ~@wip"
continue-on-error: ${{ matrix.experimental }}

- name: Run BDD Tests CLI
run: |
cd $GITHUB_WORKSPACE
export [email protected]
export ADMIN_PASSWORD=Mypassword123+
export ORGANISATION_NAME="phpList"
export ADMIN_NAME="phpList Administrator"
php public_html/lists/admin/index.php -c $GITHUB_WORKSPACE/public_html/lists/config/config.php -p initialise -f
cd $GITHUB_WORKSPACE/tests
php public_html/lists/admin/index.php -c public_html/lists/config/config.php -p initialise -f
cd tests
../vendor/bin/behat -p chrome --tags="~@initialise && ~@wip"
continue-on-error: ${{ matrix.experimental }}

- name: Handle Experimental Warnings
if: ${{ matrix.experimental && failure() }}
run: |
echo "::warning::PHP ${matrix.php-version} tests failed. This is marked as experimental and does not impact overall workflow success."
- name: Upload the screenshots
- name: Upload the Screenshots
if: always()
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v3
with:
path: "output"
name: "behat output ${{ matrix.php-version }}"
retention-days: 3

- name: Display output
- name: Display Output on Failure
if: failure() && !matrix.experimental
run: |
cd $GITHUB_WORKSPACE
# find . -type f
# cat output/selenium.log
if: ${{ failure() }}


find . -type f
cat output/selenium.log
2 changes: 1 addition & 1 deletion public_html/lists/api.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

use PhpList\Core\Core\Bootstrap;

if (version_compare(phpversion(), '7.0.0', '<')) {
if (version_compare(phpversion(), '8.1', '<')) {
die('API is not supported on this PHP version.');
}
require_once __DIR__ . '/base/vendor/autoload.php';
Expand Down

0 comments on commit 708c648

Please sign in to comment.