* Date: 9/12/14 * Time: 10:45 PM. * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace NilPortugues\Tests\Sql\QueryBuilder\Builder\Syntax; use NilPortugues\Sql\QueryBuilder\Builder\GenericBuilder; use NilPortugues\Sql\QueryBuilder\Manipulation\Insert; /** * Class InsertWriterTest. */ class InsertWriterTest extends \PHPUnit_Framework_TestCase { /** * @var GenericBuilder */ private $writer; /** * @var Insert */ private $query; /** * @var string */ private $exceptionClass = '\NilPortugues\Sql\QueryBuilder\Manipulation\QueryException'; /** * */ protected function setUp() { $this->writer = new GenericBuilder(); $this->query = new Insert(); } /** * @test */ public function itShouldThrowQueryExceptionBecauseNoColumnsWereDefined() { $this->setExpectedException($this->exceptionClass, 'No columns were defined for the current schema.'); $this->query->setTable('user'); $this->writer->write($this->query); } /** * @test */ public function itShouldWriteInsertQuery() { $valueArray = array( 'user_id' => 1, 'name' => 'Nil', 'contact' => 'contact@nilportugues.com', ); $this->query ->setTable('user') ->setValues($valueArray); $expected = 'INSERT INTO user (user.user_id, user.name, user.contact) VALUES (:v1, :v2, :v3)'; $this->assertSame($expected, $this->writer->write($this->query)); $this->assertEquals(\array_values($valueArray), \array_values($this->query->getValues())); $expected = array(':v1' => 1, ':v2' => 'Nil', ':v3' => 'contact@nilportugues.com'); $this->assertEquals($expected, $this->writer->getValues()); } /** * @test */ public function itShouldBeAbleToWriteCommentInQuery() { $valueArray = array( 'user_id' => 1, 'name' => 'Nil', 'contact' => 'contact@nilportugues.com', ); $this->query ->setTable('user') ->setComment('This is a comment') ->setValues($valueArray); $expected = "-- This is a comment\n".'INSERT INTO user (user.user_id, user.name, user.contact) VALUES (:v1, :v2, :v3)'; $this->assertSame($expected, $this->writer->write($this->query)); $this->assertEquals(\array_values($valueArray), \array_values($this->query->getValues())); $expected = array(':v1' => 1, ':v2' => 'Nil', ':v3' => 'contact@nilportugues.com'); $this->assertEquals($expected, $this->writer->getValues()); } }