use strict;
use warnings;
use TestLib;
use Test::More tests => 8;

program_help_ok('createuser');
program_version_ok('createuser');
program_options_handling_ok('createuser');

my $tempdir = tempdir;
start_test_server $tempdir;

issues_sql_like(
	[ 'createuser', 'user1' ],
qr/statement: CREATE ROLE user1 NOSUPERUSER NOCREATEDB NOCREATEROLE INHERIT LOGIN;/,
	'SQL CREATE USER run');
issues_sql_like(
	[ 'createuser', '-L', 'role1' ],
qr/statement: CREATE ROLE role1 NOSUPERUSER NOCREATEDB NOCREATEROLE INHERIT NOLOGIN;/,
	'create a non-login role');
issues_sql_like(
	[ 'createuser', '-r', 'user2' ],
qr/statement: CREATE ROLE user2 NOSUPERUSER NOCREATEDB CREATEROLE INHERIT LOGIN;/,
	'create a CREATEROLE user');
issues_sql_like(
	[ 'createuser', '-s', 'user3' ],
qr/statement: CREATE ROLE user3 SUPERUSER CREATEDB CREATEROLE INHERIT LOGIN;/,
	'create a superuser');

command_fails([ 'createuser', 'user1' ], 'fails if role already exists');