2017 © Pedro Peláez
 

library fluent-test

A few helpers to ease functional API testing in Symfony

image

nebkam/fluent-test

A few helpers to ease functional API testing in Symfony

  • Friday, July 13, 2018
  • by nebkam
  • Repository
  • 2 Watchers
  • 2 Stars
  • 131 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 1 Open issues
  • 6 Versions
  • 64 % Grown

The README.md

Latest Stable Version, (*1)

Fluent Test Helper

Few classes to make your Symfony tests more readable, (*2)

Symfony 5 & 6

composer require --dev nebkam/fluent-test, (*3)

Symfony 3 & 4

composer require --dev nebkam/fluent-test:"^2.0", (*4)

RequestBuilder

Since Symfony\Bundle\FrameworkBundle\KernelBrowser::request has 7 optional parameters, arbitrary ordered, this class follows a builder pattern to construct the request using semantic methods., (*5)

Usage

// Before
$response = $client->request($method, $uri, $parameters, $files, $server, $content);

// After
$response = RequestBuilder::create($client)
  ->setMethod($method)
  ->setUri($uri)
  ->setParameters($parameters)
  ->setFiles($files)
  ->setContent($content)
  ->getResponse();

What about $server parameter?

There's no RequestBuilder::setServer method, since it seemed to general to be semantic. Instead, you can use more specific methods (Thanks, @KristijanKanalas): - setHeader - setHttpHeader - setCredentials, (*6)

(if you think of some other uses of server variables, feel free to write a semantic method for it in a PR), (*7)

setHeader

// Before
$response = $client->request($method, $uri, $parameters, $files, [
  'CONTENT_TYPE' => $value
  ], $content);

// After
$response = RequestBuilder::create($client)
  ->setHeader('CONTENT_TYPE', $value)
  ...

setHttpHeader

// Before
$response = $client->request($method, $uri, $parameters, $files, [
  'HTTP_X-Custom-Header' => $value
  ], $content);

// After
$response = RequestBuilder::create($client)
  ->setHttpHeader('X-Custom-Header', $value)
  ...

setCredentials

// Before
$response = $client->request($method, $uri, $parameters, $files, [
  'PHP_AUTH_USER' => $username,
  'PHP_AUTH_PW' => $password
  ], $content);

//After
$response = RequestBuilder::create($client)
  ->setCredentials($username, $password)
  ...

setJsonContent

Send a JSON encoded payload with the request, (*8)

// Before
$response = $client->request($method, $uri, $parameters, $files, $server, json_encode($content));

// After
$response = RequestBuilder::create($client)
  ->setJsonContent($content)
  ...

Dynamic URIs

setUri accepts either a plain string or sprintf -compatible parameters (format and values), (*9)

// This works
$response = RequestBuilder::create($client)
  ->setUri('/users/'. $email .'/details')
  ...

// This is more readable
$response = RequestBuilder::create($client)
  ->setUri('/users/%s/details', $email)
  ...

ResponseWrapper

A decorator for Symfony\Component\HttpFoundation\Response that wraps the response and provides few semantic issers to make asserts more readable, (*10)

Usage

// Before
$client->request($method, $uri, $parameters, $files, $server, $content);
$response = $client->getResponse();
$this->assertEquals(200,$response->getStatusCode())

// After
$response = RequestBuilder::create($client)
  ...
  ->getResponse();
$this->assertTrue($response->isOk());

List of issers

  • isBadRequest
  • isCreated
  • isEmpty
  • isForbidden
  • isNotFound
  • isOk
  • isUnauthorized
  • isUnprocessable

getJsonContent

Get a JSON decoded body from the response, (*11)

// Before
$response = $client->request($method, $uri, $parameters, $files, $server, $content);
$data = json_decode($client->getResponse());

// After
$data = RequestBuilder::create($client)
  ...
  ->getResponse()
  ->getJsonContent();

The Versions

13/07 2018

dev-master

9999999-dev

A few helpers to ease functional API testing in Symfony

  Sources   Download

MIT

The Requires

 

13/07 2018

2.0.2

2.0.2.0

A few helpers to ease functional API testing in Symfony

  Sources   Download

MIT

The Requires

 

03/07 2018

2.0.1

2.0.1.0

A few helpers to ease functional API testing in Symfony

  Sources   Download

MIT

The Requires

 

27/06 2018

2.0.0

2.0.0.0

A few helpers to ease functional API testing in Symfony

  Sources   Download

MIT

The Requires

 

27/05 2018

1.0.1

1.0.1.0

A few helpers to ease functional API testing in Symfony

  Sources   Download

MIT

The Requires

 

19/03 2018

1.0.0

1.0.0.0

A few helpers to ease functional API testing in Symfony

  Sources   Download

MIT

The Requires