Skip to content

MaplePHP/Unitary

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Unitary – Evidence-Driven PHP Testing Framework

Unitary is a modern PHP testing framework for developers who value speed, precision, and full control. No configuration. No clutter. Just a clean, purpose-built core that can execute 100,000+ tests per second and scales smoothly from quick sanity checks to full integration suites.

Mocking, validation, and assertions are built in from the start, with no plugins, adapters, or bootstrapping required. The CLI is fast and intuitive, the workflow is consistent, and getting started takes seconds. Whether you are validating a single function or an entire system, Unitary lets you move quickly and test with confidence.

Prompt demo


Documentation

Visit the full documentation at:
πŸ‘‰ https://maplephp.github.io/Unitary/


Familiar Syntax. Fast Feedback.

Unitary is designed to feel natural for developers. With clear syntax, built-in validation, and zero setup required, writing tests becomes a smooth part of your daily flow and not a separate chore.

use MaplePHP\Unitary\TestCase;

group("Your grouped test subject", function (TestCase $case) {

    $json = '{"response":{"status":200,"message":"ok"}}';

    $case->expect($json)
         ->isJson()
         ->hasJsonValueAt("response.status", 200)
         ->validate();
});

Next-Gen PHP Testing Framework

Unitary is a lightning-fast, developer-first testing framework for PHP, built from the ground up with zero third-party dependencies and a highly optimized core, not just a wrapper around legacy tools.

πŸš€ Test 100,000+ cases in ~1 second. No config. No bloat. Just results.


πŸ”§ Why Use Unitary?

  • Works out of the box – No setup, no config files.
  • Not built on PHPUnit – Unitary is a standalone framework.
  • 100% agnostic – Every sub-library is purpose-built for speed and control.
  • First-class CLI – Intuitive test runner that works across platforms.
  • Powerful validation – Built-in expectation engine, assert support, and structured output.
  • Mocking included – No external mocking libraries needed.
  • Super low memory usage – Ideal for local runs and parallel CI jobs.

⚑ Lightning-fast Performance

Unitary runs large test suites in a fraction of the time β€” even 100,000+ tests in just 1 second.

πŸš€ That’s up to 50Γ— faster than the most widely used testing frameworks.


Getting Started (Under 1 Minute)

Set up your first test in three easy steps:

1. Install

composer require --dev maplephp/unitary

You can run unitary globally if preferred with composer global require maplephp/unitary.


2. Create a Test File

Create a file like tests/unitary-request.php. Unitary automatically scans all files prefixed with unitary- (excluding vendor/).

Paste this test boilerplate to get started:

use MaplePHP\Unitary\{TestCase};

group("HTTP Request", function(TestCase $case) {

    $request = new Request("GET", "https://example.com/?id=1&slug=hello");

    $case->expect($request->getUri()->getQuery())
        ->hasQueryParam("id", 1)
        ->hasQueryParam("slug", "hello")
        ->validate();
});

πŸ’‘ Tip: Run php vendor/bin/unitary --template to auto-generate this boilerplate code.


3. Run Tests

php vendor/bin/unitary

Need help?

php vendor/bin/unitary --help

The Output:

Prompt demo And that is it! Your tests have been successfully executed!

With that, you are ready to create your own tests!


πŸ“… Latest Release

v2.0.0 This release marks Unitary’s transition from a testing utility to a full framework. With the core in place, expect rapid improvements in upcoming versions.


🧱 Built From the Ground Up

Unitary stands on a solid foundation of years of groundwork. Before Unitary was possible, these independent components were developed:

This full control means everything works together, no patching, no adapters and no guesswork.


Philosophy

Test everything. All the time. Without friction.

TDD becomes natural when your test suite runs in under a second, even with 100,000 cases. No more cherry-picking. No more skipping.


Like The CLI Theme?

That’s DarkBark. Dark, quiet, confident, like a rainy-night synthwave playlist for your CLI.

Download it here


🀝 Contribute

Unitary is still young β€” your bug reports, feedback, and suggestions are hugely appreciated.

If you like what you see, consider:

  • Reporting issues
  • Sharing feedback
  • Submitting PRs
  • Starring the repo ⭐

πŸ“¬ Stay in Touch

Follow the full suite of MaplePHP tools:

Contributors 3

  •  
  •  
  •  

Languages