phphd/api-testing 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

phphd/api-testing

最新稳定版本:1.1.0

Composer 安装命令:

composer require --dev phphd/api-testing

包简介

JWT Authentication for API testing

README 文档

README

???? Provides lightweight jwt authorization utilities for Api Testing in Symfony applications. In essence, this package integrates Lexik JWT Authentication Bundle into your Api Test Cases.

Build Status Codecov Psalm coverage Psalm level Total Downloads Licence

Quick Start

Installation ????

  1. Install via composer

    composer require --dev phphd/api-testing
  2. Enable the bundle in the bundles.php

    PhPhD\ApiTesting\Bundle\PhdApiTestingBundle::class => ['test' => true],

Configuration ⚒️

Create phd_api_testing.yaml configuration file under config/packages/test directory. It's necessary to specify service id of application user provider here. If you have only one authenticated user entity (hence, one provider), use current default configuration.

phd_api_testing: jwt_authenticators: - name: default user_provider: security.user_providers

Usage ????

In your Api Test class use JwtLoginTrait and login method to handle authentication:

use PhPhD\ApiTesting\Jwt\JwtLoginTrait; final class ExampleProtectedApiTest extends ApiTestCase { use JwtLoginTrait; // ... public function testAccessFeatureWithoutPassword(): void { $token = $this->login('username'); $this->client->request('GET', '/api/protected-route', [ 'auth_bearer' => $token, ]); self::assertResponseStatusCodeSame(200); } }

In this example, login is used to generate jwt token for username user so that api request will be sent on his behalf.

Advanced Configuration ⚙️

Multiple Authenticators

It is possible to use multiple authenticators for your specific needs. For instance if you have admin panel alongside your main authenticated application, you may want to use the dedicated authenticator.

In essence, if you're utilizing security.user_providers, additional configuration is typically unnecessary, since security.user_providers acts as a chain user provider, meaning that first found user from any subordinate providers will be used.

Nonetheless, in case of conflicting usernames or any other specific reason, you may register an additional authenticator in the same configuration file by different name:

phd_api_testing: jwt_authenticators: - name: admin user_provider: security.user.provider.concrete.api_admin_user_provider

In this config, api_admin_user_provider is the name of user provider from security.yaml and admin - just an alias for our usage in tests.

Having registered authenticator, we may use its alias as a second parameter of login method:

public function testDedicatedAdminAuthenticator(): void { $token = $this->login('admin@test.com', authenticator: 'admin'); $this->client->request('GET', '/api/admin/protected-route', [ 'auth_bearer' => $token, ]); self::assertResponseStatusCodeSame(200); }

统计信息

  • 总下载量: 5.14k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固