Skip to content

Commit

Permalink
Test for Phalcon integration
Browse files Browse the repository at this point in the history
  • Loading branch information
tzatrepalek-inwk committed Feb 25, 2019
1 parent 4f69bbe commit 73c3e05
Show file tree
Hide file tree
Showing 7 changed files with 175 additions and 2 deletions.
5 changes: 5 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@ php:
- 7.2
- 7.3

cache:
directories:
- ~/cphalcon

matrix:
fast_finish: true

Expand All @@ -23,6 +27,7 @@ before_script:

- composer self-update
- composer install --no-interaction --no-progress
- if [[ $TRAVIS_PHP_VERSION == "5.5" ]] || [[ $TRAVIS_PHP_VERSION == "5.6" ]] || [[ $TRAVIS_PHP_VERSION == "7.0" ]] || [[ $TRAVIS_PHP_VERSION == "7.1" ]] || [[ $TRAVIS_PHP_VERSION == "7.2" ]]; then vendor/bin/install-phalcon.sh 3.4.x; fi

script:
- ./tests/run-unit.sh
Expand Down
1 change: 1 addition & 0 deletions composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
"symfony/console": "~2.6 | ~3.0 | ~4.0",
"symfony/dependency-injection": "~2.6 | ~3.0 | ~4.0",
"symfony/http-kernel": "~2.6 | ~3.0 | ~4.0",
"techpivot/phalcon-ci-installer": "~1.0",
"tracy/tracy": "^2.2",
"ext-openssl": "*"
},
Expand Down
2 changes: 1 addition & 1 deletion src/Bridges/Phalcon/PhalconAdapter.php
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ public function exec($sql)

public function escapeString($value)
{
return $this->conn->escapeString($value);
return $this->conn->getPdo()->quote($value, \PDO::PARAM_STR);
}


Expand Down
150 changes: 150 additions & 0 deletions tests/cases/integration/phalcon/PhalconTest.phpt
Original file line number Diff line number Diff line change
@@ -0,0 +1,150 @@
<?php

/**
* @testCase
* @dataProvider ../../../dbals.ini
*/

namespace NextrasTests\Migrations;

use Phalcon\Cli\Dispatcher;
use Tester\Assert;
use Tester\Environment;
use Tester\TestCase;


require __DIR__ . '/../../../bootstrap.php';


class PhalconTest extends TestCase
{
/** @var \Phalcon\Cli\Console */
private $console;


protected function setUp()
{
parent::setUp();

Environment::lock(__CLASS__, __DIR__ . '/../../../temp');

$options = Environment::loadData();
$driversConfig = parse_ini_file(__DIR__ . '/../../../drivers.ini', TRUE);
$dbalOptions = $driversConfig[$options['driver']];

// Using the CLI factory default services container
$di = new \Phalcon\Di\FactoryDefault\Cli();

// DI services
$di->set(
'config',
new \Phalcon\Config([
'migrationsDir' => __DIR__ . "/../../../fixtures/$options[driver]",
'host' => $dbalOptions['host'],
'username' => $dbalOptions['username'],
'password' => $dbalOptions['password'],
'dbname' => $dbalOptions['database'],
])
);
$di->set(
'migrationsDir',
function () {
/** @var \Phalcon\Config $config */
$config = $this->get('config');
return $config->migrationsDir;
}
);
$di->set(
'phalconAdapter',
function () {
/** @var \Phalcon\Db\Adapter\Pdo $connection */
$connection = $this->get('connection');
return new \Nextras\Migrations\Bridges\Phalcon\PhalconAdapter($connection);
}
);

if ($options['driver'] === 'mysql') {
$di->set(
'connection',
function () {
/** @var \Phalcon\Config $config */
$config = $this->get('config');
return new \Phalcon\Db\Adapter\Pdo\Mysql([
'host' => $config->host,
'username' => $config->username,
'password' => $config->password,
'dbname' => $config->dbname,
'dialectClass' => new \Phalcon\Db\Dialect\Mysql(),
]);
}
);
$di->set(
'driver',
function () {
/** @var \Nextras\Migrations\Bridges\Phalcon\PhalconAdapter $phalconAdapter */
$phalconAdapter = $this->get('phalconAdapter');
return new \Nextras\Migrations\Drivers\MySqlDriver($phalconAdapter);
}
);
} else {
$di->set(
'connection',
function () {
/** @var \Phalcon\Config $config */
$config = $this->get('config');
return new \Phalcon\Db\Adapter\Pdo\Postgresql([
'host' => $config->host,
'username' => $config->username,
'password' => $config->password,
'dbname' => $config->dbname,
'dialectClass' => new \Phalcon\Db\Dialect\Mysql(),
]);
}
);
$di->set(
'driver',
function () {
/** @var \Nextras\Migrations\Bridges\Phalcon\PhalconAdapter $phalconAdapter */
$phalconAdapter = $this->get('phalconAdapter');
return new \Nextras\Migrations\Drivers\PgSqlDriver($phalconAdapter);
}
);
}

// Configure Task Namespace
/** @var Dispatcher $dispatcher */
$dispatcher = $di->get('dispatcher');
$dispatcher->setDefaultNamespace('Nextras\\Migrations\\Bridges\\Phalcon');

// Create a console application
$this->console = new \Phalcon\Cli\Console();
$this->console->setDI($di);
}


public function testMigrationsReset()
{
Assert::noError(function () {
$arguments = [];
$arguments['task'] = 'migrations';
$arguments['action'] = 'main';
$arguments['params'] = ['reset'];
$this->console->handle($arguments);
});
}


public function testMigrationsContinue()
{
Assert::noError(function () {
$arguments['task'] = 'migrations';
$arguments['action'] = 'main';
$arguments['params'] = ['continue'];

$this->console->handle($arguments);
});
}
}


(new PhalconTest)->run();
5 changes: 5 additions & 0 deletions tests/matrix/dbal/phalcon-3.4.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
#!/usr/bin/env bash
PHP_VERSION_MIN="50500"
PHP_VERSION_MAX="70399"
COMPOSER_REQUIRE="$COMPOSER_REQUIRE doctrine/dbal:~2.5"
DBAL="doctrine"
5 changes: 5 additions & 0 deletions tests/matrix/phalcon/phalcon-php-5.5-to-7.2.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
#!/usr/bin/env bash
PHP_VERSION_MIN="50500"
PHP_VERSION_MAX="70399"
DBAL="doctrine"
PHALCON="phalcon"
9 changes: 8 additions & 1 deletion tests/run-integration.sh
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ run()
PHP_VERSION_MAX=""
COMPOSER_REQUIRE=""
DBAL=""
PHALCON=""

echo
echo
Expand All @@ -33,7 +34,7 @@ run()
return 0
fi

create_dbals_ini "$DBAL"
create_dbals_ini "$DBAL" "$PHALCON"

composer_prepare_dependencies "$COMPOSER_REQUIRE" ""
tester_run_integration_group "$INTEGRATION_GROUP"
Expand All @@ -51,9 +52,11 @@ run()
create_dbals_ini()
{
DBAL="$1"
PHALCON="$2"
INI_PATH="$PROJECT_DIR/tests/dbals.ini"

rm --force "$INI_PATH"

if [[ ! -z "$DBAL" ]]; then
echo "[$DBAL.mysql]" >> "$INI_PATH"
echo "dbal = $DBAL" >> "$INI_PATH"
Expand All @@ -63,6 +66,10 @@ create_dbals_ini()
echo "dbal = $DBAL" >> "$INI_PATH"
echo "driver = pgsql" >> "$INI_PATH"
fi

if [[ ! -z "$PHALCON" ]]; then
echo "extension=phalcon.so" >> "$PROJECT_DIR/tests/php.ini"
fi
}


Expand Down

0 comments on commit 73c3e05

Please sign in to comment.