tyler36/phpunit-helper-traits

There is no license information available for the latest version (v1.0) of this package.

Additional phpunit traits to complement Laravel testing

v1.0 2016-07-11 06:35 UTC

This package is auto-updated.

Last update: 2024-10-29 04:09:26 UTC


README

``# PHPUnit Traits

Installation

1.Install package through composer.

   composer require tyler36/phpunit-helper-traits

Intro

These traits were designed and tested with Laravel 5.2, with Laravel-elixir 5. Using laravel-elixir's 'visit' command will test a page is available and generate a crawler object used for some of the tests. Check the tests directory for further examples and uses.

CheckAssetExistsTrait

Check if item/s are available, and also appears on the page. If the string starts with 'http', this trait will make a HTTP request to the web and check if the asset is available. Usefully for checking CDNs. Other paths will begin looking in the projects 'public' directory ("app()->publicPath()"). If the tests has a crawler object, this trait will also check if the string is displayed on the page.

*Returns TEST case to allow chaining.

USE: Include trait within class - use tyler36\phpunitTraits\CheckAssetExistsTrait;

Call trait with filename or array - $this->checkAssetExists($filename);

EG.

$this->checkAssetExists("https://code.jquery.com/jquery-3.1.0.min.js");

$this->checkAssetExists("/robots.txt");

$this->checkAssetExists(["js/jquery.js", "css/main.css"]);

$this->visit('/home')->checkAssetExists("/images/logo.jpg")

CountElementsTrait

Check page and counts occurrence of specified CSS selector.

USE: Include trait within class - use tyler36\phpunitTraits\CountElementsTrait;

Call trait with CSS selector and expected count - $this->countElements($selector, $count);

EG. $this->countElements('.card', 3);

DisableExceptionHandlerTrait

This trait overwrites the default exception handler, allowing you to check error messages with assertions.

USE: Include trait within class - use tyler36\phpunitTraits\DisableExceptionHandlerTrait;

Call trait with CSS selector to disable exception handling - $this->disableExceptionHandling()

Use TRY / CATCH in test.

ImpersonateTrait

Helper for setting authenticated state.

asGuest

Ensure current status is guest (logged out).

USE: Include trait within class - use tyler36\phpunitTraits\CountElementsTrait;

EG.

$this->asGuest();

asMember

Ensure current status is member (logged out). If a user object is passed, this trait will login as that user. If no user object is passed, this trait will use a 'App\User' factory to create a random User object and log in.

USE: Include trait within class - use tyler36\phpunitTraits\CountElementsTrait;

EG.

$this->asMember();

MailTrackingTrait

Inspired by phpunit-testing-in-laravel Check mail options by intercepting sent mails. You may want to prevent laravel from sending mail by using the log driver; in a test or setUp() function

config()->set('mail.driver', 'log');

USE: Include trait within class - use tyler36\phpunitTraits\MailTrackerTrait;

seeEmailWasNotSent

ASSERT: Mail was NOT sent

$this->seeEmailWasNotSent();

seeEmailWasSent

ASSERT: Mail was sent

$this->seeEmailWasSent();

seeEmailsSent($count)

ASSERT: $count number of emails were sent

$this->seeEmailsSent(3)

seeEmailTo($recipient)

ASSERT: Recipient

$this->seeEmailTo($recipient);

seeEmailNotTo($recipient)

ASSERT: NOT Recipient

$this->seeEmailNotTo($recipient);

seeEmailFrom($sender)

ASSERT: Sender

$this->seeEmailFrom($sender);

seeEmailNotFrom($sender)

ASSERT: NOT Sender

$this->seeEmailNotFrom($sender);

seeEmailEquals($body)

ASSERT: Body Matches

$this->seeEmailEquals($body);

seeEmailNotEquals($body)

ASSERT: Body NOT Matches

$this->seeEmailNotEquals($body);

seeEmailContains($excerpt)

ASSERT: Body contains fragment

$this->seeEmailContains($excerpt);

seeEmailNotContains($excerpt)

ASSERT: Body NOT contains fragment

$this->seeEmailNotContains($excerpt);

seeEmailSubjectEquals($subject)

ASSERT: Subject Matches

$this->seeEmailSubjectEquals($subject);

seeEmailSubjectNotEquals($subject)

ASSERT: Subject NOT Matches

$this->seeEmailSubjectNotEquals($subject);

seeEmailSubjectContains($excerpt)

ASSERT: Subject contains

$this->seeEmailSubjectContains($fragment);

seeEmailSubjectNotContains($excerpt)

ASSERT: Subject NOT contains

$this->seeEmailSubjectNotContains($fragment);

PrepareFileUploadTrait

Simulate a file upload

Include trait within class - use tyler36\phpunitTraits\PrepareFileUploadTrait;

Call trait with filename or array - $this->prepareUpload($file)

EG. $this->prepareUpload('./avatar.jpg');