0

Mockito と Podam を使用して JUnit テストを作成しています。多くの機能は正常に動作していますが、再帰オブジェクトの生成中に 1 つのテスト ケースで問題が発生しました。

次のようなコードでは、行PodamMockeryExceptionに podam 7.0.0.RELEASE がスローされます。manufacturePojo()

@Test
 public void testDoTest() {
     PodamFactory podamfactory = new PodamFactoryImpl();
     Entity eTest = podamfactory.manufacturePojo(Entity.class);
     ...
 }

より多くのスタック トレースとエンティティを以下に示します。

Entity は JPA エンティティであり、次のようになります。

public class Entity extends AllTheEntities {
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "DOCUMENT_SEQ")
    @SequenceGenerator(name = "DOCUMENT_SEQ", sequenceName = "DOCUMENT_SEQ", allocationSize = 1)
    @Column(name = "DOCUMENT_ID", precision = 19)
    private long objectId;
    @Column(name = "NAME")
    private String name;

    // bi-directional many-to-one associations
    @ManyToOne
    @JoinColumn(name = "FK_STND_MIME_TYPE_ID", nullable = false)
    private StndMimeTypeEntity stndMimeType;

    @OneToMany(mappedBy = "document", cascade = CascadeType.REMOVE)
    private List<FolderThingEntity> FolderThings;

    @OneToMany(mappedBy = "document", cascade = CascadeType.ALL)
    private List<FieldData> fieldData;

    @OneToMany(mappedBy="document")
    private List<PersonalFormContentEntity> personalFormContents;

    public Entity() {
    }

    public void setName(String name) {
        this.name = name;
    }

    public List<FieldData> getDocumentBindFieldData() {
        return this.fieldData;
    }

    public void setDocumentBindFieldData(
            List<FieldData> fieldData) {
        this.fieldData = fieldData;
    }

    public FieldData addDocumentBindFieldData(
            FieldData fieldData) {
        getDocumentBindFieldData().add(fieldData);
        fieldData.setDocument(this);

        return fieldData;
    }

    @Override
    public String toString() {
        return "Entity [objectId=" + objectId + ", name="
    + name + ", stndMimeType=" + stndMimeType.getStndMimeTypeId() + "]";
    }

    public OfficeActionEntity getForm() {

        FolderThingEntity fd = getFolderThings().get(0);

        FolderEntity folderEntity = fd.getFolder();

        return folderEntity.getForm();

    }

}

もう少しスタック トレース:

uk.co.jemos.podam.exceptions.PodamMockeryException
    at uk.co.jemos.podam.api.PodamFactoryImpl.doManufacturePojo(PodamFactoryImpl.java:443)
    at uk.co.jemos.podam.api.PodamFactoryImpl.manufacturePojo(PodamFactoryImpl.java:148)
    at CENSORED(CENSOREDTest.java:261)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
  ... 20 more
Caused by: java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at uk.co.jemos.podam.api.PodamFactoryImpl.populatePojoInternal(PodamFactoryImpl.java:694)
    at uk.co.jemos.podam.api.PodamFactoryImpl.manufacturePojoInternal(PodamFactoryImpl.java:532)
    at uk.co.jemos.podam.api.PodamFactoryImpl.manufactureAttributeValue(PodamFactoryImpl.java:885)
    at uk.co.jemos.podam.api.PodamFactoryImpl.populatePojoInternal(PodamFactoryImpl.java:687)
    at uk.co.jemos.podam.api.PodamFactoryImpl.manufacturePojoInternal(PodamFactoryImpl.java:532)
    at uk.co.jemos.podam.api.PodamFactoryImpl.doManufacturePojo(PodamFactoryImpl.java:436)
    ... 30 more
Caused by: java.lang.IllegalArgumentException: nanos > 999999999 or < 0
    at java.sql.Timestamp.setNanos(Timestamp.java:386)
    ... 40 more
4

1 に答える 1

2

FieldDataオブジェクトにそれが含まれているjava.sql.Timestampか、拡張されていると思います。後者は、セッターに非常に具体的な値を必要とします。そのため、このクラスに合わせてカスタマイズされたランダム値が必要です。これを実現する方法の例を次に示します。

PodamFactory podamFactory = new PodamFactoryImpl();
TypeManufacturer<Integer> manufacturer = new IntTypeManufacturerImpl() {

    @Override
    public Integer getInteger(AttributeMetadata attributeMetadata) {

        if (attributeMetadata.getPojoClass() instanceof Timestamp) {
            return PodamUtils.getIntegerInRange(0, 999999999);
        } else {
            return super.getInteger(attributeMetadata);
        }
    }
};
podamFactory.getStrategy().addOrReplaceTypeManufacturer(int.class, manufacturer);

FieldData pojo = podamFactory.manufacturePojo(FieldData.class);
于 2017-04-27T10:27:18.647 に答える