Welcome to mirror list, hosted at ThFree Co, Russian Federation.

ContactsTest.php « PublicNamespace « lib « tests - github.com/nextcloud/server.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 8b07c4831b665d095cbca3d4f53c2ce9225f9abb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
<?php
/**
 * ownCloud
 *
 * @author Thomas Müller
 * @copyright 2012 Thomas Müller thomas.mueller@tmit.eu
 *
 * 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/>.
 */

namespace Test\PublicNamespace;

class ContactsTest extends \Test\TestCase {
	protected function setUp() {
		parent::setUp();
		\OCP\Contacts::clear();
	}

	public function testDisabledIfEmpty() {
		// pretty simple
		$this->assertFalse(\OCP\Contacts::isEnabled());
	}

	public function testEnabledAfterRegister() {
		// create mock for the addressbook
		$stub = $this->getMockForAbstractClass("OCP\IAddressBook", array('getKey'));

		// we expect getKey to be called twice:
		// first time on register
		// second time on un-register
		$stub->expects($this->exactly(2))
			->method('getKey');

		// not enabled before register
		$this->assertFalse(\OCP\Contacts::isEnabled());

		// register the address book
		\OCP\Contacts::registerAddressBook($stub);

		// contacts api shall be enabled
		$this->assertTrue(\OCP\Contacts::isEnabled());

		// unregister the address book
		\OCP\Contacts::unregisterAddressBook($stub);

		// not enabled after register
		$this->assertFalse(\OCP\Contacts::isEnabled());
	}

	public function testAddressBookEnumeration() {
		// create mock for the addressbook
		$stub = $this->getMockForAbstractClass("OCP\IAddressBook", array('getKey', 'getDisplayName'));

		// setup return for method calls
		$stub->expects($this->any())
			->method('getKey')
			->will($this->returnValue('SIMPLE_ADDRESS_BOOK'));
		$stub->expects($this->any())
			->method('getDisplayName')
			->will($this->returnValue('A very simple Addressbook'));

		// register the address book
		\OCP\Contacts::registerAddressBook($stub);
		$all_books = \OCP\Contacts::getAddressBooks();

		$this->assertEquals(1, count($all_books));
		$this->assertEquals('A very simple Addressbook', $all_books['SIMPLE_ADDRESS_BOOK']);
	}

	public function testSearchInAddressBook() {
		// create mock for the addressbook
		$stub1 = $this->getMockForAbstractClass("OCP\IAddressBook", array('getKey', 'getDisplayName', 'search'));
		$stub2 = $this->getMockForAbstractClass("OCP\IAddressBook", array('getKey', 'getDisplayName', 'search'));

		$searchResult1 = array(
			array('id' => 0, 'FN' => 'Frank Karlitschek', 'EMAIL' => 'a@b.c', 'GEO' => '37.386013;-122.082932'),
			array('id' => 5, 'FN' => 'Klaas Freitag', 'EMAIL' => array('d@e.f', 'g@h.i')),
		);
		$searchResult2 = array(
			array('id' => 0, 'FN' => 'Thomas Müller', 'EMAIL' => 'a@b.c'),
			array('id' => 5, 'FN' => 'Thomas Tanghus', 'EMAIL' => array('d@e.f', 'g@h.i')),
		);

		// setup return for method calls for $stub1
		$stub1->expects($this->any())->method('getKey')->will($this->returnValue('SIMPLE_ADDRESS_BOOK1'));
		$stub1->expects($this->any())->method('getDisplayName')->will($this->returnValue('Address book ownCloud Inc'));
		$stub1->expects($this->any())->method('search')->will($this->returnValue($searchResult1));

		// setup return for method calls for $stub2
		$stub2->expects($this->any())->method('getKey')->will($this->returnValue('SIMPLE_ADDRESS_BOOK2'));
		$stub2->expects($this->any())->method('getDisplayName')->will($this->returnValue('Address book ownCloud Community'));
		$stub2->expects($this->any())->method('search')->will($this->returnValue($searchResult2));

		// register the address books
		\OCP\Contacts::registerAddressBook($stub1);
		\OCP\Contacts::registerAddressBook($stub2);
		$all_books = \OCP\Contacts::getAddressBooks();

		// assert the count - doesn't hurt
		$this->assertEquals(2, count($all_books));

		// perform the search
		$result = \OCP\Contacts::search('x', array());

		// we expect 4 hits
		$this->assertEquals(4, count($result));

	}
}