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 language: php
php: php:
- 5.3 - 5.6
- 5.4 - 7.0
- 5.5
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: 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 .. - 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/ - mv registration core/apps/
- cd core
- git submodule init before_script:
- git submodule update # Set up core
- cd apps/registration - 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: 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> <testsuites>
<testsuite name="unit"> <testsuite name="unit">
<directory>./tests/unit</directory> <directory>./unit</directory>
</testsuite> </testsuite>
</testsuites> </testsuites>
<filter> <filter>

View File

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