Download the PHP package spatie/pest-plugin-route-testing without Composer

On this page you can find all versions of the php package spatie/pest-plugin-route-testing. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package pest-plugin-route-testing

Make sure all routes in your Laravel app are ok

In a typical Laravel application there are many pages that can be accessed by users. It's easy to forget to test all of them. This package makes it easy to test all GET routes in your application.

Here's a quick example:

This will test all GET routes in your application and ensure they return a 200 HTTP status code. Here's what the output looks like when you run this test in a small app.

screenshot

Instead of assertSuccessful() you can use any assertion that is available in Laravel's TestResponse class, such as assertRedirect(), assertNotFound(), assertForbidden(), etc.

You can also test specific routes:

If you there are routes that have route model bindings, the package will skip the test for those routes. Let's assume you have a route defined as user/{user}. Here's what the output looks like when you run the test.

screenshot

If you want to test a route with a route model binding, you can provide the model using the bind method.

When you run the test now, the package will use the provided model to test the route.

screenshot

Support us

We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.

We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.

Installation

You can install the package via composer:

Usage

You can use the routeTesting function to test all routes in your application.

This will test all GET routes in your application and ensure they return a 200 HTTP status code. Here's what the output looks like when you run this test in a small app.

screenshot

Instead of assertSuccessful() you can use any assertion that is available in Laravel's TestResponse class, such as assertRedirect(), assertNotFound(), assertForbidden(), etc.

Here's an example where we test if a redirect is working.

Testing specific routes

You can test specific routes by using the include method. There is support for wildcards. Here's an example that tests all routes that start with blog.

You can also pass as many arguments as you want to the include method.

Excluding routes

If you want to exclude routes from the test, you can use the exclude method. Here's an example that tests all routes except the ones that start with admin.

Binding route model bindings

If you there are routes that have route model bindings, the package will skip the test for those routes. Let's assume you have a route defined as user/{user}. Here's what the output looks like when you run the test.

screenshot

If you want to test a route with a route model binding, you can provide the model using the bind method.

When you run the test now, the package will use the provided model to test the route.

screenshot

If you don't want to display tests that are skipped because of a missing model binding, you can call ignoreRoutesWithMissingBindings().

Executing custom code before the test

You can use the setUp method to execute code before the route test is run. Here's an example where we log in a user before running the test.

Testing

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.


All versions of pest-plugin-route-testing with dependencies

PHP Build Version
Package Version
Requires php Version ^8.1
nunomaduro/termwind Version ^1.15.1|^2.0
pestphp/pest Version ^2.34.9
pestphp/pest-plugin Version ^2.1.1
spatie/laravel-package-tools Version ^1.16.4
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package spatie/pest-plugin-route-testing contains the following files

Loading the files please wait ....