SConscript 1.4 KB

12345678910111213141516171819202122232425262728293031323334
  1. # Version of AllTypes test case for protobuf 3 file format.
  2. Import("env")
  3. env.NanopbProto(["alltypes", "alltypes.options"])
  4. enc = env.Program(["encode_alltypes.c", "alltypes.pb.c", "$COMMON/pb_encode.o", "$COMMON/pb_common.o"])
  5. dec = env.Program(["decode_alltypes.c", "alltypes.pb.c", "$COMMON/pb_decode.o", "$COMMON/pb_common.o"])
  6. # Test the round-trip from nanopb encoder to nanopb decoder
  7. env.RunTest(enc)
  8. env.RunTest([dec, "encode_alltypes.output"])
  9. # Re-encode the data using protoc, and check that the results from nanopb
  10. # match byte-per-byte to the protoc output.
  11. env.Decode("encode_alltypes.output.decoded",
  12. ["encode_alltypes.output", "alltypes.proto"],
  13. MESSAGE='AllTypes')
  14. env.Encode("encode_alltypes.output.recoded",
  15. ["encode_alltypes.output.decoded", "alltypes.proto"],
  16. MESSAGE='AllTypes')
  17. env.Compare(["encode_alltypes.output", "encode_alltypes.output.recoded"])
  18. # Do the same checks with the optional fields present.
  19. env.RunTest("optionals.output", enc, ARGS = ['1'])
  20. env.RunTest("optionals.decout", [dec, "optionals.output"], ARGS = ['1'])
  21. env.Decode("optionals.output.decoded",
  22. ["optionals.output", "alltypes.proto"],
  23. MESSAGE='AllTypes')
  24. env.Encode("optionals.output.recoded",
  25. ["optionals.output.decoded", "alltypes.proto"],
  26. MESSAGE='AllTypes')
  27. env.Compare(["optionals.output", "optionals.output.recoded"])