PHP Classes

File: tests/performance.php

Recommend this page to a friend!
  Classes of AlexanderC   PStorage   tests/performance.php   Download  
File: tests/performance.php
Role: Example script
Content type: text/plain
Description: Unit test script
Class: PStorage
Store and retrieve objects in flat files
Author: By
Last change: Update of tests/performance.php
Date: 8 months ago
Size: 3,381 bytes
 

Contents

Class file image Download
<?php
/**
 * @author AlexanderC
 *
 * This results are returned with native PHP serialization, MsgPack would give better results...
 * Note: that also means that in case of same field values each time would be considerable improvements
 *
 * IMPORTANT: The time of CRUD operations would increase considerably if we have an comparable value.
 * For example for inserting 1000 entries with same data(except comparable field) when having
 * just one comparable field will cost 19.5728 seconds. But selection of an range of values costs
 * the same as simple selection(~ 0.0172 seconds from the middle of the tree, up to 100 rows).
 * The only limitation is the size of binary tree file that will grow up considerable and
 * does require a lot of RAM in cases you have more entries with different comparable fields values.
 *
 * Results, when all fields different each time:
 * 1000 entries are created with all infrastructure in 3.9936 seconds
 * 1000 entries are counted without filters in 0.0007 seconds
 * 1000 entries are returned without filters in 0.0453 seconds
 * find one entry by multiple reference field from 1000 entries in 0.0013 seconds
 * find one entry by single reference field from 1000 entries in 0.0010 seconds
 * find entries range with pk offset 500 and limit 100 (#501-#601) from 1000 entries in 0.0069 seconds
 *
 * Results, when all fields same each time:
 * 1000 entries are created with all infrastructure in 4.0991 seconds
 * 1000 entries are counted without filters in 0.0008 seconds
 * 1000 entries are returned without filters in 0.0460 seconds
 * find one entry by multiple reference field from 1000 entries in 0.1185 seconds
 * find one entry by single reference field from 1000 entries in 0.1197 seconds
 * find entries range with pk offset 500 and limit 100 (#501-#601) from 1000 entries in 0.0069 seconds
 */

require __DIR__ . "/Post.php";
require
__DIR__ . "/Timer.php";

$timer = new Timer();

/*
$post = new Post();

$timer->start();
var_dump($post->findRangeOfComparable(500, 600, 'old_id')->count());
$timer->stop();

//*/

/*

$timer->start();
for($i = 0; $i < 1000; $i++) {
    $post = new Post();
    $post->setTitle('new title');
    $post->setText('Lorem ipsum dolor sit amet...');
    $post->setTags([
        'tag1', 'tag2', 'testtag'
    ]);
    $post->setOld_id($i);

    $post->save();
}
$timer->stop();

//*/

/*
$rand = rand(0, 100000);

$timer->start();
for($i = 0; $i < 1000; $i++) {
    $post = new Post();
    $post->setTitle('new title' . $rand);
    $post->setText('Lorem ipsum dolor sit amet...' . $rand);
    $post->setTags([
        'tag1' . $rand, 'tag2' . $rand, 'testtag' . $rand
    ]);

    $post->save();
}
$timer->stop();

//*/

/*
$post = new Post();

$timer->start();
var_dump($post->countAll());
$timer->stop();

//*/

/*
$post = new Post();

$timer->start();
var_dump($post->findAll()->count());
$timer->stop();

//*/

/*
$post = new Post();

$timer->start();
var_dump($post->findOneByTags('tag1')->getTitle());
$timer->stop();

//*/

/*
$post = new Post();

$timer->start();
var_dump($post->findOneByTitle('new title')->getTags());
$timer->stop();

//*/

/*
$post = new Post();

$timer->start();
var_dump($post->findRangeByPrimaryKey(500, 100, Post::COMPARATOR_GREATER)->count());
$timer->stop();
//*/

echo $timer->format() . "\n";