Прото-сгенерированный класс toString вызывает исключение

Я следую учебному пособию Google [ https://developers.google.com/protocol-buffers/docs/javatutorial?hl=en ], чтобы написать Proto Class.

Мой Прото файл

package protoc_Shashi;

option java_package="com.shashi.protoc.generated";
option java_outer_classname="AddressBookProtos";

message Person {
    required string name = 1;
    required int32 id = 2;
    optional string email = 3;

    enum PhoneType {
        MOBILE = 0;
        HOME = 1;
        WORK = 2;
    }

    message PhoneNumber {
        required string number = 1;
        optional PhoneType type = 2 [default = HOME];
    }

    repeated PhoneNumber number = 4;
}

message AddressBook {
    repeated Person person = 1;
}

и я писал тестовый случай Junit, чтобы создать новый Person объект, как указано в учебнике.
Объект создан, но вызывает его toString() Метод дает мне ошибку, что он должен быть переопределен подклассами. Stacetrace для того же выглядит следующим образом

java.lang.UnsupportedOperationException: This is supposed to be overridden by subclasses.
    at com.google.protobuf.GeneratedMessage.getUnknownFields(GeneratedMessage.java:192)
    at com.google.protobuf.TextFormat$Printer.print(TextFormat.java:301)
    at com.google.protobuf.TextFormat$Printer.printFieldValue(TextFormat.java:434)
    at com.google.protobuf.TextFormat$Printer.printSingleField(TextFormat.java:353)
    at com.google.protobuf.TextFormat$Printer.printField(TextFormat.java:309)
    at com.google.protobuf.TextFormat$Printer.print(TextFormat.java:299)
    at com.google.protobuf.TextFormat$Printer.access$400(TextFormat.java:273)
    at com.google.protobuf.TextFormat.print(TextFormat.java:76)
    at com.google.protobuf.TextFormat.printToString(TextFormat.java:143)
    at com.google.protobuf.AbstractMessage.toString(AbstractMessage.java:79)
    at com.shashi.protoc.generated.AddressBookProtosTest.createPerson(AddressBookProtosTest.java:29)

Мой тестовый класс Junit выглядит следующим образом

package com.shashi.protoc.generated;

import org.junit.Test;

/**
 * @author Shashi Bhushan
 *         Created on 29/12/15.
 *         For Google-Protoc
 */
public class AddressBookProtosTest {

    @Test
    public void createPerson(){
        AddressBookProtos.Person person =
                AddressBookProtos.Person.newBuilder()
                .setId(100)
                .setName("Shashi")
                .setEmail("sb@sb.com")
                .addNumber(
                        AddressBookProtos.Person.PhoneNumber.newBuilder()
                                .setNumber("555")
                                .setType(AddressBookProtos.Person.PhoneType.WORK)
                )
                .build();

        System.out.println("Is Initialized : " +
                person.isInitialized());
        System.out.println("To String : " +
                person.toString());     // Error on this line
    }
}

я что-то здесь упускаю?

1 ответ

Решение

Убедитесь, что ваш protoc и ваш libprotobuf.jar точно такая же версия. Исходя из трассировки стека, я предполагаю, что вы используете protoc v3 и libprotobuf.jar v2.x, хотя я не уверен. В общем, вы всегда должны использовать одни и те же версии этих двух вещей, потому что protoc генерирует код, который зависит от частных API в libprotobuf.jar которые часто меняются между версиями.

Другие вопросы по тегам