Add some tests and enable travisCI

This commit is contained in:
Pellaeon Lin 2017-09-17 16:48:38 +08:00
parent 87f902a4f1
commit 96a73ee827
3 changed files with 91 additions and 21 deletions

View File

@ -1,17 +1,87 @@
sudo: required
language: php
php:
- 5.3
- 5.4
- 5.5
- 5.6
- 7.0
addons:
apt:
packages:
- mysql-server-5.6
- mysql-client-core-5.6
- mysql-client-5.6
- php5-pgsql
- libxml2-utils
env:
global:
- PHP_COVERAGE=FALSE
matrix:
- CORE_FORK_BRANCH=nc_master DB=sqlite
- CORE_FORK_BRANCH=nc_stable11 DB=sqlite
- CORE_FORK_BRANCH=nc_stable12 DB=sqlite
- CORE_FORK_BRANCH=oc_master DB=sqlite
- CORE_FORK_BRANCH=oc_stable10 DB=sqlite
- CORE_FORK_BRANCH=nc_master DB=mysql
- CORE_FORK_BRANCH=nc_stable11 DB=mysql
- CORE_FORK_BRANCH=nc_stable12 DB=mysql
- CORE_FORK_BRANCH=oc_master DB=mysql
- CORE_FORK_BRANCH=oc_stable10 DB=mysql
matrix:
allow_failures:
- php: 7.0
fast_finish: true
branches:
only:
- master
before_install:
- php --info
# Set up DB
- if [[ "$DB" == 'pgsql' ]]; then createuser -U travis -s oc_autotest; fi
- if [[ "$DB" == 'mysql' ]]; then mysql -u root -e 'create database oc_autotest;'; fi
- if [[ "$DB" == 'mysql' ]]; then mysql -u root -e "CREATE USER 'oc_autotest'@'localhost' IDENTIFIED BY '';"; fi
- if [[ "$DB" == 'mysql' ]]; then mysql -u root -e "GRANT ALL ON oc_autotest.* TO 'oc_autotest'@'localhost';"; fi
- cd ..
- git clone https://github.com/owncloud/core.git
- if [[ $(echo $CORE_FORK_BRANCH | awk -F '_' '{print $1}') == 'oc' ]]; then git clone https://github.com/owncloud/core.git --recursive --depth 1 -b $(echo $CORE_FORK_BRANCH | awk -F '_' '{print $2}') core; fi
- if [[ $(echo $CORE_FORK_BRANCH | awk -F '_' '{print $1}') == 'nc' ]]; then git clone https://github.com/nextcloud/server.git --recursive --depth 1 -b $(echo $CORE_FORK_BRANCH | awk -F '_' '{print $2}') core; fi
- mv registration core/apps/
- cd core
- git submodule init
- git submodule update
- cd apps/registration
before_script:
# Set up core
- php -f core/occ maintenance:install --database-name oc_autotest --database-user oc_autotest --admin-user admin --admin-pass admin --database $DB --database-pass=''
# Set up app
- php -f core/occ app:enable registration
# Enable app twice to check occ errors of registered commands
- php -f core/occ app:enable registration
- cd core/apps/registration
# XDebug is only needed if we report coverage -> speeds up other builds
- if [[ "$PHP_COVERAGE" = "FALSE" ]]; then phpenv config-rm xdebug.ini; fi
script:
- phpunit tests
# Check info.xml schema validity
- wget https://apps.nextcloud.com/schema/apps/info.xsd
- xmllint appinfo/info.xml --schema info.xsd --noout
- rm info.xsd
# Check PHP syntax errors
#- find . -name \*.php -not -path './vendor/*' -exec php -l "{}" \;
# Run server's app code checker
# TODO: enable once table renames are possible
# - php ../../occ app:check-code mail
# Run PHP tests
- cd tests
- phpunit -c phpunit.xml
# Test packaging
#- cd ..
#- if [[ "$PACKAGE" = "TRUE" ]]; then make appstore; fi

View File

@ -1,7 +1,7 @@
<phpunit bootstrap="tests/autoloader.php" colors="true">
<phpunit bootstrap="autoloader.php" colors="true">
<testsuites>
<testsuite name="unit">
<directory>./tests/unit</directory>
<directory>./unit</directory>
</testsuite>
</testsuites>
<filter>

View File

@ -122,10 +122,10 @@ class ApiControllerTest extends TestCase {
*/
public function testStatusNoRegistration() {
$this->registrationService
->method('getRegistrationForToken')
->with('ABCDEF')
->method('getRegistrationForSecret')
->with('L2qdLAtrJTx499ErjwkwnZqGmLdm3Acp')
->willThrowException(new DoesNotExistException(''));
$this->controller->status('ABCDEF');
$this->controller->status('L2qdLAtrJTx499ErjwkwnZqGmLdm3Acp');
}
/**
@ -136,10 +136,10 @@ class ApiControllerTest extends TestCase {
$registration = new Registration();
$registration->setEmailConfirmed(false);
$this->registrationService
->method('getRegistrationForToken')
->with('ABCDEF')
->method('getRegistrationForSecret')
->with('L2qdLAtrJTx499ErjwkwnZqGmLdm3Acp')
->willReturn($registration);
$actual = $this->controller->status('ABCDEF');
$actual = $this->controller->status('L2qdLAtrJTx499ErjwkwnZqGmLdm3Acp');
}
public function testStatusConfirmedRegistration() {
@ -148,8 +148,8 @@ class ApiControllerTest extends TestCase {
$registration->setClientSecret('mysecret');
$user = $this->createMock(IUser::class);
$this->registrationService
->method('getRegistrationForToken')
->with('ABCDEF')
->method('getRegistrationForSecret')
->with('mysecret')
->willReturn($registration);
$this->registrationService
->expects($this->once())
@ -162,7 +162,7 @@ class ApiControllerTest extends TestCase {
$this->registrationService
->expects($this->once())
->method('generateAppPassword');
$actual = $this->controller->status('ABCDEF');
$actual = $this->controller->status('mysecret');
$expected = new DataResponse([]);
$this->assertEquals($expected, $actual);
}