1

テストスイートにある他の多くのテストケースと同じように、パラメーター化されたテストケースがあり、それらを追加しようとしています。

package com.example;

import com.google.gson.Gson;
import com.example.Event;
import com.example.LocalStorage;
import com.example.TimeMachine;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;

import java.util.Arrays;
import java.util.Collection;

import static org.fest.assertions.api.Assertions.assertThat;
import static org.mockito.Mockito.mock;

@RunWith(Parameterized.class)
public class TimeMachineEventEndTimeTest {

    public TimeMachineEventEndTimeTest(Event event, String end_time) {
        _event = event;
        _end_time = end_time;
    }

    @Parameters
    public static Collection<Object[]> data() {
        return Arrays.asList(new Object[][]{
            { _UNSCHEDULED, "" },
            { _NOON_FOR_1_HOUR, "13:00" },
            { _NOON_FOR_HALF_HOUR, "12:30" },
            { _MIDNIGHT_FOR_1_HOUR, "1:00" },
            { _MIDNIGHT_FOR_HALF_HOUR, "0:30" },
            { _MIDNIGHT_FOR_12_HOUR, "12:00" }
        });
    }

    @Before
    public void initialize() throws Exception {
        _time_machine = new _TimeMachine();
    }

    @Test
    public void testEndTimeForEvent() throws Exception {
        assertThat(_time_machine.endTimeForEvent(_event)).isEqualTo(_end_time);
    }

    private TimeMachine _time_machine;
    private final Event _event;
    private final String _end_time;
    private static final Gson _gson = new _GsonProvider(mock(LocalStorage.class)).gson();
    private static final Event _UNSCHEDULED = _gson.fromJson("{}", Event.class);
    private static final Event _NOON_FOR_1_HOUR = _gson.fromJson("{\n" +
        "      \"starttime\" : \"12:00\",\n" +
        "      \"duration\" : \"60\",\n" +
        "    }", Event.class);
    private static final Event _NOON_FOR_HALF_HOUR = _gson.fromJson("{\n" +
        "      \"starttime\" : \"12:00\",\n" +
        "      \"duration\" : \"30\",\n" +
        "    }", Event.class);
    private static final Event _MIDNIGHT_FOR_1_HOUR = _gson.fromJson("{\n" +
        "      \"starttime\" : \"0:00\",\n" +
        "      \"duration\" : \"60\",\n" +
        "    }", Event.class);
    private static final Event _MIDNIGHT_FOR_HALF_HOUR = _gson.fromJson("{\n" +
        "      \"starttime\" : \"0:00\",\n" +
        "      \"duration\" : \"30\",\n" +
        "    }", Event.class);
    private static final Event _MIDNIGHT_FOR_12_HOUR = _gson.fromJson("{\n" +
        "      \"starttime\" : \"0:00\",\n" +
        "      \"duration\" : \"360\",\n" +
        "    }", Event.class);
}

同じディレクトリとパッケージでさまざまなメソッドをテストする、ほぼ同じ構造のテスト ケースがいくつかあります。このテスト ケースがこのスタック トレースをスローすることを除いて、他のすべてのテストが実行され、100% 合格します。

java.lang.NoClassDefFoundError: org.apache.maven.surefire の java.lang.Class.forName(Class.java:186) で java.lang.Class.forName0(Native Method) でクラス com.example.TimeMachineEventEndTimeTest を初期化できませんでした.report.SmartStackTraceParser.getClass(SmartStackTraceParser.java:63) org.apache.maven.surefire.report.SmartStackTraceParser.(SmartStackTraceParser.java:53) org.apache.maven.surefire.common.junit4.JUnit4StackTraceWriter.smartTrimmedStackTrace( JUnit4StackTraceWriter.java:72) org.apache.maven.surefire.booter.ForkingRunListener.encode(ForkingRunListener.java:328) org.apache.maven.surefire.booter.ForkingRunListener.encode(ForkingRunListener.java:312) org .apache.maven.surefire.booter.ForkingRunListener.toString(ForkingRunListener.java:258) at org.apache.maven.surefire.booter.ForkingRunListener.testError(ForkingRunListener.java:131) org.apache.maven.surefire.common.junit4.JUnit4RunListener.testFailure(JUnit4RunListener.java:111) org.junit.runner.notification.RunNotifier$4.notifyListener(RunNotifier.java) :100) org.junit.runner.notification.RunNotifier$SafeNotifier.run(RunNotifier.java:41) で org.junit.runner.notification.RunNotifier.fireTestFailure(RunNotifier.java:97) で org.junit.internal. org.junit.internal.runners.ErrorReportingRunner.run(ErrorReportingRunner.java:34) の runners.ErrorReportingRunner.runCause(ErrorReportingRunner.java:57) org.apache.maven.surefire.junit4.JUnit4Provider.execute(JUnit4Provider.java: 264) org.apache.maven.surefire.junit4.JUnit4Provider.executeTestSet(JUnit4Provider.java:153) で org.apache.maven.surefire.junit4.JUnit4Provider.invoke(JUnit4Provider.java:124)

4

2 に答える 2

1

IDE からテストを実行できますか? https://jira.codehaus.org/browse/SUREFIRE-962のため、スタック トレースが誤解を招くようです。

問題を再現する実行可能な要点を提供していただけると助かります。

于 2013-07-27T22:44:10.440 に答える
0

他の誰かが同様の問題に遭遇した場合、私にとっては、いくつかEventの s を作成したのは最後の数行だったようです。JSON に小さなエラーがあり、Gsonそれらを作成するときにエラーが発生するはずです。

 private static final Event _NOON_FOR_1_HOUR = _gson.fromJson("{\n" +
    "      \"starttime\" : \"12:00\",\n" +
    "      \"duration\" : \"60\"\n" +
    "    }", Event.class);
private static final Event _NOON_FOR_HALF_HOUR = _gson.fromJson("{\n" +
    "      \"starttime\" : \"12:00\",\n" +
    "      \"duration\" : \"30\"\n" +
    "    }", Event.class);
private static final Event _MIDNIGHT_FOR_1_HOUR = _gson.fromJson("{\n" +
    "      \"starttime\" : \"0:00\",\n" +
    "      \"duration\" : \"60\"\n" +
    "    }", Event.class);
private static final Event _MIDNIGHT_FOR_HALF_HOUR = _gson.fromJson("{\n" +
    "      \"starttime\" : \"0:00\",\n" +
    "      \"duration\" : \"30\"\n" +
    "    }", Event.class);
private static final Event _MIDNIGHT_FOR_12_HOUR = _gson.fromJson("{\n" +
    "      \"starttime\" : \"0:00\",\n" +
    "      \"duration\" : \"360\"\n" +
    "    }", Event.class);

修正は、「duration」値の後の「,」を削除することでした。実際、スタックトレースは非常にわかりにくく、かなり誤解を招くものだったようです。

于 2013-08-09T22:43:34.103 に答える