Весеннее пакетное тестирование с помощью jUnit всегда выдает мне исключение NullPointerException - PullRequest
0 голосов
/ 05 марта 2019

Я пытаюсь проверить работу в весеннем пакете с помощью jUnit, и я не знаю, как решить эту ошибку.

У меня есть этот класс

ParametersValidatorService

@Service("parametersValidator")
public class ParametersValidatorService implements IParameterValidatorService {

/**
 * The Constant LOGGER.
 */
private static final Logger LOGGER = LoggerFactory.getLogger(ParametersValidatorService.class);

/**
 * Array con los parametros obligatorios.
 */
private static final String[] PARAMETROS_OBLIGATORIOS = new String[]{
        "val1", "val2", "val3", "val4", "val5", "val6", "val7"
};

/**
 * Array con los parametros que deben ser numericos.
 */
private static final String[] PARAMETROS_NUMERICOS = new String[]{
        "val1", "val2", "val3", "val4"};

/**
 * @param jobId:      the job id
 * @param parameters: input job parameters
 * ParametersValidatorException: manages exceptions related with input parameters.
 */
@Override
public void validate(final String jobId, final JobParameters parameters) throws ParametersValidatorException {
    try {
        validate(parameters);
    } catch (JobParametersInvalidException e) {
        throw new ParametersValidatorException(e);
    }
}

/**
 * @param parameters: input job parameters
 * JobParametersInvalidException: manages exceptions related with input parameters.
 */
@Override
public void validate(final JobParameters parameters) throws JobParametersInvalidException {
    validarParametros(parameters);
}


/**
 * Comprueba que los parámetros no estén vacíos y que los que tienen que ser numéricos, sean numéricos
 *
 * @param parameters: input job parameters
 * JobParametersInvalidException: manages exceptions related with input parameters.
 */
private void validarParametros(final JobParameters parameters) throws JobParametersInvalidException {

    List<String> numericParameters = Arrays.asList(PARAMETROS_NUMERICOS);
    String error = null;
    for (String validacion : PARAMETROS_OBLIGATORIOS) {

        if (StringUtils.isBlank(parameters.getString(validacion))) {
            error = "El parametro " + validacion + " es obligatorio";
        } else if (numericParameters.contains(validacion) && !StringUtils.isNumeric(parameters.getString(validacion))) {
            error = "El parametro " + validacion + " debe ser numerico";
        }
        if (error != null) {
            LOGGER.error(error);
            throw new JobParametersInvalidException(error);
        }
    }
}

}

Я пытаюсь проверить это с помощью jUnit4, но не могу выполнить его правильно.Я сделал этот тест

ParametersValidatorServiceTest

@RunWith(SpringJUnit4ClassRunner.class)
public class ParametersValidatorServiceTest {


//@Autowired
@Bean
public JobLauncherTestUtils jobLauncherTestUtils() {
    return new JobLauncherTestUtils();
}


@Test
public void testLaunchJobOK() throws Exception {

    JobParameters jobParameters = new JobParametersBuilder().addString("val1", "1")
                                                            .addString("val2", "Nombre de prueba")
                                                            .addString("val3", "61").addString("val6", "1")
                                                            .addString("val4", "RCVD").addString("val7", "43")
                                                            .addString("val5", "2017-05-10 10:48:42").toJobParameter

    JobExecution jobExecution = jobLauncherTestUtils().launchJob(jobParameters);
    Assert.assertEquals(ExitStatus.COMPLETED.getExitCode(), jobExecution.getExitStatus().getExitCode());

}

}

Я всегда получаю исключение java.lang.NullPointerException, как показано ниже

java.lang.NullPointerException
at org.springframework.batch.test.JobLauncherTestUtils.launchJob(JobLauncherTestUtils.java:152)
at com.bbva.kyob.respuestasob.services.impl.ParametersValidatorServiceTest.testLaunchJobOK(ParametersValidatorServiceTest.java:59)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:252)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:94)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:191)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:89)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:41)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:541)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:763)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:463)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:209)

Когда я делаю отладку теста, я вижу, что вводимые параметры собираются и сохраняются в jobParameters, поэтому я не знаю, что происходит

1 Ответ

0 голосов
/ 05 марта 2019

Если подумать, нет ли ссылки на какую-либо работу в классе ParametersValidatorServiceTest, верно?Поэтому, когда вы выполняете этот оператор:

JobExecution jobExecution = jobLauncherTestUtils().launchJob(jobParameters);

Какое задание должно быть запущено?Работа на самом деле зависимость от JobLauncherTestUtils.Вот почему в вашем тестовом контексте это должно быть определено для правильной автопроводки в JobLauncherTestUtils.Например, вы можете импортировать класс конфигурации, содержащий его определение:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(classes = {MyJobConfiguration.class}) // contains the job bean under test
public class ParametersValidatorServiceTest {
   // ...
}

Надеюсь, это поможет.

...