Backlog4jでカスタム項目(CustomField)が取得できない【Java】

Backlog4jを使用して、APIでBacklogを操作していたところ、課題のカスタム項目(CustomField)の取得がうまく行えなかった。
その時の問題内容と解決/回避策を残しておく。

目次

問題内容

Exception発生

カスタム項目(CustomField)を含む課題クラスをMapに変換しようとしたらExceptionが発生した。
「クラスをMapに変換」という処理は、具体的には以下で行っている。

Map map = new ObjectMapper().convertValue([変換したいオブジェクト], Map.class);

Exception詳細

2021/12/20 19:50:12,123 ERROR com.fasterxml.jackson.databind.JsonMappingException: Cannot invoke "java.math.BigDecimal.longValue()" because "this.value" is null (through reference chain: com.nulabinc.backlog4j.internal.json.IssueJSONImpl["customFields"]->java.util.Arrays$ArrayList[3]->com.nulabinc.backlog4j.internal.json.customFields.NumericCustomField["longValue"]) [tool.execute.BacklogGetIssue]
com.fasterxml.jackson.databind.JsonMappingException: Cannot invoke "java.math.BigDecimal.longValue()" because "this.value" is null (through reference chain: com.nulabinc.backlog4j.internal.json.IssueJSONImpl["customFields"]->java.util.Arrays$ArrayList[3]->com.nulabinc.backlog4j.internal.json.customFields.NumericCustomField["longValue"])
    at com.fasterxml.jackson.databind.JsonMappingException.wrapWithPath(JsonMappingException.java:390)
    at com.fasterxml.jackson.databind.JsonMappingException.wrapWithPath(JsonMappingException.java:349)
    at com.fasterxml.jackson.databind.ser.std.StdSerializer.wrapAndThrow(StdSerializer.java:316)
    at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:778)
    at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:178)
    at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serializeContents(IndexedListSerializer.java:119)
    at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serialize(IndexedListSerializer.java:79)
    at com.fasterxml.jackson.databind.ser.impl.IndexedListSerializer.serialize(IndexedListSerializer.java:18)
    at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:728)
    at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:770)
    at com.fasterxml.jackson.databind.ser.BeanSerializer.serialize(BeanSerializer.java:178)
    at com.fasterxml.jackson.databind.ser.DefaultSerializerProvider._serialize(DefaultSerializerProvider.java:480)
    at com.fasterxml.jackson.databind.ser.DefaultSerializerProvider.serializeValue(DefaultSerializerProvider.java:319)
    at com.fasterxml.jackson.databind.ObjectMapper._writeValueAndClose(ObjectMapper.java:4487)
    at com.fasterxml.jackson.databind.ObjectMapper.writeValueAsString(ObjectMapper.java:3742)
    at tool.execute.BackupBacklogGetIssue.main(BackupBacklogGetIssue.java:90)
Caused by: java.lang.NullPointerException: Cannot invoke "java.math.BigDecimal.longValue()" because "this.value" is null
    at com.nulabinc.backlog4j.internal.json.customFields.NumericCustomField.getLongValue(NumericCustomField.java:45)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:64)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:564)
    at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:689)
    at com.fasterxml.jackson.databind.ser.std.BeanSerializerBase.serializeFields(BeanSerializerBase.java:770)
    ... 12 more

原因(おそらく)

課題にカスタム項目を利用しているBacklogプロジェクトで、カスタム項目が数値型で且つnullの場合、Exceptionが発生するようだ。

上記問題を調査していたら、そもそもカスタム項目(CustomField)に値が設定されていても、その値が取得できないことがわかった。
ブレークポイントでデバッグしてみると、value値としては存在するが、その値を取得する術がなかった。
「name」や「id」、「fieldType」項目にはgetterがあるが、「value」項目にはgetterがない。
Backlog4jのjavadocも見てみたが、そちらにもない。
 Backlog4jのjavadoc

解決策/回避策

CustomFieldをMapに変換しようとするとExceptionが発生してしまうので、
その中身を1項目ずつMapに詰め替えるように対応した。

泣く泣くカスタム項目(CustomField)のvalue値の取得は諦めた。
取得可能な範囲での取得とした。

※Backlog側に問い合わせもしてみたが、自動での受付レスポンス以降の回答は頂けていない。
 「翌営業日までに返答」のところ、既に1週間程回答がないので、何か間違いがあったかもしれない。
 Backlogお問い合わせページ

よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!

この記事を書いた人

文系の大学を卒業後、未経験でWebエンジニアとしての道を歩む。
プログラミングスクールで基礎を学び、Webエンジニアとして就職。
今ではプロジェクト経験15年以上のベテランエンジニアに。
 
今までの経験を活かし、プログラミング関連の情報や生活に役立つ情報を配信していきます。

コメント

コメントする

目次