UserEditorTest.java

/***************************************************************************
   Copyright 2015 Emily Estes

   Licensed under the Apache License, Version 2.0 (the "License");
   you may not use this file except in compliance with the License.
   You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
***************************************************************************/
package net.metanotion.sqlauthident;


import java.sql.Connection;
import java.sql.DriverManager;
import javax.sql.DataSource;

import net.metanotion.sql.DbUtil;

public final class UserEditorTest {
	public static final int ARGS_URL = 0;
	public static final int ARGS_DBNAME = 1;
	public static final int ARGS_USER = 2;
	public static final int ARGS_PASS = 3;
	public static final int ARGS_FILE = 4;

	public static final String OPT_DBURL = "-dbUrl:";
	public static final String OPT_DBUSER = "-dbUser:";
	public static final String OPT_DBPASS = "-dbPass:";
	public static final String OPT_SCHEMA = "-schema:";
	public static final String OPT_USER = "-user:";
	public static final String OPT_PASS = "-pass:";
	public static final String OPT_ADDUSER= "-addUser";
	public static final String OPT_FILE = "-file:";

	public static void main(final String[] args) throws Exception {
		final String url = args[ARGS_URL];
		final String dbName = args[ARGS_DBNAME];
		final String user = args[ARGS_USER];
		final String pass = args[ARGS_PASS];
		final String file = args[ARGS_FILE];

		try (final Connection conn = DriverManager.getConnection(url, user, pass)) {
			DbUtil.createDatabase(conn, dbName, user, true);
		}

		final DataSource ds = DbUtil.startDBConnectionPool(url + dbName, user, pass);
		DbUtil.runSchema(ds, SQLRealm.schemaFactory());

		final String[] add = new String[] {
			OPT_DBURL + url + dbName,
			OPT_DBUSER + user,
			OPT_DBPASS + pass,
			OPT_ADDUSER,
			OPT_USER + "test",
			OPT_PASS + "asdf"
		};
		UserEditor.main(add);

		final String[] json = new String[] {
			OPT_DBURL + url + dbName,
			OPT_DBUSER + user,
			OPT_DBPASS + pass,
			OPT_FILE + file
		};
		UserEditor.main(json);
	}
}