summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorJoshua Haberman <jhaberman@gmail.com>2015-06-22 15:37:59 -0700
committerJoshua Haberman <jhaberman@gmail.com>2015-06-22 15:37:59 -0700
commitff8b042ad310f105249eeab761427669d6fe9766 (patch)
treedaeed7a7201ca0440a0b34f66ee0525369ccf113 /tests
parentd264438d15a8f5a6b539ce38f8ea125ab5f1dd98 (diff)
parentc3e9a57a6fff08640f3ad05e8df971d5ddb37d51 (diff)
Merge pull request #30 from haberman/encoderfix
Fixed some bad bugs in upb_env.
Diffstat (limited to 'tests')
-rw-r--r--tests/pb/test_encoder.cc52
1 files changed, 52 insertions, 0 deletions
diff --git a/tests/pb/test_encoder.cc b/tests/pb/test_encoder.cc
new file mode 100644
index 0000000..8a222f4
--- /dev/null
+++ b/tests/pb/test_encoder.cc
@@ -0,0 +1,52 @@
+
+#include "tests/upb_test.h"
+#include "upb/bindings/stdc++/string.h"
+#include "upb/descriptor/descriptor.upb.h"
+#include "upb/pb/decoder.h"
+#include "upb/pb/encoder.h"
+#include "upb/pb/glue.h"
+
+std::string read_string(const char *filename) {
+ size_t len;
+ char *str = upb_readfile(filename, &len);
+ ASSERT(str);
+ if (!str) { return std::string(); }
+ std::string ret = std::string(str, len);
+ free(str);
+ return ret;
+}
+
+void test_pb_roundtrip() {
+ upb::reffed_ptr<const upb::MessageDef> md(
+ upbdefs::google::protobuf::FileDescriptorSet::MessageDef());
+ upb::reffed_ptr<const upb::Handlers> encoder_handlers(
+ upb::pb::Encoder::NewHandlers(md.get()));
+ upb::reffed_ptr<const upb::pb::DecoderMethod> method(
+ upb::pb::DecoderMethod::New(
+ upb::pb::DecoderMethodOptions(encoder_handlers.get())));
+
+ char buf[512];
+ upb::SeededAllocator alloc(buf, sizeof(buf));
+ upb::Environment env;
+ env.SetAllocator(&alloc);
+ std::string input = read_string("upb/descriptor/descriptor.pb");
+ std::string output;
+ upb::StringSink string_sink(&output);
+ upb::pb::Encoder* encoder =
+ upb::pb::Encoder::Create(&env, encoder_handlers.get(),
+ string_sink.input());
+ upb::pb::Decoder* decoder =
+ upb::pb::Decoder::Create(&env, method.get(), encoder->input());
+ bool ok = upb::BufferSource::PutBuffer(input, decoder->input());
+ ASSERT(ok);
+ ASSERT(input == output);
+}
+
+extern "C" {
+int run_tests(int argc, char *argv[]) {
+ UPB_UNUSED(argc);
+ UPB_UNUSED(argv);
+ test_pb_roundtrip();
+ return 0;
+}
+}
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback