2017 © Pedro Peláez
 

library benchmark

Benchmark package.

image

janiaje/benchmark

Benchmark package.

  • Thursday, March 15, 2018
  • by janiaje
  • Repository
  • 1 Watchers
  • 2 Stars
  • 29 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 12 % Grown

The README.md

Laravel-Benchmark

Adds a Benchmark helper to your project, to get * exact time * elapsed time * RAM usage * queries ran by Eloquent, (*1)

between checkpoints., (*2)

Installation

composer require janiaje/benchmark

If Laravel version < 5.5, you have to manually include the following line in your config/app.php:, (*3)

Janiaje\Benchmark\Provider::class,

Usage (basics)

Use the 'benchmark()' helper to easily access to the Benchmark class

benchmark()

Add checkpoints:

benchmark()->checkpoint();

Get the elapsed time between the first and the last checkpoint

$elapsedTime = benchmark()->getElapsedTime();

Get the maximum amount RAM (in bytes) allocated by PHP in the checkpoints

$ramUsage = benchmark()->getPeakRamUsage();

Get the checkpoints

$checkpoints = benchmark()->getCheckpoints();

Dump the checkpoints

benchmark()->dump();

DD the checkpoints:

benchmark()->dd();

Set the output format for the checkpoints:

benchmark()->setOutputFormat(ArrayFormat::class);
benchmark()->setOutputFormat(JsonFormat::class);

The 2 options mentioned above are available by default. You can override them or make your own, but make sure it implements the \Janiaje\Benchmark\OutputFormats\OutputFormat interface., (*4)

Example of ArrayFormat::class output:, (*5)

Collection {#275 ▼
  #items: array:2 [▼
    0 => array:6 [▼
      "id" => "#1"
      "name" => null
      "group" => null
      "time" => Carbon @1521101210 {#272 ▶}
      "timeDifference" => null
      "ram" => 6291456
      "queries" => []
    ]
    1 => array:6 [▼
      "id" => "#2"
      "name" => null
      "group" => null
      "time" => Carbon @1521101211 {#270 ▶}
      "timeDifference" => DateInterval {#277 ▶}
      "ram" => 6291456
      "queries" => array:1 [▼
        0 => {#279 ▼
          +"query": "SELECT * FROM users WHERE email = ?"
          +"bindings": array:1 [▼
            0 => "janiaje@gmail.com"
          ]
          +"time": 1.15
        }
      ]
    ]
  ]
}

Usage (additional options)

Naming checkpoints

This name will show up in the results so it will be easier to find a specific checkpoint., (*6)

benchmark()->checkpoint("After expensive calculation");
    1 => array:6 [▼
      "id" => "#2"
      "name" => "After expensive calculation"
      "group" => null
      "time" => Carbon @1521101211 {#270 ▶}

Grouping checkpoints

Creating a checkpoint with a group:, (*7)

benchmark()->checkpointWithGroup("File generation");

This group will show up in the results:, (*8)

    1 => array:6 [▼
      "id" => "#2"
      "name" => "After expensive calculation"
      "group" => "File generation"
      "time" => Carbon @1521101211 {#270 ▶}

You can filter the results by groups:, (*9)

benchmark()->getCheckpointsByGroup("File generation");

Deleting checkpoints

Delete all checkpoints:, (*10)

benchmark()->deleteAllCheckpoints();

Delete checkoints by group:, (*11)

benchmark()->deleteCheckpoints("File generation");

Delete checkoints by id:, (*12)

$checkpoint = benchmark()->checkpoint();
benchmark()->deleteCheckpoint($checkpoint->getId();

If you dont want to delete them, you can always create your own Benchmark instances and collect everythign sepearately:, (*13)

$benchmark1 = new Benchmark;
$benchmark1->checkpoint();
$benchmark1->getAllCheckpoints();

$benchmark2 = new Benchmark;
$benchmark2->checkpoint();
$benchmark2->getAllCheckpoints();

The Versions

15/03 2018

dev-master

9999999-dev

Benchmark package.

  Sources   Download

MIT

The Requires

 

by János Tihanyi

laravel benchmark

15/03 2018

v1.0.1

1.0.1.0

Benchmark package.

  Sources   Download

MIT

The Requires

 

by János Tihanyi

laravel benchmark

04/02 2018

v1.0.0

1.0.0.0

Benchmark package.

  Sources   Download

MIT

The Requires

 

by János Tihanyi

laravel benchmark