PHP Classes

File: tests/SingleTestThenExistsTest.php

Recommend this page to a friend!
  Packages of Scott Arciszewski   EasyDB   tests/SingleTestThenExistsTest.php   Download  
File: tests/SingleTestThenExistsTest.php
Role: Class source
Content type: text/plain
Description: Class source
Class: EasyDB
Simple Database Abstraction Layer around PDO
Author: By
Last change: Test Improvements + Mutation Testing (#168)

* Update testing frameworks
* Add infection for mutation tests
* Modernize PHPUnit usage
Date: 2 months ago
Size: 2,003 bytes
 

Contents

Class file image Download
<?php
declare(strict_types=1);

namespace
ParagonIE\EasyDB\Tests;

use
ParagonIE\EasyDB\EasyDB;
use
ParagonIE\EasyDB\Factory;
use
PHPUnit\Framework\Attributes\CoversClass;
use
PHPUnit\Framework\Attributes\DataProvider;


#[CoversClass(EasyDB::class)]
#[CoversClass(Factory::class)]
class SingleTestThenExistsTest extends EasyDBWriteTestCase
{
    protected function
getResultForMethod(EasyDB $db, $statement, $params)
    {
       
$args = $params;
       
array_unshift($args, $statement);
        return
call_user_func_array([$db, 'exists'], $args);
    }

   
/**
     * @dataProvider goodFactoryCreateArgument2EasyDBInsertManyProvider
     * @param callable $cb
     * @param array $insertMany
     */
    #[DataProvider("goodFactoryCreateArgument2EasyDBInsertManyProvider")]
   
public function testExists(callable $cb, array $insertMany): void
   
{
       
$db = $this->easyDBExpectedFromCallable($cb);
       
$this->assertFalse(
           
$db->exists('SELECT COUNT(*) FROM irrelevant_but_valid_tablename')
        );
       
$db->insertMany('irrelevant_but_valid_tablename', $insertMany);
       
$this->assertTrue(
           
$db->exists('SELECT COUNT(*) FROM irrelevant_but_valid_tablename')
        );
        foreach (
$insertMany as $insertVal) {
           
$this->assertTrue(
               
$this->getResultForMethod(
                   
$db,
                   
'SELECT COUNT(*) FROM irrelevant_but_valid_tablename WHERE foo = ?',
                   
array_values($insertVal)
                )
            );
           
$db->delete('irrelevant_but_valid_tablename', $insertVal);
           
$this->assertFalse(
               
$this->getResultForMethod(
                   
$db,
                   
'SELECT COUNT(*) FROM irrelevant_but_valid_tablename WHERE foo = ?',
                   
array_values($insertVal)
                )
            );
        }
       
$this->assertFalse(
           
$db->exists('SELECT COUNT(*) FROM irrelevant_but_valid_tablename')
        );
    }
}