index.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. require_once 'vendor/autoload.php';
  3. error_reporting(-1);
  4. Flight::register('db', PDO::class, [ 'mysql:host=tfb-database;port=3306;dbname=hello_world', 'benchmarkdbuser', 'benchmarkdbpass', [ \PDO::ATTR_PERSISTENT => TRUE ] ]);
  5. // JSON test
  6. Flight::route('/json', function() {
  7. Flight::json(['message' => 'Hello, World!']);
  8. });
  9. // Plaintext test
  10. Flight::route('/plaintext', function() {
  11. Flight::response()
  12. ->header('Content-Type', 'text/plain');
  13. echo 'Hello, World!';
  14. });
  15. // DB test
  16. Flight::route('/db', function() {
  17. $id = mt_rand(1, 10000);
  18. $db = Flight::db();
  19. $stmt = $db->prepare('SELECT * FROM World WHERE id = ?');
  20. $stmt->execute([ $id ]);
  21. $world = $stmt->fetch();
  22. // Cast fields to int so they don't get wrapped with quotes
  23. $world = [
  24. 'id' => (int) $world['id'],
  25. 'randomNumber' => (int) $world['randomNumber']
  26. ];
  27. Flight::json($world);
  28. });
  29. // DB multiple test
  30. Flight::route('/db-multiple', function () {
  31. $queries = Flight::request()->query['queries'];
  32. if (is_numeric($queries)) {
  33. $queries = max(1, min($queries, 500));
  34. } else {
  35. $queries = 1;
  36. }
  37. $db = Flight::db();
  38. $stmt = $db->prepare('SELECT * FROM World WHERE id = ?');
  39. $worlds = [];
  40. for ($i = 0; $i < $queries; ++$i) {
  41. $random_id = mt_rand(1, 10000);
  42. $stmt->execute([ $random_id ]);
  43. $world = $stmt->fetch();
  44. // Cast fields to int so they don't get wrapped with quotes
  45. $world = [
  46. 'id' => (int) $world['id'],
  47. 'randomNumber' => (int) $world['randomNumber']
  48. ];
  49. $worlds[] = $world;
  50. }
  51. Flight::json($worlds);
  52. });
  53. // DB Update Test
  54. Flight::route('/updates', function () {
  55. $queries = Flight::request()->query['queries'];
  56. if (is_numeric($queries)) {
  57. $queries = max(1, min($queries, 500));
  58. } else {
  59. $queries = 1;
  60. }
  61. $db = Flight::db();
  62. $select_stmt = $db->prepare('SELECT id FROM World WHERE id = ?');
  63. $update_stmt = $db->prepare('UPDATE World SET randomNumber = ? WHERE id = ?');
  64. $worlds = [];
  65. for ($i = 0; $i < $queries; ++$i) {
  66. $id = mt_rand(1, 10000);
  67. $random_number = mt_rand(1, 10000);
  68. $select_stmt->execute([$id]);
  69. $world = $select_stmt->fetch();
  70. $world = [
  71. 'id' => (int) $world['id'],
  72. 'randomNumber' => $random_number
  73. ];
  74. $update_stmt->execute([ $random_number, (int) $world['id'] ]);
  75. $worlds[] = $world;
  76. }
  77. Flight::json($worlds);
  78. });
  79. // Fortunes Test
  80. Flight::route('/fortunes', function() {
  81. $db = Flight::db();
  82. $fortunes = $db->query('SELECT * FROM Fortune')->fetchAll(PDO::FETCH_KEY_PAIR);
  83. $fortunes[0] = 'Additional fortune added at request time.';
  84. asort($fortunes);
  85. Flight::render('fortunes.php', [ 'fortunes' => $fortunes ]);
  86. });
  87. Flight::start();