2013-05-29 01:46:57 +04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ownCloud
|
|
|
|
*
|
|
|
|
* @author Robin Appelman
|
|
|
|
* @copyright 2012 Robin Appelman icewind@owncloud.com
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2016-05-19 10:17:54 +03:00
|
|
|
namespace Test\User;
|
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
/**
|
|
|
|
* Abstract class to provide the basis of backend-specific unit test classes.
|
|
|
|
*
|
|
|
|
* All subclasses MUST assign a backend property in setUp() which implements
|
|
|
|
* user operations (add, remove, etc.). Test methods in this class will then be
|
|
|
|
* run on each separate subclass and backend therein.
|
|
|
|
*
|
|
|
|
* For an example see /tests/lib/user/dummy.php
|
|
|
|
*/
|
|
|
|
|
2016-05-19 10:17:54 +03:00
|
|
|
abstract class Backend extends \Test\TestCase {
|
2013-05-29 01:46:57 +04:00
|
|
|
/**
|
2016-05-04 10:09:01 +03:00
|
|
|
* @var \OC\User\Backend $backend
|
2013-05-29 01:46:57 +04:00
|
|
|
*/
|
|
|
|
protected $backend;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* get a new unique user name
|
|
|
|
* test cases can override this in order to clean up created user
|
2013-10-08 21:14:13 +04:00
|
|
|
* @return string
|
2013-05-29 01:46:57 +04:00
|
|
|
*/
|
|
|
|
public function getUser() {
|
2014-11-05 14:21:02 +03:00
|
|
|
return $this->getUniqueID('test_');
|
2013-05-29 01:46:57 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddRemove() {
|
|
|
|
//get the number of groups we start with, in case there are exising groups
|
|
|
|
$startCount=count($this->backend->getUsers());
|
|
|
|
|
|
|
|
$name1=$this->getUser();
|
|
|
|
$name2=$this->getUser();
|
|
|
|
$this->backend->createUser($name1, '');
|
|
|
|
$count=count($this->backend->getUsers())-$startCount;
|
|
|
|
$this->assertEquals(1, $count);
|
|
|
|
$this->assertTrue((array_search($name1, $this->backend->getUsers())!==false));
|
|
|
|
$this->assertFalse((array_search($name2, $this->backend->getUsers())!==false));
|
|
|
|
$this->backend->createUser($name2, '');
|
|
|
|
$count=count($this->backend->getUsers())-$startCount;
|
|
|
|
$this->assertEquals(2, $count);
|
|
|
|
$this->assertTrue((array_search($name1, $this->backend->getUsers())!==false));
|
|
|
|
$this->assertTrue((array_search($name2, $this->backend->getUsers())!==false));
|
|
|
|
|
|
|
|
$this->backend->deleteUser($name2);
|
|
|
|
$count=count($this->backend->getUsers())-$startCount;
|
|
|
|
$this->assertEquals(1, $count);
|
|
|
|
$this->assertTrue((array_search($name1, $this->backend->getUsers())!==false));
|
|
|
|
$this->assertFalse((array_search($name2, $this->backend->getUsers())!==false));
|
|
|
|
}
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
public function testLogin() {
|
|
|
|
$name1=$this->getUser();
|
|
|
|
$name2=$this->getUser();
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->assertFalse($this->backend->userExists($name1));
|
|
|
|
$this->assertFalse($this->backend->userExists($name2));
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->backend->createUser($name1, 'pass1');
|
|
|
|
$this->backend->createUser($name2, 'pass2');
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->assertTrue($this->backend->userExists($name1));
|
|
|
|
$this->assertTrue($this->backend->userExists($name2));
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-10-08 21:53:20 +04:00
|
|
|
$this->assertSame($name1, $this->backend->checkPassword($name1, 'pass1'));
|
|
|
|
$this->assertSame($name2, $this->backend->checkPassword($name2, 'pass2'));
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->assertFalse($this->backend->checkPassword($name1, 'pass2'));
|
|
|
|
$this->assertFalse($this->backend->checkPassword($name2, 'pass1'));
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->assertFalse($this->backend->checkPassword($name1, 'dummy'));
|
|
|
|
$this->assertFalse($this->backend->checkPassword($name2, 'foobar'));
|
2014-11-05 14:21:02 +03:00
|
|
|
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->backend->setPassword($name1, 'newpass1');
|
|
|
|
$this->assertFalse($this->backend->checkPassword($name1, 'pass1'));
|
2013-10-08 21:53:20 +04:00
|
|
|
$this->assertSame($name1, $this->backend->checkPassword($name1, 'newpass1'));
|
2013-05-29 01:46:57 +04:00
|
|
|
$this->assertFalse($this->backend->checkPassword($name2, 'newpass1'));
|
|
|
|
}
|
2014-06-23 20:33:13 +04:00
|
|
|
|
|
|
|
public function testSearch() {
|
|
|
|
$name1 = 'foobarbaz';
|
|
|
|
$name2 = 'bazbarfoo';
|
|
|
|
$name3 = 'notme';
|
2017-12-20 17:51:37 +03:00
|
|
|
$name4 = 'under_score';
|
2014-06-23 20:33:13 +04:00
|
|
|
|
|
|
|
$this->backend->createUser($name1, 'pass1');
|
|
|
|
$this->backend->createUser($name2, 'pass2');
|
|
|
|
$this->backend->createUser($name3, 'pass3');
|
2017-12-20 17:51:37 +03:00
|
|
|
$this->backend->createUser($name4, 'pass4');
|
2014-06-23 20:33:13 +04:00
|
|
|
|
|
|
|
$result = $this->backend->getUsers('bar');
|
2017-12-20 17:51:37 +03:00
|
|
|
$this->assertCount(2, $result);
|
2014-06-23 20:33:13 +04:00
|
|
|
|
|
|
|
$result = $this->backend->getDisplayNames('bar');
|
2017-12-20 17:51:37 +03:00
|
|
|
$this->assertCount(2, $result);
|
|
|
|
|
|
|
|
$result = $this->backend->getUsers('under_');
|
|
|
|
$this->assertCount(1, $result);
|
|
|
|
|
|
|
|
$result = $this->backend->getUsers('not_');
|
|
|
|
$this->assertCount(0, $result);
|
2014-06-23 20:33:13 +04:00
|
|
|
}
|
2013-05-29 01:46:57 +04:00
|
|
|
}
|