<?php

namespace dokuwiki\plugin\bureaucracyau\test;

/**
 * @group plugin_bureaucracyau
 * @group plugins
 */
class syntax_plugin_bureaucracyau_fieldusers_test extends BureaucracyauTest
{

    /**
     * Create some users
     */
    public function setUp()
    {
        parent::setUp();

        /** @var \DokuWiki_Auth_Plugin $auth */
        global $auth;

        $auth->createUser('user1', '54321', 'user1Name', 'user1@example.com');
        $auth->createUser('user2', '543210', 'user2Name', 'user2@example.com');
        $auth->createUser('mwuser', '12345', 'Wiki User', 'me@example.com', ['group1', 'group2']);
    }

    public function dataProvider()
    {
        return [
            [
                'users:@@users@@',
                'users users',
                'user1, user2',
                'users:user1, user2',
                [],
                'default substitution',
            ],
            [
                'users:@@users@@',
                'users users',
                '',
                'users:',
                ['users'],
                'error for empty substitution',
            ],
            [
                'users:@@users(;)@@',
                'users users',
                'user1, user2',
                'users:user1;user2',
                [],
                'custom delimiter',
            ],
            [
                "users:@@users(\n)@@",
                'users users',
                'user1, user2',
                "users:user1\nuser2",
                [],
                'newline delimiter',
            ],
            [
                'users:@@users()@@',
                'users users',
                'user1, user2',
                'users:user1user2',
                [],
                'empty delimiter',
            ],
            [
                'users:@@users.name@@',
                'users users',
                'user1, user2',
                'users:user1Name, user2Name',
                [],
                'names substitution default delitmiter',
            ],
            [
                'users:@@users(;).name@@',
                'users users',
                'user1, user2',
                'users:user1Name;user2Name',
                [],
                'names substitution custom delitmiter',
            ],
            [
                'users:@@users.mail@@',
                'users users',
                'user1, user2',
                'users:user1@example.com, user2@example.com',
                [],
                'mail substitution default delitmiter',
            ],
            [
                "mails:@@users.mail@@\n\nnames:@@users(\n).name@@",
                'users users',
                'user1, user2',
                "mails:user1@example.com, user2@example.com\n\nnames:user1Name\nuser2Name",
                [],
                'multiple replacements',
            ],
            [
                'users:@@users@@',
                'users users',
                'not_existing1, not_existing2',
                'users:not_existing1, not_existing2',
                ['users'],
                'unknown users should cause errors',
            ],
            [
                'users:@@users.unknown_attribute@@',
                'users users',
                'user1, user2',
                'users:@@users.unknown_attribute@@',
                [],
                'non existant attribute is not replaced',
            ],
            [
                'users:@@*]]@@',  // the label must be something to break a regex when not properly quoted
                'users "*]]"',
                'user1, user2',
                'users:user1, user2',
                [],
                'ensure label desn\'t break regex',
            ],
            [
                'users:@@tHis Is UsEr@@',
                'users "tHis Is UsEr"',
                'user1, user2',
                'users:user1, user2',
                [],
                'label with spaces and mixed case',
            ],
        ];
    }

    /**
     * @dataProvider dataProvider
     *
     * @param string $templateSyntax
     * @param string $formSyntax
     * @param string $postedValue value of 'users' field
     * @param string $expectedWikiText
     * @param string $expectedValidationErrors
     * @param string $msg
     *
     */
    public function test_field_users(
        $templateSyntax,
        $formSyntax,
        $postedValue,
        $expectedWikiText,
        $expectedValidationErrors,
        $msg
    ) {
        $actualValidationErrors = [];

        $actualWikiText = parent::send_form_action_template(
            $formSyntax,
            $templateSyntax,
            $actualValidationErrors,
            $postedValue
        );

        $this->assertEquals($expectedWikiText, $actualWikiText, $msg);
        $this->assertEquals($expectedValidationErrors, $actualValidationErrors, $msg);
    }
}
