Skip to content

Commit

Permalink
Add github workflows
Browse files Browse the repository at this point in the history
  • Loading branch information
llorensjj committed Sep 26, 2024
1 parent 059ad72 commit 6b9ff39
Show file tree
Hide file tree
Showing 3 changed files with 111 additions and 3 deletions.
36 changes: 36 additions & 0 deletions .github/workflows/analyse.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
name: Analyse

on:
push:
branches: [master]
pull_request:
branches: [master]

jobs:
phpstan:
runs-on: ubuntu-latest

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: 8.0

- name: Cache Composer packages
id: composer-cache
uses: actions/cache@v4
with:
path: vendor
key: ${{ runner.os }}-php-8.0-${{ hashFiles('**/composer.json') }}
restore-keys: |
${{ runner.os }}-php-8.0-
- name: Install dependencies
run: |
composer install --no-interaction --no-progress
- name: Run analyse phpstan
run: vendor/bin/phpstan analyse src tests --error-format github
72 changes: 72 additions & 0 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
name: Tests

on:
push:
branches: [master]
pull_request:
branches: [master]

jobs:
phpunit:
runs-on: ubuntu-latest

strategy:
fail-fast: true
matrix:
php: [8.1, 8.2, 8.3]
laravel: [8.*, 9.*, 10.*, 11.*]
include:
- laravel: 8.*
testbench: 6.*
- laravel: 9.*
testbench: 7.*
- laravel: 10.*
testbench: 8.*
- laravel: 11.*
testbench: 9.*
exclude:
- laravel: 8.*
php: 8.2
- laravel: 8.*
php: 8.3
- laravel: 9.*
php: 8.3
- laravel: 11.*
php: 8.1

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php }}
extensions: curl, pdo, sqlite, pdo_sqlite

- name: Install SQLite 3
run: |
sudo apt-get update
sudo apt-get install sqlite3
- name: Validate composer.json
run: composer validate

- name: Cache Composer packages
id: composer-cache
uses: actions/cache@v4
with:
path: vendor
key: ${{ runner.os }}-php-${{ matrix.php }}-laravel-${{ matrix.laravel }}-${{ hashFiles('**/composer.lock') }}
restore-keys: |
${{ runner.os }}-php-${{ matrix.php }}-laravel-${{ matrix.laravel }}-
- name: Install dependencies
if: steps.composer-cache.outputs.cache-hit != 'true'
run: |
composer require "laravel/framework:${{ matrix.laravel }}" "orchestra/testbench:${{ matrix.testbench }}" --no-interaction --no-update
composer update --prefer-stable --prefer-dist --no-interaction
- name: Run test phpunit
run: vendor/bin/phpunit --stop-on-error --stop-on-failure
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ public function testLoggedEmail()

// Simula la respuesta HTTP
Http::fake([
config('descom_lib.notification_manager.url') => Http::sequence()->push($responseExpected)
'*' => Http::response($responseExpected, 200)
]);

$notificationManager = new NotificationManager;
Expand All @@ -39,7 +39,7 @@ public function testLoggedEmailPermanentException()

// Simula la respuesta HTTP con un código 404
Http::fake([
config('descom_lib.notification_manager.url') => Http::response(null, 404)
'*' => Http::response([], 404)
]);

$notificationManager = new NotificationManager;
Expand All @@ -59,7 +59,7 @@ public function testLoggedEmailTemporaryException()

// Simula la respuesta HTTP con un código 503
Http::fake([
config('descom_lib.notification_manager.url') => Http::response(null, 503)
'*' => Http::response([], 503)
]);

$notificationManager = new NotificationManager;
Expand Down

0 comments on commit 6b9ff39

Please sign in to comment.