98 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (c) 2016 MariaDB Corporation Ab
 | 
						|
 *
 | 
						|
 * Use of this software is governed by the Business Source License included
 | 
						|
 * in the LICENSE.TXT file and at www.mariadb.com/bsl11.
 | 
						|
 *
 | 
						|
 * Change Date: 2022-01-01
 | 
						|
 *
 | 
						|
 * On the date above, in accordance with the Business Source License, use
 | 
						|
 * of this software will be governed by version 2 or later of the General
 | 
						|
 * Public License.
 | 
						|
 */
 | 
						|
 | 
						|
/**
 | 
						|
 *
 | 
						|
 * @verbatim
 | 
						|
 * Revision History
 | 
						|
 *
 | 
						|
 * Date         Who                 Description
 | 
						|
 * 08-10-2014   Martin Brampton     Initial implementation
 | 
						|
 *
 | 
						|
 * @endverbatim
 | 
						|
 */
 | 
						|
 | 
						|
// To ensure that ss_info_assert asserts also when builing in non-debug mode.
 | 
						|
#if !defined(SS_DEBUG)
 | 
						|
#define SS_DEBUG
 | 
						|
#endif
 | 
						|
#if defined(NDEBUG)
 | 
						|
#undef NDEBUG
 | 
						|
#endif
 | 
						|
#include <stdio.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <string.h>
 | 
						|
 | 
						|
#include <maxscale/users.h>
 | 
						|
#include <maxscale/log_manager.h>
 | 
						|
 | 
						|
static int test1()
 | 
						|
{
 | 
						|
    USERS* users;
 | 
						|
    bool rv;
 | 
						|
 | 
						|
    /* Poll tests */
 | 
						|
    ss_dfprintf(stderr,
 | 
						|
                "testusers : Initialise the user table.");
 | 
						|
    users = users_alloc();
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_info_dassert(NULL != users, "Allocating user table should not return NULL.");
 | 
						|
    ss_dfprintf(stderr, "\t..done\nAdd a user");
 | 
						|
    rv = users_add(users, "username", "authorisation", USER_ACCOUNT_ADMIN);
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_info_dassert(rv, "Should add one user");
 | 
						|
    rv = users_auth(users, "username", "authorisation");
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_info_dassert(rv, "Fetch valid user must not return NULL");
 | 
						|
    rv = users_auth(users, "username", "newauth");
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_info_dassert(rv == 0, "Fetch invalid user must return NULL");
 | 
						|
 | 
						|
    ss_dfprintf(stderr, "\t..done\nAdd another user");
 | 
						|
    rv = users_add(users, "username2", "authorisation2", USER_ACCOUNT_ADMIN);
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_info_dassert(rv, "Should add one user");
 | 
						|
    ss_dfprintf(stderr, "\t..done\nDelete a user.");
 | 
						|
    rv = users_delete(users, "username");
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_info_dassert(rv, "Should delete just one user");
 | 
						|
 | 
						|
    ss_dfprintf(stderr, "\t..done\nDump users table.");
 | 
						|
    json_t* dump = users_to_json(users);
 | 
						|
    ss_info_dassert(dump, "Users should be dumped");
 | 
						|
    USERS* loaded_users = users_from_json(dump);
 | 
						|
    ss_info_dassert(dump, "Users should be loaded");
 | 
						|
    json_decref(dump);
 | 
						|
    rv = users_auth(loaded_users, "username2", "authorisation2");
 | 
						|
    users_free(loaded_users);
 | 
						|
    ss_info_dassert(rv, "Loaded users should contain users");
 | 
						|
 | 
						|
    ss_dfprintf(stderr, "\t..done\nFree user table.");
 | 
						|
    users_free(users);
 | 
						|
    mxs_log_flush_sync();
 | 
						|
    ss_dfprintf(stderr, "\t..done\n");
 | 
						|
 | 
						|
    return 0;
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
int main(int argc, char **argv)
 | 
						|
{
 | 
						|
    int result = 0;
 | 
						|
 | 
						|
    result += test1();
 | 
						|
 | 
						|
    exit(result);
 | 
						|
}
 | 
						|
 |