BenchPress

47 0

BenchPress

BenchPress is a WordPress® plugin for benchmarking PHP code snippets, WordPress® queries, and other critical operations.

It's designed to help developers evaluate and optimize code performance by running benchmarks and capturing snapshots for later comparison.


Table of Contents

Installation

  1. Download the plugin ZIP from the GitHub repository.
  2. Upload it via WordPress® Admin:
    • Go to Plugins > Add New.
    • Click Upload Plugin, select the downloaded ZIP, and click Install Now.
  3. Activate the plugin via the Plugins page in the WordPress® Admin.

Setup

BenchPress automatically creates a custom database table to store snapshots of benchmark results on activation. The plugin also includes settings to customize benchmark runs. To configure these:

  1. Go to BenchPress > Settings in your WordPress® admin sidebar.
  2. Adjust loop counts, post IDs, and other options to customize how each benchmark runs.

Usage

Once installed and configured, you can run benchmarks, view results, and save snapshots for later reference:

  1. Running Benchmarks:

    • Navigate to BenchPress in your WordPress® admin menu.
    • Click Refresh Tests to run all enabled benchmarks and view results.
  2. Saving Snapshots:

    • On the main BenchPress page, click Save Snapshot to save a record of the current benchmark results.
  3. Viewing Snapshots:

    • Go to BenchPress > Snapshots to view all saved snapshots. Each snapshot can be viewed, downloaded, or deleted.
      • *

Available Benchmarks

BenchPress comes with several built-in benchmarks. Here's a quick overview:

  • Switch vs. Match: Compares the performance of PHP switch vs match statements.
  • Transient vs. Direct Query: Tests the speed of transient caching against direct database queries.
  • Post Meta Access: Compares get_post_meta() with WP_Meta_Query for retrieving post meta data.
  • WP_Query by ID: Measures query performance for retrieving single or multiple posts.
  • Array Merge vs. Union: Compares array_merge with the array union (+) operator.
  • String Concatenation: Benchmarks PHP's . operator vs sprintf.
    • *

Customizing Benchmarks

Adding Custom Benchmarks

BenchPress includes a benchpress_run_all_benchmarks filter to allow you to add custom benchmarks. Here's an example of how to add your own benchmark:

add_filter( 'benchpress_run_all_benchmarks', function( $benchmarks ) {
    // Define your custom benchmark
    $benchmarks[] = custom_benchmark_example();
    return $benchmarks;
});

// Custom benchmark function
function custom_benchmark_example() {
    $loop_count = get_option( 'custom_benchmark_loop_count', 100000 );
    $start_time = microtime( true );

    for ( $i = 0; $i < $loop_count; $i++ ) {
        $result = $i * 2; // Example operation
    }

    $execution_time = microtime( true ) - $start_time;

    return [
        'name'          => esc_html__( 'Custom Benchmark', 'benchpress' ),
        'execution_time'=> round( $execution_time, 5 ),
        'description'   => sprintf( esc_html__( 'Executed a loop of %d iterations.', 'benchpress' ), $loop_count ),
    ];
}

Removing Benchmarks

If you want to remove a specific benchmark, you can use the same benchpress_run_all_benchmarks filter. For example, to remove the "Switch vs Match" benchmark:

add_filter( 'benchpress_run_all_benchmarks', function( $benchmarks ) {
    return array_filter( $benchmarks, function( $benchmark ) {
        return $benchmark['name'] !== esc_html__( 'Switch vs Match', 'benchpress' );
    });
});

Accessing Benchmark Data

To access saved snapshots for analysis or custom display, use the custom database table created by BenchPress, which stores each snapshot as JSON data.


Snapshots

Snapshots are records of benchmark results that you can refer back to later. Snapshots can be managed in the BenchPress > Snapshots page:

  • Clear Snapshots: Clears all stored snapshots.
  • Download Snapshots: Downloads all snapshots as a CSV file.
    • *

Plugin Settings

To configure BenchPress benchmarks, navigate to BenchPress > Settings. Options include:

  • Loop Count for Benchmarks: Set the number of iterations for each benchmark.
  • Enable Benchmarks: Select which benchmarks to run.
  • WP_Query Settings: Configure WP_Query options, including post types, IDs, taxonomy terms, etc.
    • *

Contributing

BenchPress is an open-source project, and contributions are welcome!

To contribute:

  1. Fork the repository.
  2. Create a new branch for your feature or fix.
  3. Submit a pull request with a clear description of your changes.

The following is a list of the most recent releases for this plugin.

  • 1.1.0 - 1.1.0 / Nov 18th, 2024

    * [📦 NEW: Added benchpress_admin_header helper function](https://github.com/robertdevore/benchpress/commit/057921bdc32b0d1d7be7a56aa124d3af19fd8577) * [📦 NEW: Added 'settings' link to Plugins page](https://github.com/robertdevore/benchpress/commit/f36bebff527cd2e65f50ac1d04fc4fedea952fe6) * [📦 NEW: Added Spanish translation](https://github.com/robertdevore/benchpress/commit/e2ac95b4747bd3ae77f2a0c7f7548f46ad2f2fea) * [👌 IMPROVE: General code cleanup](https://github.com/robertdevore/benchpress/commit/9d296afe29073b57b1554ef9298f2ce31261864b) * [👌 IMPROVE: Updated text strings for localization](https://github.com/robertdevore/benchpress/commit/a06865769ffa22f3203b9bcdc274e7b62d0e95f9)

    SHA256 hash:
    cf3d6d379edacd093d37a9f56cb5e56a162cfbbf84ed5b1b5764c8abe927cf59
  • 1.0.2 - 1.0.2 / Nov 14th, 2024

    * [🐛 BUG: Fixed assets loading on pages outside of BenchPress specific pages](https://github.com/robertdevore/benchpress/commit/9be50870d00d0b423da58dd46b42ce0058aa4846)

    SHA256 hash:
    5ea8be56631e8ef8b243906fd71ea0fb34034bc5fd0745a09ac191b826f4e853
  • 1.0.1 - 1.0.1 / Nov 12th, 2024

    * [👌 IMPROVE: Updated benchmarks for PHP 7.4 compatibility](https://github.com/robertdevore/benchpress/commit/6811631d327bf833d99c249d8f8a7e909ddc7500) * [👌 IMPROVE: Updated text strings for localization](https://github.com/robertdevore/benchpress/commit/304472a7c47d56e4e2f9b6e0e27aeda3f490798b)

    SHA256 hash:
    d3810d0155c9079b9cb6abe52d7d2fa40ed5f09caf4b0ccb0323d3c330ec1dc4
  • 1.0.0 - 1.0.0 / Nov 11th, 2024

    * Initial release

    SHA256 hash:
    b9e88fa4315567ffdae15daa9710d7900f544f02bede1153e0fd358878657c10

The following is a list of the most recent issues for this plugin.

  • User avatar
    [BUG] Bulk actions on the Plugins page are hidden
    Nov 14th, 2024

    This is happening because you are loading the benchpress assets on every admin screen. Possible solutions are: ### 1. Only load the benchpress assets on benchpress admin pages (unless they are needed globally). For example: ```php function benchpress_enqueue_assets(): void { if (!str_contains(get_current_screen()->base, 'page_benchpress')) { return; } // enqueue assets here... } add_action('admin_enqueue_scripts', 'benchpress_enqueue_assets'); ``` ### 2. Override the protected `display_tablenav` method in your extended `WP_List_Table` classes. For example: ```php protected function display_tablenav($which) { if ('top' === $which) { return; } parent::display_tablenav($which); } ``` ### 3. Prefix your CSS selectors with the page specific body class. For example: ```css [class*="page_benchpress"] .tablenav.top { display: none; } ```

  • User avatar
    [FR] Add snippets from the UI
    Nov 13th, 2024

    Interesting plugin! Have you considered allowing people to add a benchmark snippet from the admin? It could be a similar UI to the [Code Snippets](https://wordpress.org/plugins/code-snippets/) plugin. <img width="833" alt="image" src="https://github.com/user-attachments/assets/de01103c-6643-4334-a03f-dc4f6186d9c4">

  • User avatar
    Plugin could not be activated because it triggered a fatal error.
    Nov 12th, 2024

    Screenshot of report attached. Using WPEngine, php 7.4 ``` Parse error: syntax error, unexpected '=>' (T_DOUBLE_ARROW) in /nas/content/live/wwwuatbestegg/wp-content/plugins/benchpress-main/includes/helper-functions.php on line 43 ``` ![Screenshot 2024-11-11 at 10 35 05 AM](https://github.com/user-attachments/assets/f1825a19-b17d-4aad-ab84-8c4791e61ff5)

Hash Verification

ZIP files downloaded via this site have an associated SHA256 hash.

Mac

On Mac, you can use the sha256 command to calculate the hash of a downloaded ZIP file. Open terminal and execute:

sha256 [filename]

Where [filename] is the name of the ZIP file. If the hash matches the one on the website, the ZIP file is genuine.

Linux

On Linux, you can use the sha256sum command to calculate the hash of a downloaded ZIP file. From a shell, execute:

sha256sum [filename]

Where [filename] is the name of the ZIP file. If the hash matches the one on the website, the ZIP file is genuine.

Latest Release

The latest official release is below.

1.1.0

Nov 18th, 2024
Download 1.1.0
SHA-256 hash:
cf3d6d379edacd093d37a9f56cb5e56a162cfbbf84ed5b1b5764c8abe927cf59

Github Repository

This project is located on Github in the repository robertdevore/benchpress.

Star Support Project