/*
* Copyright 2008-2013 Red Hat, Inc, and individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software 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 software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.torquebox.jobs.processors;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail;
import java.util.List;
import java.util.concurrent.TimeUnit;
import org.jboss.as.server.deployment.DeploymentUnitProcessingException;
import org.junit.Before;
import org.junit.Test;
import org.projectodd.polyglot.core.util.TimeInterval;
import org.projectodd.polyglot.test.as.MockDeploymentUnit;
import org.torquebox.core.app.processors.AppKnobYamlParsingProcessor;
import org.torquebox.core.processors.TorqueBoxYamlParsingProcessor;
import org.torquebox.jobs.JobSchedulerMetaData;
import org.torquebox.jobs.ScheduledJobMetaData;
import org.torquebox.test.as.AbstractDeploymentProcessorTestCase;
public class JobsYamlParsingProcessorTest extends AbstractDeploymentProcessorTestCase {
@Before
public void setUp() {
clearDeployers();
appendDeployer( new TorqueBoxYamlParsingProcessor() );
appendDeployer( new JobsYamlParsingProcessor() );
}
/** Ensure that an empty jobs.yml causes no problems. */
@Test
public void testEmptyJobsYml() throws Exception {
MockDeploymentUnit unit = deployResourceAsTorqueboxYml( "empty.yml" );
List<ScheduledJobMetaData> allMetaData = unit.getAttachmentList( ScheduledJobMetaData.ATTACHMENTS_KEY );
assertTrue( allMetaData.isEmpty() );
}
/** Ensure that a valid jobs.yml attaches metadata. */
@Test
public void testValidJobsYml() throws Exception {
MockDeploymentUnit unit = deployResourceAsTorqueboxYml( "valid-jobs.yml" );
JobSchedulerMetaData schedulerMetaData = unit.getAttachment( JobSchedulerMetaData.ATTACHMENT_KEY );
assertNotNull( schedulerMetaData );
assertEquals( 5, schedulerMetaData.getThreadCount() );
List<ScheduledJobMetaData> allJobMetaData = unit.getAttachmentList( ScheduledJobMetaData.ATTACHMENTS_KEY );
assertNotNull( allJobMetaData );
assertEquals( 4, allJobMetaData.size() );
ScheduledJobMetaData jobOne = getJobMetaData( allJobMetaData, "job.one" );
assertNotNull( jobOne );
assertEquals( "job.one", jobOne.getName() );
assertEquals( "My Job is routine", jobOne.getDescription() );
assertEquals( "01 * * * * ?", jobOne.getCronExpression() );
assertEquals( "MyJobClass", jobOne.getRubyClassName() );
assertEquals( "bar", jobOne.getParameters().get( "foo" ) );
assertTrue( jobOne.isSingleton() );
assertNotNull( jobOne.getGroup() );
assertFalse( jobOne.isStopped() );
ScheduledJobMetaData jobTwo = getJobMetaData( allJobMetaData, "job.two" );
assertNotNull( jobTwo );
assertEquals( "job.two", jobTwo.getName() );
assertEquals( "My other Job is extraodinary", jobTwo.getDescription() );
assertEquals( "01 01 01 15 * ?", jobTwo.getCronExpression() );
assertEquals( "MyOtherJobClass", jobTwo.getRubyClassName() );
assertTrue( jobTwo.isSingleton() );
assertNotNull( jobTwo.getGroup() );
assertFalse( jobTwo.isStopped() );
ScheduledJobMetaData jobThree = getJobMetaData( allJobMetaData, "job.three" );
assertNotNull( jobThree );
assertEquals( "job.three", jobThree.getName() );
assertEquals( "My non-singleton job class", jobThree.getDescription() );
assertEquals( "01 01 01 15 * ?", jobThree.getCronExpression() );
assertEquals( "NonSingletonJobClass", jobThree.getRubyClassName() );
assertFalse( jobThree.isSingleton() );
assertNotNull( jobThree.getGroup() );
assertFalse( jobThree.isStopped() );
ScheduledJobMetaData jobFour = getJobMetaData( allJobMetaData, "job.four" );
assertNotNull( jobFour );
assertEquals( "job.four", jobFour.getName() );
assertEquals( "My long running job has timeout", jobFour.getDescription() );
assertEquals( "01 01 01 15 * ?", jobFour.getCronExpression() );
assertEquals( "MyLongRunningJob", jobFour.getRubyClassName() );
assertEquals( new TimeInterval( 5000, TimeUnit.MILLISECONDS ), jobFour.getTimeout() );
assertTrue( jobFour.isSingleton() );
assertNotNull( jobFour.getGroup() );
assertTrue( jobFour.isStopped() );
assertEquals( jobOne.getGroup(), jobTwo.getGroup() );
assertEquals( jobOne.getGroup(), jobThree.getGroup() );
}
@Test
public void testNoUnitsJobTimeout() throws Exception {
MockDeploymentUnit unit = deployResourceAsTorqueboxYml( "timeout-nounits-jobs.yml" );
List<ScheduledJobMetaData> allJobMetaData = unit.getAttachmentList( ScheduledJobMetaData.ATTACHMENTS_KEY );
assertNotNull( allJobMetaData );
assertEquals( 1, allJobMetaData.size() );
ScheduledJobMetaData jobOne = getJobMetaData( allJobMetaData, "job.one" );
assertNotNull( jobOne );
assertEquals( "job.one", jobOne.getName() );
assertEquals( "My Job is routine", jobOne.getDescription() );
assertEquals( "01 * * * * ?", jobOne.getCronExpression() );
assertEquals( "MyNoUnitJobClass", jobOne.getRubyClassName() );
assertEquals( new TimeInterval( 60, TimeUnit.SECONDS ), jobOne.getTimeout() );
assertTrue( jobOne.isSingleton() );
assertNotNull( jobOne.getGroup() );
}
/**
* Locate a RubyJobMetaData given a collection and a name to search for.
*
* @param allJobMetaData
* The collection
* @param name
* The search name
* @return The found metadata, or null if no matching are found.
*/
protected ScheduledJobMetaData getJobMetaData(List<ScheduledJobMetaData> allJobMetaData, String name) {
for (ScheduledJobMetaData each : allJobMetaData) {
if (each.getName().equals( name )) {
return each;
}
}
return null;
}
}