<?php 
namespace eMapper\SQLite\Mapper\ScalarMapper; 
 
use eMapper\SQLite\SQLiteTest; 
 
/** 
 * Test SQLiteMapper with boolean values 
 * @author emaphp 
 * @group sqlite 
 * @group mapper 
 * @group boolean 
 */ 
class BooleanTypeTest extends SQLiteTest { 
    public function testBoolean() { 
        $result = self::$mapper->type('boolean')->query("SELECT NULL"); 
        $this->assertNull($result); 
         
        $value = self::$mapper->type('b')->query("SELECT refurbished FROM products WHERE product_id = 1"); 
        $this->assertFalse($value); 
     
        $value = self::$mapper->type('boolean')->query("SELECT * FROM products WHERE product_id = 5"); 
        $this->assertTrue($value); 
     
        $result = self::$mapper->type('bool')->query("SELECT 'T'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('bool')->query("SELECT 'F'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertFalse($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 't'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 'f'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertFalse($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 'true'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 'false'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertFalse($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 'TRUE'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 'FALSE'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertFalse($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 0"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertFalse($result); 
     
        $result = self::$mapper->type('b')->query("SELECT 1"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT user_id FROM users WHERE user_name = 'jdoe'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT user_name FROM users WHERE user_name = 'jdoe'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT birth_date FROM users WHERE user_name = 'jdoe'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT last_login FROM users WHERE user_name = 'jdoe'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT newsletter_time FROM users WHERE user_name = 'jdoe'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT avatar FROM users WHERE user_name = 'jdoe'"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT price FROM products WHERE product_id = 1"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT rating FROM products WHERE product_id = 1"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT manufacture_year FROM products WHERE product_id = 1"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
     
        $result = self::$mapper->type('b')->query("SELECT discount FROM sales WHERE sale_id = 1"); 
        $this->assertInternalType('boolean', $result); 
        $this->assertTrue($result); 
    } 
     
    public function testBooleanColumn() { 
        $value = self::$mapper->type('bool', 'refurbished')->query("SELECT * FROM products WHERE product_id = 1"); 
     
        $this->assertInternalType('boolean', $value); 
        $this->assertFalse($value); 
    } 
     
    public function testBooleanList() { 
        $values = self::$mapper->type('bool[]')->query("SELECT refurbished FROM products ORDER BY product_id ASC"); 
     
        $this->assertInternalType('array', $values); 
        $this->assertCount(5, $values); 
     
        $this->assertFalse($values[0]); 
        $this->assertFalse($values[1]); 
        $this->assertFalse($values[2]); 
        $this->assertFalse($values[3]); 
        $this->assertTrue($values[4]); 
    } 
     
    public function testBooleanColumnList() { 
        $values = self::$mapper->type('bool[]', 'refurbished')->query("SELECT * FROM products ORDER BY product_id ASC"); 
     
        $this->assertInternalType('array', $values); 
        $this->assertCount(5, $values); 
     
        $this->assertFalse($values[0]); 
        $this->assertFalse($values[1]); 
        $this->assertFalse($values[2]); 
        $this->assertFalse($values[3]); 
        $this->assertTrue($values[4]); 
    } 
} 
 
?>
 
 |