Skip to content

ArrayIterator/Php.Profiler

Repository files navigation

PHP Profiler

Code Checking

INSTALLATION

composer require arrayiterator/profiler

PROFILING

use ArrayIterator\Profiler\Profiler;

$profiler = new Profiler();
// start the profiler
$performance = $profiler->start('benchmark', 'Group Name', ['data' => 'information']);
try {
    // do something with the code
    // write the code that you want to benchmark
} finally {
    // best practice to stop the profiler using try -> finally
    // using finally to make sure the profiler is stopped
    $performance->stop(['additional' => 'information']);
    // or using profiler object
    // the group name is important when you have different group of benchmark
    // the group: default, as default group
    // the name of benchmark also important to identify the benchmark
    $profiler->stop('benchmark', 'Group Name', ['additional' => 'information']);
}

RENDERING TOOLBAR

/**
 * @var \ArrayIterator\Profiler\Profiler $profiler 
 */
$waterfall = $profiler->getWaterfall();

// render the toolbar
$darkMode = null; // set true if default dark mode or let it null when using autodetect
$content = $waterfall->renderJs($darkMode);

// can be echo or append to stream
// echo $content;
// append to stream interface (PSR-7)
// $response->getBody()->write($content);

PREVIEW

Toolbar Preview Toolbar Preview

ATTENTION

This package still under development, the profiler is ready but the UI is not yet ready. The UI is still under development.

But the profiler is ready to use, you can use it by installing the package and use the profiler. You can customize the implementation of the Frontend or Backend.

UI & IMPLEMENTATION OF RENDERER

Typescript & scss [assets] is used to create the UI, the UI is created using the following technologies:

Maximum record size is 5000 records, if more than 5000 records, the UI will not render the benchmark. (maximum record size can be changed in the preferences). When the record less than 5000 and set less than record, can be reset with:

window.arrayiterator_waterfall.set_max_records(5000);

REQUIREMENT:

  • PHP 7.4 or later
  • Composer
  • DEV (Node.js (npm) - for installing the dependencies)

TASKS

BACKEND

  • Benchmark Profiler
  • Memory Profiler
  • Time Profiler
  • Render Profiler
  • Code Styling & PhpStan

FRONTEND

  • ToolBar (Chrome Like)
  • Dark Mode & Light Mode (Auto Detect)
  • Resizeable
  • Responsiveness
  • Action Size
    • Maximize
    • Minimize (restore)
    • Close
  • Benchmark Tab
    • Filtering
    • Waterfall Profiling
    • Importer
    • Exporter
    • Restorer
    • Message (information about the import, export, restore)
    • Input Search
    • Horizontal Resizable Section
  • Labs Tab (Under Development)
    • Profiler Information
    • Metadata of JSON
    • RAM Usage & Limit (chart using pie chart from highchart.js)
    • Additional Information
    • Chart for benchmark
  • Source Tab

Benchmark Tab

  • Filtering
    • Importer
    • Exporter
    • Restorer
    • Message (information about the import, export, restore)
    • General Filter
    • Performance Filter (Slow, Fast, Average)
    • Search Filter (Follow the benchmark content)
    • Aggregator Filter (Follow the benchmark aggregation)
  • Waterfall Profiling
    • Using waterfall using div percentage
    • Add additional information for certain table
    • Clickable to show the detail of the benchmark

Labs Tab

  • Profiler Information
    • Metadata of JSON
    • RAM Usage & Limit (chart using pie chart from highchart.js)
    • Additional Information
    • Chart for benchmark

Source Tab

  • Code Section
    • Prettify/Minify the source code
    • Download the source code
    • Import the source code

DEPENDENCIES

NOTE

Rendering benchmark & source code using looping og setTimeout to make sure the rendering is not blocking the main thread.

LICENSE

MIT License