/** * Copyright (C) 2009-2013 FoundationDB, LLC * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package com.foundationdb.sql.pg; import com.foundationdb.sql.NamedParamsTestBase; import com.foundationdb.sql.TestBase; import com.foundationdb.junit.NamedParameterizedRunner; import com.foundationdb.junit.NamedParameterizedRunner.TestParameters; import com.foundationdb.junit.Parameterization; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import static org.junit.Assert.*; import java.sql.PreparedStatement; import java.io.File; import java.util.Collection; @RunWith(NamedParameterizedRunner.class) public class PostgresServerUpdateIT extends PostgresServerFilesITBase implements TestBase.GenerateAndCheckResult { public static final File RESOURCE_DIR = new File(PostgresServerITBase.RESOURCE_DIR, "update"); @Before public void loadDatabase() throws Exception { loadDatabase(RESOURCE_DIR); } @TestParameters public static Collection<Parameterization> queries() throws Exception { return NamedParamsTestBase.namedCases(TestBase.sqlAndExpectedAndParams(RESOURCE_DIR)); } public PostgresServerUpdateIT(String caseName, String sql, String expected, String error, String[] params) { super(caseName, sql, expected, error, params); } @Test public void testUpdate() throws Exception { generateAndCheckResult(); } @Override public String generateResult() throws Exception { PreparedStatement stmt = getConnection().prepareStatement(sql); if (params != null) { for (int i = 0; i < params.length; i++) { String param = params[i]; if (param.startsWith("#")) stmt.setLong(i + 1, Long.parseLong(param.substring(1))); else stmt.setString(i + 1, param); } } try { int count = stmt.executeUpdate(); } catch (Exception ex) { if (error == null) forgetConnection(); throw ex; } stmt.close(); return dumpData(); } @Override public void checkResult(String result) { assertEquals(caseName, expected, result); } }