aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/tests/Settings/Personal/Security/AuthtokensTest.php
blob: 0ed5145da2a53e91b3915f726330db8d56136bb3 (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
<?php

declare(strict_types=1);

/**
 * SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */
namespace OCA\Settings\Tests\Settings\Personal\Security;

use OC\Authentication\Token\IProvider as IAuthTokenProvider;
use OC\Authentication\Token\PublicKeyToken;
use OCA\Settings\Settings\Personal\Security\Authtokens;
use OCP\AppFramework\Http\TemplateResponse;
use OCP\AppFramework\Services\IInitialState;
use OCP\ISession;
use OCP\IUserSession;
use PHPUnit\Framework\MockObject\MockObject;
use Test\TestCase;

class AuthtokensTest extends TestCase {

	/** @var IAuthTokenProvider|MockObject */
	private $authTokenProvider;

	/** @var ISession|MockObject */
	private $session;

	/** @var IUserSession|MockObject */
	private $userSession;

	/** @var IInitialState|MockObject */
	private $initialState;

	/** @var string */
	private $uid;

	/** @var Authtokens */
	private $section;

	protected function setUp(): void {
		parent::setUp();

		$this->authTokenProvider = $this->createMock(IAuthTokenProvider::class);
		$this->session = $this->createMock(ISession::class);
		$this->userSession = $this->createMock(IUserSession::class);
		$this->initialState = $this->createMock(IInitialState::class);
		$this->uid = 'test123';

		$this->section = new Authtokens(
			$this->authTokenProvider,
			$this->session,
			$this->userSession,
			$this->initialState,
			$this->uid
		);
	}

	public function testGetForm() {
		$token1 = new PublicKeyToken();
		$token1->setId(100);
		$token2 = new PublicKeyToken();
		$token2->setId(200);
		$tokens = [
			$token1,
			$token2,
		];
		$sessionToken = new PublicKeyToken();
		$sessionToken->setId(100);

		$this->authTokenProvider->expects($this->once())
			->method('getTokenByUser')
			->with($this->uid)
			->willReturn($tokens);
		$this->session->expects($this->once())
			->method('getId')
			->willReturn('session123');
		$this->authTokenProvider->expects($this->once())
			->method('getToken')
			->with('session123')
			->willReturn($sessionToken);
		$this->initialState->expects($this->exactly(2))
			->method('provideInitialState')
			->withConsecutive(
				[
					'app_tokens', [
						[
							'id' => 100,
							'name' => null,
							'lastActivity' => 0,
							'type' => 0,
							'canDelete' => false,
							'current' => true,
							'scope' => ['filesystem' => true],
							'canRename' => false,
						],
						[
							'id' => 200,
							'name' => null,
							'lastActivity' => 0,
							'type' => 0,
							'canDelete' => true,
							'scope' => ['filesystem' => true],
							'canRename' => true,
						],
					]
				],
				['can_create_app_token', true],
			);

		$form = $this->section->getForm();

		$expected = new TemplateResponse('settings', 'settings/personal/security/authtokens');
		$this->assertEquals($expected, $form);
	}
}