epfremme / swagger-bundle
Symfony 2 bundle for leveraging swagger library test/mock API contracts
Installs: 4 602
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 1
Open Issues: 2
Type:symfony-bundle
Requires
- php: >=5.5
- behat/behat: ~3.0
- behat/mink: ~1.6
- behat/mink-browserkit-driver: ~1.2
- behat/mink-extension: ~2.0
- behat/symfony2-extension: ~2.0
- epfremme/swagger-php: ^1.0
- justinrainbow/json-schema: ^2.0
- symfony/symfony: ^2.0|^3.0
- tebru/realtype: ^0.1.0
Requires (Dev)
- phpunit/phpunit: ~4.1
README
Symfony 2 bundle for leveraging swagger development & testing tools
Installation
- Require package
composer require epfremme/swagger-bundle
- Install packages
composer install
Note: This bundle should only be used in dev mode and be included as a dev only dependency. The purpose of these resources are to assist the creation of an API symfony application during development
Usage
There are 2 main bundle parameters to you can override in your parameters.yml:
swagger_bundle.swagger_file
default: Resources/docs/swagger.yaml - specify swagger fileswagger_bundle.mock_api
default: true - turn on/off to deactivate the mock API listener
More deatils on each below...
Behat Usage
Behat documentation: behat
- Add the SwaggerContext file to your behat.yml config suite(s)
Sample Behat Config
Sample Behat configuration using the SwaggerContext for validating json schemas
default:
suites:
app:
paths:
- %paths.base%/src/AppBundle/Tests/Features/
contexts:
- Epfremme\SwaggerBundle\Behat\SwaggerContext: ~
extensions:
Behat\Symfony2Extension: ~
Behat\MinkExtension:
sessions:
default:
symfony2: ~
testers:
rerun_cache: .behat_rerun_cache
Context Details
@Given I have the request payload:
Takes in a TableNode for key value pairs to be used as request payload
Format: | key | value |
@When I request :path
@When I request :path with method :method
Make a request to the API with or without a request method (defaults to GET)
@When I use the :schema schema
@When I am using the :schema schema
Store a swagger definition schema from your swagger doc to be used to validate API json response data
Note: The swagger documentation used is the file defined in the swagger_bundle.swagger_file
parameter
@When I test swagger path :path
@When I test swagger path :path with operation :operation
@When I test swagger path :path with operation :operation and response :response
Store a swagger response schema from your swagger doc to be used to validate API json response data
Note: The swagger documentation used is the file defined in the swagger_bundle.swagger_file
parameter
@Then the response should be json
Assert the the response is json
@Then the response json should contain key :key
Assert that the response json contains "key"
@Then the response json key :key should equal :value
Assert the response json key equals "value"
@Then The json response data should be valid
@Then The json response key :key should be valid
Validates the response data agains the previously specified swagger definition or response schema
Mock API Usage
The mock API can be disabled by setting swagger_bundle.mock_api
to false. Also note the listener will not run in
prod mode if you forget to move it to require-dev or added it to the wrong are of your kernel
- Install
app/console swagger:install:mock-api
- Add the
x-mock-api
header to the request to trigger the listener to trigger the mock response
Resources
A useful chrome extension used to mock request headers Modheader
Additional chance methods & options that can be defined in the swagger.json doc chance