/*
* Copyright (c) 2010, Stanislav Muhametsin. All Rights Reserved.
*
* 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 org.qi4j.entitystore.sql;
import java.sql.Connection;
import java.sql.Statement;
import org.junit.Ignore;
import org.qi4j.api.common.Visibility;
import org.qi4j.api.unitofwork.UnitOfWork;
import org.qi4j.bootstrap.AssemblyException;
import org.qi4j.bootstrap.ModuleAssembly;
import org.qi4j.entitystore.memory.MemoryEntityStoreService;
import org.qi4j.entitystore.sql.assembly.PostgreSQLEntityStoreAssembler;
import org.qi4j.entitystore.sql.internal.SQLs;
import org.qi4j.library.sql.common.SQLConfiguration;
import org.qi4j.library.sql.common.SQLUtil;
import org.qi4j.library.sql.ds.PGDataSourceConfiguration;
import org.qi4j.core.testsupport.AbstractEntityStoreTest;
/**
* WARN This test is deactivated on purpose, please do not commit it activated.
*
* To run it you need to have a user & database set up in postgresql. Here are two snippets to create and drop the
* needed test environment.
*
* Use 'password' as password for the jdbc_test_login user.
*
* createuser -A -D -P -E -W jdbc_test_login createdb -O jdbc_test_login -W jdbc_test_db
*
* dropdb -W jdbc_test_db dropuser -W jdbc_test_login
*
* @author Stanislav Muhametsin
* @author Paul Merlin
*/
@Ignore
public class PostgreSQLEntityStoreTest extends AbstractEntityStoreTest
{
@Override
@SuppressWarnings("unchecked")
public void assemble( ModuleAssembly module )
throws AssemblyException
{
super.assemble( module );
new PostgreSQLEntityStoreAssembler().assemble( module );
ModuleAssembly config = module.layer().module( "config" );
config.services( MemoryEntityStoreService.class );
config.entities( PGDataSourceConfiguration.class, SQLConfiguration.class ).visibleIn( Visibility.layer );
}
@Override
public void tearDown()
throws Exception
{
UnitOfWork uow = this.unitOfWorkFactory.newUnitOfWork();
try
{
SQLConfiguration config = uow.get( SQLConfiguration.class,
PostgreSQLEntityStoreAssembler.ENTITYSTORE_SERVICE_NAME );
Connection connection = SQLUtil.getConnection( this.serviceLocator );
String schemaName = config.schemaName().get();
if( schemaName == null )
{
schemaName = SQLs.DEFAULT_SCHEMA_NAME;
}
Statement stmt = null;
try
{
stmt = connection.createStatement();
stmt.execute( String.format( "DELETE FROM %s." + SQLs.TABLE_NAME, schemaName ) );
connection.commit();
}
finally
{
SQLUtil.closeQuietly( stmt );
}
}
finally
{
uow.discard();
super.tearDown();
}
}
}