01: /******************************************************************************
02: * Copyright (C) Lars Ivar Almli. All rights reserved. *
03: * ---------------------------------------------------------------------------*
04: * This file is part of MActor. *
05: * *
06: * MActor is free software; you can redistribute it and/or modify *
07: * it under the terms of the GNU General Public License as published by *
08: * the Free Software Foundation; either version 2 of the License, or *
09: * (at your option) any later version. *
10: * *
11: * MActor is distributed in the hope that it will be useful, *
12: * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14: * GNU General Public License for more details. *
15: * *
16: * You should have received a copy of the GNU General Public License *
17: * along with MActor; if not, write to the Free Software *
18: * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA *
19: ******************************************************************************/package org.mactor.framework.commandexecutors.sql;
20:
21: import java.util.List;
22: import org.mactor.framework.MactorException;
23: import org.mactor.framework.TestContextImpl;
24: import org.mactor.framework.commandexecutors.ActionCommandExecutor;
25:
26: public class SqlActionCommandExecutor implements ActionCommandExecutor {
27: private String command;
28: private List<String> params;
29:
30: public SqlActionCommandExecutor(String command, List<String> params) {
31: this .command = command;
32: this .params = params;
33: }
34:
35: public void perform(TestContextImpl context) throws MactorException {
36: boolean ignoreSqlErrors = false;
37: if (params != null && params.size() > 0)
38: ignoreSqlErrors = Boolean.parseBoolean(params.get(0));
39: SqlCommandUtil sqlUtil = new SqlCommandUtil(command, context
40: .getGlobalConfig());
41: if (sqlUtil.getSqlExpression().trim().toLowerCase().endsWith(
42: ".sql"))
43: sqlUtil.getDb().execScript(sqlUtil.getSqlExpression(),
44: ignoreSqlErrors);
45: else
46: sqlUtil.getDb().execUpdateSql(sqlUtil.getSqlExpression());
47: }
48: }
|