/** * OpenSpotLight - Open Source IT Governance Platform * * Copyright (c) 2009, CARAVELATECH CONSULTORIA E TECNOLOGIA EM INFORMATICA LTDA * or third-party contributors as indicated by the @author tags or express * copyright attribution statements applied by the authors. All third-party * contributions are distributed under license by CARAVELATECH CONSULTORIA E * TECNOLOGIA EM INFORMATICA LTDA. * * This copyrighted material is made available to anyone wishing to use, modify, * copy, or redistribute it subject to the terms and conditions of the GNU * Lesser General Public License, as published by the Free Software Foundation. * * 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution; if not, write to: * Free Software Foundation, Inc. * 51 Franklin Street, Fifth Floor * Boston, MA 02110-1301 USA * *********************************************************************** * OpenSpotLight - Plataforma de Governança de TI de Código Aberto * * Direitos Autorais Reservados (c) 2009, CARAVELATECH CONSULTORIA E TECNOLOGIA * EM INFORMATICA LTDA ou como contribuidores terceiros indicados pela etiqueta * @author ou por expressa atribuição de direito autoral declarada e atribuída pelo autor. * Todas as contribuições de terceiros estão distribuídas sob licença da * CARAVELATECH CONSULTORIA E TECNOLOGIA EM INFORMATICA LTDA. * * Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo sob os * termos da Licença Pública Geral Menor do GNU conforme publicada pela Free Software * Foundation. * * Este programa é distribuído na expectativa de que seja útil, porém, SEM NENHUMA * GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU ADEQUAÇÃO A UMA * FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral Menor do GNU para mais detalhes. * * Você deve ter recebido uma cópia da Licença Pública Geral Menor do GNU junto com este * programa; se não, escreva para: * Free Software Foundation, Inc. * 51 Franklin Street, Fifth Floor * Boston, MA 02110-1301 USA */ package org.openspotlight.bundle.language.java.bundle.test; import com.google.inject.Guice; import com.google.inject.Injector; import org.hamcrest.core.Is; import org.hamcrest.core.IsNull; import org.junit.Assert; import org.junit.Ignore; import org.openspotlight.bundle.language.java.JavaConstants; import org.openspotlight.bundle.language.java.bundle.JavaBinaryProcessor; import org.openspotlight.bundle.language.java.bundle.JavaGlobalPhase; import org.openspotlight.bundle.context.ExecutionContext; import org.openspotlight.bundle.context.ExecutionContextFactory; import org.openspotlight.federation.domain.artifact.ArtifactSource; import org.openspotlight.bundle.processing.BundleProcessorManager.GlobalExecutionStatus; import org.openspotlight.bundle.processing.DefaultBundleProcessorManager; import org.openspotlight.bundle.scheduler.GlobalSettingsSupport; import org.openspotlight.graph.SLConsts; import org.openspotlight.graph.SLGraph; import org.openspotlight.graph.Nodeimport org.openspotlight.graph.guice.SLGraphModule; import org.openspotlight.graph.server.RemoteGraphSessionServer; import org.openspotlight.jcr.provider.DefaultJcrDescriptor; import org.openspotlight.jcr.provider.JcrConnectionDescriptor; import org.openspotlight.jcr.provider.JcrConnectionProvider; import org.openspotlight.jcr.provider.SessionWithLock; import org.openspotlight.persist.guice.SimplePersistModule; import org.openspotlight.remote.server.UserAuthenticator; import org.openspotlight.storage.StorageSessionimport org.openspotlight.storage.domain.RegularPartitionition; import org.openspotlight.storage.redis.guice.JRedisFactory; import org.openspotlight.storage.redis.guice.JRedisStorageModule; import org.openspotlight.storage.redis.util.ExampleRedisConfig; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import javax.jcr.Node; import javax.jcr.NodeIterator; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileOutputStream; import static org.openspotlight.storage.STRepositoryPath.repositoryPath; @Ignore public class JavaStressExampleDataCreationTest { public static void main(final String... args) throws Exception { final JavaStressExampleDataCreationTest test = new JavaStressExampleDataCreationTest(); try { test.setupResourcesAndCreateData(); } catch (final Exception e) { e.printStackTrace(); } catch (final AssertionError e) { e.printStackTrace(); } finally { JcrConnectionProvider.createFromData(descriptor).closeRepositoryAndCleanResources(); } } private ExecutionContextFactory includedFilesContextFactory; private GlobalSettings settings; private Group group; private final String username = "username"; private final String password = "password"; private static final JcrConnectionDescriptor descriptor = DefaultJcrDescriptor.TEMP_DESCRIPTOR; Logger logger = LoggerFactory.getLogger(getClass()); public void setupResourcesAndCreateData() throws Exception { Injector injector = Guice.createInjector(new JRedisStorageModule(StStorageSessionlushMode.AUTO, ExampleRedisConfig.EXAMPLE.getMappedServerConfig(), repositoryPath("repository")), new SimplePersistModule(), new SLGraphModule(DefaultJcrDescriptor.TEMP_DESCRIPTOR)); injector.getInstance(JRedisFactory.class).getRegularPartitionrPartition.GRAPH).flushall(); SLGraph graph = injector.getInstance(SLGraph.class); JcrConnectionProvider.createFromData(descriptor).closeRepositoryAndCleanResources(); new RemoteGraphSessionServer(new UserAuthenticator() { public boolean canConnect(final String userName, final String password, final String clientHost) { return true; } public boolean equals(final Object o) { return this.getClass().equals(o.getClass()); } }, 7070, 60 * 1000 * 10L, descriptor, graph); System.err.println("Server waiting connections on port 7070"); final Repository repo = new Repository(); repo.setName("name"); repo.setActive(true); final ArtifactSource includedSource = new ArtifactSource(); includedSource.setRepository(repo); includedSource.setName("classpath"); includedSource.setInitialLookup("./src/test/resources/stringArtifacts/stressData"); includedFilesContextFactory = injector.getInstance(ExecutionContextFactory.class); settings = new GlobalSettings(); settings.setDefaultSleepingIntervalInMilliseconds(1000); GlobalSettingsSupport.initializeScheduleMap(settings); group = new Group(); group.setName("sampleGroup"); group.setRepository(repo); repo.getGroups().add(group); group.setActive(true); final BundleProcessorType jarProcessor = new BundleProcessorType(); jarProcessor.setActive(true); jarProcessor.setName("jar processor"); jarProcessor.setGroup(group); jarProcessor.setGlobalPhase(JavaGlobalPhase.class); jarProcessor.getArtifactPhases().add(JavaBinaryProcessor.class); group.getBundleTypes().add(jarProcessor); final BundleSource bundleJarSource = new BundleSource(); jarProcessor.getSources().add(bundleJarSource); bundleJarSource.setBundleProcessorType(jarProcessor); bundleJarSource.setRelative("jar/"); bundleJarSource.getIncludeds().add("**/*.jar"); ExecutionContext ctx = includedFilesContextFactory.createExecutionContext(username, password, descriptor, group.getRootRepository()); ctx.getDefaultConfigurationManager().saveGlobalSettings(settings); ctx.getDefaultConfigurationManager().saveRepository(repo); final GlobalExecutionStatus result = DefaultBundleProcessorManager.INSTANCE.executeBundles(username, password, descriptor, includedFilesContextFactory, settings, group); Assert.assertThat(result, Is.is(GlobalExecutionStatus.SUCCESS)); ctx = includedFilesContextFactory.createExecutionContext(username, password, descriptor, group.getRootRepository()); final NoNodeRoot = ctx.getGraphSession().getContext(JavaConstants.ABSTRACT_CONTEXT).getRootNode(); final NodeNodetNode = ctxRoot.getNode("java.lang").getNode("Object"); Assert.assertThat(objectNode, Is.is(IsNull.notNullValue())); final SessionWithLock session = ctx.getDefaultConnectionProvider().openSession(); final Node node = session.getRootNode().getNode(SLConsts.DEFAULT_JCR_ROOT_NAME); new File("target/test-data/").mkdirs(); final BufferedOutputStream bufferedOutputStream = new BufferedOutputStream( new FileOutputStream( "target/test-data/exported-stress-data.xml")); session.exportSystemView(node.getPath(), bufferedOutputStream, false, false); bufferedOutputStream.flush(); bufferedOutputStream.close(); final NodeIterator contexts = node.getNodes("name/contexts").nextNode().getNodes(); while (contexts.hasNext()) { final Node ctxNode = contexts.nextNode(); final BufferedOutputStream o = new BufferedOutputStream(new FileOutputStream("target/test-data/exported-" + ctxNode.getName() + ".xml")); logger.debug("exported-" + ctxNode.getName() + ".xml"); session.exportSystemView(node.getPath(), o, false, false); bufferedOutputStream.flush(); bufferedOutputStream.close(); } System.err.println("Done test! Server is still waiting connections on port 7070"); while (true) { Thread.sleep(5000); } } }