aboutsummaryrefslogtreecommitdiffstats
path: root/apps/admin_audit/tests/Listener/UserManagementEventListenerTest.php
blob: c8cb0281113b450c84c9fca21e1c976dd13e75da (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
<?php

declare(strict_types=1);
/**
 * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */
namespace OCA\AdminAudit\Tests\Actions;

use OCA\AdminAudit\IAuditLogger;
use OCA\AdminAudit\Listener\UserManagementEventListener;
use OCP\IUser;
use OCP\User\Events\UserChangedEvent;
use PHPUnit\Framework\MockObject\MockObject;
use Test\TestCase;

class UserManagementEventListenerTest extends TestCase {
	private IAuditLogger&MockObject $logger;

	private UserManagementEventListener $listener;

	private MockObject&IUser $user;

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

		$this->logger = $this->createMock(IAuditLogger::class);
		$this->listener = new UserManagementEventListener($this->logger);

		$this->user = $this->createMock(IUser::class);
		$this->user->method('getUID')->willReturn('alice');
		$this->user->method('getDisplayName')->willReturn('Alice');
	}

	public function testSkipUnsupported(): void {
		$this->logger->expects($this->never())
			->method('info');

		$event = new UserChangedEvent(
			$this->user,
			'unsupported',
			'value',
		);

		$this->listener->handle($event);
	}

	public function testUserEnabled(): void {
		$this->logger->expects($this->once())
			->method('info')
			->with('User enabled: "alice"', ['app' => 'admin_audit']);

		$event = new UserChangedEvent(
			$this->user,
			'enabled',
			true,
			false,
		);

		$this->listener->handle($event);
	}

	public function testUserDisabled(): void {
		$this->logger->expects($this->once())
			->method('info')
			->with('User disabled: "alice"', ['app' => 'admin_audit']);

		$event = new UserChangedEvent(
			$this->user,
			'enabled',
			false,
			true,
		);

		$this->listener->handle($event);
	}

	public function testEmailChanged(): void {
		$this->logger->expects($this->once())
			->method('info')
			->with('Email address changed for user alice', ['app' => 'admin_audit']);

		$event = new UserChangedEvent(
			$this->user,
			'eMailAddress',
			'alice@alice.com',
			'',
		);

		$this->listener->handle($event);
	}
}