/var/www/html_de/wp-content/plugins/wp-smtp/tests/Integration/REST/ConnectionsPermissionsTest.php


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

namespace Integration\REST;

use 
lucatume\WPBrowser\TestCase\WPRestApiTestCase;
use 
WP_REST_Request;

class 
ConnectionsPermissionsTest extends WPRestApiTestCase {
    public function 
testUnloggedUserCanNotAccessConnections(): void {
        
wp_set_current_user);

        
$request  = new WP_REST_Request'GET''/solid-mail/v1/connections' );
        
$response rest_get_server()->dispatch$request );

        
$this->assertSame401$response->get_status() );
    }

    public function 
testUserWithoutManageOptionsCapabilityCanNotAccessConnections(): void {
        
wp_set_current_user$this->createEditorUser() );

        
$request  = new WP_REST_Request'GET''/solid-mail/v1/connections' );
        
$response rest_get_server()->dispatch$request );

        
$this->assertSame403$response->get_status() );
    }

    public function 
testPermissionsForReadEndpoints(): void {
        
$read_endpoints = [
            [ 
'GET''/solid-mail/v1/connections' ],
            [ 
'GET''/solid-mail/v1/connections/test_smtp_1' ],
        ];

        foreach ( 
$read_endpoints as [ $method$route ] ) {
            
wp_set_current_user);
            
$request  = new WP_REST_Request$method$route );
            
$response rest_get_server()->dispatch$request );
            
$this->assertSame401$response->get_status(), "Failed for {$method} {$route});

            
wp_set_current_user$this->createEditorUser() );
            
$request  = new WP_REST_Request$method$route );
            
$response rest_get_server()->dispatch$request );
            
$this->assertSame403$response->get_status(), "Failed for {$method} {$route});
        }
    }

    public function 
testPermissionsForWriteEndpoints(): void {
        
$write_endpoints = [
            [ 
'PUT''/solid-mail/v1/connections/test_smtp_1' ],
            [ 
'DELETE''/solid-mail/v1/connections/test_smtp_2' ],
        ];

        foreach ( 
$write_endpoints as [ $method$route ] ) {
            
wp_set_current_user);
            
$request  = new WP_REST_Request$method$route );
            
$response rest_get_server()->dispatch$request );
            
$this->assertSame401$response->get_status(), "Failed for {$method} {$route});

            
wp_set_current_user$this->createEditorUser() );
            
$request  = new WP_REST_Request$method$route );
            
$response rest_get_server()->dispatch$request );
            
$this->assertSame403$response->get_status(), "Failed for {$method} {$route});
        }
    }

    public function 
testPermissionsForCreateEndpoint(): void {
        
// POST endpoint behaves differently - it validates parameters before checking permissions
        // when no name is provided, so we need to provide valid data to test permissions
        
wp_set_current_user);
        
$request = new WP_REST_Request'POST''/solid-mail/v1/connections' );
        
$request->set_param'name''other' );
        
$request->set_param'from_email''[email protected]);
        
$request->set_param'from_name''Test' );
        
$request->set_param'smtp_host''smtp.test.com' );
        
$request->set_param'smtp_port''587' );
        
$response rest_get_server()->dispatch$request );
        
$this->assertSame401$response->get_status() );

        
wp_set_current_user$this->createEditorUser() );
        
$request = new WP_REST_Request'POST''/solid-mail/v1/connections' );
        
$request->set_param'name''other' );
        
$request->set_param'from_email''[email protected]);
        
$request->set_param'from_name''Test' );
        
$request->set_param'smtp_host''smtp.test.com' );
        
$request->set_param'smtp_port''587' );
        
$response rest_get_server()->dispatch$request );
        
$this->assertSame403$response->get_status() );
    }

    private function 
createEditorUser(): int {
        return 
$this->factory()->user->create( [ 'role' => 'editor' ] );
    }
}