Merge pull request #51 from kinglozzer/45-indexes

Update for 4.x indexes API (closes #45)
This commit is contained in:
Loz Calver 2018-05-29 16:00:49 +01:00 committed by GitHub
commit 5ce3cf26bd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 57 additions and 28 deletions

View File

@ -9,36 +9,45 @@ services:
before_test: before_test:
- sqlcmd -S "(local)\SQL2014" -Q "Use [master]; CREATE DATABASE [appveyor]" - sqlcmd -S "(local)\SQL2014" -Q "Use [master]; CREATE DATABASE [appveyor]"
- SET PATH=C:\Program Files\OpenSSL;C:\tools\php;%PATH% - SET PATH=C:\Program Files\OpenSSL;C:\tools\php;%PATH%
- cinst -y php -version 5.6.11 - ps: appveyor-retry cinst --params '""/InstallDir:C:\tools\php""' --ignore-checksums -y php --version ((choco search php --exact --all-versions -r | select-string -pattern 5.6 | sort { [version]($_ -split '\|' | select -last 1) } -Descending | Select-Object -first 1) -replace '[php|]','')
- cd c:\tools\php - cd c:\tools\php
- ps: cat php.ini-production | %{$_ -replace "memory_limit = 128M","memory_limit = 256M"} | Out-File -Encoding "Default" php.ini - ps: cat php.ini-production | %{$_ -replace "memory_limit = 128M","memory_limit = 256M"} | Out-File -Encoding "Default" php.ini
- echo date.timezone="UTC" >> php.ini - echo date.timezone="UTC" >> php.ini
- echo extension_dir=ext >> php.ini - echo extension_dir=ext >> php.ini
- echo extension=php_intl.dll >> php.ini
- echo extension=php_openssl.dll >> php.ini - echo extension=php_openssl.dll >> php.ini
- echo extension=php_pdo_mysql.dll >> php.ini
- echo extension=php_mbstring.dll >> php.ini - echo extension=php_mbstring.dll >> php.ini
- echo extension=php_curl.dll >> php.ini - echo extension=php_curl.dll >> php.ini
- echo extension=php_gd2.dll >> php.ini - echo extension=php_gd2.dll >> php.ini
- echo extension=php_tidy.dll >> php.ini - echo extension=php_tidy.dll >> php.ini
- echo extension=php_fileinfo.dll >> php.ini - echo extension=php_fileinfo.dll >> php.ini
- php -r "readfile('http://getcomposer.org/installer');" | php - php -r "readfile('http://getcomposer.org/installer');" | php
- php -r "readfile('https://dl.dropboxusercontent.com/u/7129062/sqlsrv_unofficial_3.0.2.2.zip');" > sqlsrv.zip - php -r "readfile('https://gist.github.com/kinglozzer/f804bd11c8ba47cac2733d617e6e8b09/raw/a4a498e8fdaa8a20e3eb8b3133c6968371f8815f/sqlsrv_unofficial_3.0.2.2.zip');" > sqlsrv.zip
- unzip sqlsrv.zip - unzip sqlsrv.zip
- copy sqlsrv_unofficial_3.0.2.2\x64\*.dll ext - copy x64\*.dll ext
- echo extension=php_sqlsrv_56_nts.dll >> php.ini - echo extension=php_sqlsrv_56_nts.dll >> php.ini
- echo extension=php_pdo_sqlsrv_56_nts.dll >> php.ini - echo extension=php_pdo_sqlsrv_56_nts.dll >> php.ini
- ps: echo "php c:\tools\php\composer.phar %*" | Out-File -Encoding "Default" composer.bat - ps: echo "php c:\tools\php\composer.phar %*" | Out-File -Encoding "Default" composer.bat
- type composer.bat - type composer.bat
- composer --version - composer --version
- git clone --branch=windows-support git://github.com/silverstripe-labs/silverstripe-travis-support.git c:\projects\travis-support - cd c:\projects\silverstripe
- php c:\projects\travis-support\travis_setup.php --source c:\projects\silverstripe --target c:\projects\assembled - composer validate
- cd c:\projects\assembled - composer require --no-update silverstripe/installer:4.1.x-dev
- composer install --prefer-source --no-interaction --no-progress --no-suggest --optimize-autoloader --verbose --profile
test_script: test_script:
- cd c:\projects\assembled - cd c:\projects\silverstripe
- rename phpunit.xml.dist phpunit.xml.dist.orig - rename phpunit.xml.dist phpunit.xml.dist.orig
- ps: cat phpunit.xml.dist.orig | %{$_ -replace "colors=`"true`"","colors=`"false`""} | Out-File -Encoding "Default" phpunit.xml.dist - ps: cat phpunit.xml.dist.orig | %{$_ -replace "colors=`"true`"","colors=`"false`""} | Out-File -Encoding "Default" phpunit.xml.dist
- php .\vendor\phpunit\phpunit\composer\bin\phpunit framework/tests - vendor\bin\phpunit ./tests
- vendor\bin\phpunit vendor/silverstripe/framework/tests/php
environment: environment:
DB: MSSQL DB: MSSQL
CORE_RELEASE: master PDO: 1
SS_DATABASE_CLASS: 'MSSQLPDODatabase'
SS_DATABASE_USERNAME: 'sa'
SS_DATABASE_PASSWORD: 'Password12!'
SS_DATABASE_NAME: 'appveyor'
SS_DATABASE_SERVER: '(local)\SQL2014'

View File

@ -607,7 +607,7 @@ class MSSQLSchemaManager extends DBSchemaManager
$index = $this->buildMSSQLIndexName($tableName, $indexName); $index = $this->buildMSSQLIndexName($tableName, $indexName);
// Consolidate/Cleanup spec into array format // Consolidate/Cleanup spec into array format
$indexSpec = $this->parseIndexSpec($indexName, $indexSpec); $columns = $this->implodeColumnList($indexSpec['columns']);
$drop = "IF EXISTS (SELECT name FROM sys.indexes WHERE name = '$index' AND object_id = object_id(SCHEMA_NAME() + '.$tableName')) DROP INDEX $index ON \"$tableName\";"; $drop = "IF EXISTS (SELECT name FROM sys.indexes WHERE name = '$index' AND object_id = object_id(SCHEMA_NAME() + '.$tableName')) DROP INDEX $index ON \"$tableName\";";
@ -621,16 +621,16 @@ class MSSQLSchemaManager extends DBSchemaManager
$primary_key = $this->getPrimaryKey($tableName); $primary_key = $this->getPrimaryKey($tableName);
if ($primary_key) { if ($primary_key) {
return "$drop CREATE FULLTEXT INDEX ON \"$tableName\" ({$indexSpec['value']})" return "$drop CREATE FULLTEXT INDEX ON \"$tableName\" ({$columns})"
. "KEY INDEX $primary_key WITH CHANGE_TRACKING AUTO;"; . "KEY INDEX $primary_key WITH CHANGE_TRACKING AUTO;";
} }
} }
if ($indexSpec['type'] == 'unique') { if ($indexSpec['type'] == 'unique') {
return "$drop CREATE UNIQUE INDEX $index ON \"$tableName\" ({$indexSpec['value']});"; return "$drop CREATE UNIQUE INDEX $index ON \"$tableName\" ({$columns});";
} }
return "$drop CREATE INDEX $index ON \"$tableName\" ({$indexSpec['value']});"; return "$drop CREATE INDEX $index ON \"$tableName\" ({$columns});";
} }
public function alterIndex($tableName, $indexName, $indexSpec) public function alterIndex($tableName, $indexName, $indexSpec)
@ -662,11 +662,11 @@ class MSSQLSchemaManager extends DBSchemaManager
// Extract columns // Extract columns
$columns = $this->quoteColumnSpecString($index['index_keys']); $columns = $this->quoteColumnSpecString($index['index_keys']);
$indexList[$indexName] = $this->parseIndexSpec($indexName, array( $indexList[$indexName] = array(
'name' => $indexName, 'name' => $indexName,
'value' => $columns, 'columns' => $this->explodeColumnString($columns),
'type' => $indexType 'type' => $indexType
)); );
} }
// Now we need to check to see if we have any fulltext indexes attached to this table: // Now we need to check to see if we have any fulltext indexes attached to this table:
@ -682,11 +682,11 @@ class MSSQLSchemaManager extends DBSchemaManager
} }
if (!empty($columns)) { if (!empty($columns)) {
$indexList['SearchFields'] = $this->parseIndexSpec('SearchFields', array( $indexList['SearchFields'] = array(
'name' => 'SearchFields', 'name' => 'SearchFields',
'value' => $this->implodeColumnList($columns), 'columns' => $this->implodeColumnList($columns),
'type' => 'fulltext' 'type' => 'fulltext'
)); );
} }
} }

View File

@ -14,7 +14,11 @@
} }
], ],
"require": { "require": {
"silverstripe/framework": "^4" "silverstripe/framework": "^4",
"silverstripe/vendor-plugin": "^1.0"
},
"require-dev": {
"phpunit/phpunit": "^5.7"
}, },
"suggest": { "suggest": {
"ext-sqlsrv": "Required to support MSSQLDatabase as the server type", "ext-sqlsrv": "Required to support MSSQLDatabase as the server type",

16
phpunit.xml.dist Normal file
View File

@ -0,0 +1,16 @@
<phpunit bootstrap="vendor/silverstripe/cms/tests/bootstrap.php" colors="true">
<testsuite name="Default">
<directory>tests</directory>
</testsuite>
<filter>
<whitelist addUncoveredFilesFromWhitelist="true">
<directory suffix=".php">.</directory>
<exclude>
<directory suffix=".php">tests/</directory>
</exclude>
</whitelist>
</filter>
</phpunit>

View File

@ -6,28 +6,28 @@ use SilverStripe\Dev\TestOnly;
class MSSQLDatabaseQueryTest extends SapphireTest class MSSQLDatabaseQueryTest extends SapphireTest
{ {
protected static $fixture_file = 'MSSQLDatabaseQueryTest.yml';
public static $fixture_file = 'MSSQLDatabaseQueryTest.yml'; public static function getExtraDataObjects()
{
protected $extraDataObjects = array( return ['MSSQLDatabaseQueryTestDataObject'];
'MSSQLDatabaseQueryTestDataObject' }
);
public function testDateValueFormatting() public function testDateValueFormatting()
{ {
$obj = $this->objFromFixture('MSSQLDatabaseQueryTestDataObject', 'test-data-1'); $obj = $this->objFromFixture('MSSQLDatabaseQueryTestDataObject', 'test-data-1');
$this->assertEquals('2012-01-01', $obj->obj('TestDate')->Format('Y-m-d'), 'Date field value is formatted correctly (Y-m-d)'); $this->assertEquals('2012-01-01', $obj->obj('TestDate')->Format('y-MM-dd'), 'Date field value is formatted correctly (y-MM-dd)');
} }
public function testDatetimeValueFormatting() public function testDatetimeValueFormatting()
{ {
$obj = $this->objFromFixture('MSSQLDatabaseQueryTestDataObject', 'test-data-1'); $obj = $this->objFromFixture('MSSQLDatabaseQueryTestDataObject', 'test-data-1');
$this->assertEquals('2012-01-01 10:30:00', $obj->obj('TestDatetime')->Format('Y-m-d H:i:s'), 'Datetime field value is formatted correctly (Y-m-d H:i:s)'); $this->assertEquals('2012-01-01 10:30:00', $obj->obj('TestDatetime')->Format('y-MM-dd HH:mm:ss'), 'Datetime field value is formatted correctly (y-MM-dd HH:mm:ss)');
} }
} }
class MSSQLDatabaseQueryTestDataObject extends DataObject implements TestOnly class MSSQLDatabaseQueryTestDataObject extends DataObject implements TestOnly
{ {
private static $db = array( private static $db = array(
'TestDate' => 'Date', 'TestDate' => 'Date',
'TestDatetime' => 'Datetime' 'TestDatetime' => 'Datetime'