Copy two data files from ruby/tests to src/google/compiler/ruby. Tests in src/google/compiler/ruby depend on these two files, but they were missed in language distributions other than ruby
This commit is contained in:
parent
eef79f3ef0
commit
a9332e201d
4 changed files with 150 additions and 7 deletions
|
@ -449,6 +449,8 @@ EXTRA_DIST = \
|
|||
google/protobuf/testdata/text_format_unittest_extensions_data_pointy.txt \
|
||||
google/protobuf/package_info.h \
|
||||
google/protobuf/io/package_info.h \
|
||||
google/protobuf/compiler/ruby/ruby_generated_code.proto \
|
||||
google/protobuf/compiler/ruby/ruby_generated_code.rb \
|
||||
google/protobuf/compiler/package_info.h \
|
||||
google/protobuf/compiler/zip_output_unittest.sh \
|
||||
google/protobuf/unittest_enormous_descriptor.proto
|
||||
|
|
67
src/google/protobuf/compiler/ruby/ruby_generated_code.proto
Normal file
67
src/google/protobuf/compiler/ruby/ruby_generated_code.proto
Normal file
|
@ -0,0 +1,67 @@
|
|||
syntax = "proto3";
|
||||
|
||||
package A.B.C;
|
||||
|
||||
message TestMessage {
|
||||
int32 optional_int32 = 1;
|
||||
int64 optional_int64 = 2;
|
||||
uint32 optional_uint32 = 3;
|
||||
uint64 optional_uint64 = 4;
|
||||
bool optional_bool = 5;
|
||||
double optional_double = 6;
|
||||
float optional_float = 7;
|
||||
string optional_string = 8;
|
||||
bytes optional_bytes = 9;
|
||||
TestEnum optional_enum = 10;
|
||||
TestMessage optional_msg = 11;
|
||||
|
||||
repeated int32 repeated_int32 = 21;
|
||||
repeated int64 repeated_int64 = 22;
|
||||
repeated uint32 repeated_uint32 = 23;
|
||||
repeated uint64 repeated_uint64 = 24;
|
||||
repeated bool repeated_bool = 25;
|
||||
repeated double repeated_double = 26;
|
||||
repeated float repeated_float = 27;
|
||||
repeated string repeated_string = 28;
|
||||
repeated bytes repeated_bytes = 29;
|
||||
repeated TestEnum repeated_enum = 30;
|
||||
repeated TestMessage repeated_msg = 31;
|
||||
|
||||
oneof my_oneof {
|
||||
int32 oneof_int32 = 41;
|
||||
int64 oneof_int64 = 42;
|
||||
uint32 oneof_uint32 = 43;
|
||||
uint64 oneof_uint64 = 44;
|
||||
bool oneof_bool = 45;
|
||||
double oneof_double = 46;
|
||||
float oneof_float = 47;
|
||||
string oneof_string = 48;
|
||||
bytes oneof_bytes = 49;
|
||||
TestEnum oneof_enum = 50;
|
||||
TestMessage oneof_msg = 51;
|
||||
}
|
||||
|
||||
map<int32, string> map_int32_string = 61;
|
||||
map<int64, string> map_int64_string = 62;
|
||||
map<uint32, string> map_uint32_string = 63;
|
||||
map<uint64, string> map_uint64_string = 64;
|
||||
map<bool, string> map_bool_string = 65;
|
||||
map<string, string> map_string_string = 66;
|
||||
map<string, TestMessage> map_string_msg = 67;
|
||||
map<string, TestEnum> map_string_enum = 68;
|
||||
map<string, int32> map_string_int32 = 69;
|
||||
map<string, bool> map_string_bool = 70;
|
||||
|
||||
message NestedMessage {
|
||||
int32 foo = 1;
|
||||
}
|
||||
|
||||
NestedMessage nested_message = 80;
|
||||
}
|
||||
|
||||
enum TestEnum {
|
||||
Default = 0;
|
||||
A = 1;
|
||||
B = 2;
|
||||
C = 3;
|
||||
}
|
74
src/google/protobuf/compiler/ruby/ruby_generated_code.rb
Normal file
74
src/google/protobuf/compiler/ruby/ruby_generated_code.rb
Normal file
|
@ -0,0 +1,74 @@
|
|||
# Generated by the protocol buffer compiler. DO NOT EDIT!
|
||||
# source: ruby_generated_code.proto
|
||||
|
||||
require 'google/protobuf'
|
||||
|
||||
Google::Protobuf::DescriptorPool.generated_pool.build do
|
||||
add_message "A.B.C.TestMessage" do
|
||||
optional :optional_int32, :int32, 1
|
||||
optional :optional_int64, :int64, 2
|
||||
optional :optional_uint32, :uint32, 3
|
||||
optional :optional_uint64, :uint64, 4
|
||||
optional :optional_bool, :bool, 5
|
||||
optional :optional_double, :double, 6
|
||||
optional :optional_float, :float, 7
|
||||
optional :optional_string, :string, 8
|
||||
optional :optional_bytes, :string, 9
|
||||
optional :optional_enum, :enum, 10, "A.B.C.TestEnum"
|
||||
optional :optional_msg, :message, 11, "A.B.C.TestMessage"
|
||||
repeated :repeated_int32, :int32, 21
|
||||
repeated :repeated_int64, :int64, 22
|
||||
repeated :repeated_uint32, :uint32, 23
|
||||
repeated :repeated_uint64, :uint64, 24
|
||||
repeated :repeated_bool, :bool, 25
|
||||
repeated :repeated_double, :double, 26
|
||||
repeated :repeated_float, :float, 27
|
||||
repeated :repeated_string, :string, 28
|
||||
repeated :repeated_bytes, :string, 29
|
||||
repeated :repeated_enum, :enum, 30, "A.B.C.TestEnum"
|
||||
repeated :repeated_msg, :message, 31, "A.B.C.TestMessage"
|
||||
map :map_int32_string, :int32, :string, 61
|
||||
map :map_int64_string, :int64, :string, 62
|
||||
map :map_uint32_string, :uint32, :string, 63
|
||||
map :map_uint64_string, :uint64, :string, 64
|
||||
map :map_bool_string, :bool, :string, 65
|
||||
map :map_string_string, :string, :string, 66
|
||||
map :map_string_msg, :string, :message, 67, "A.B.C.TestMessage"
|
||||
map :map_string_enum, :string, :enum, 68, "A.B.C.TestEnum"
|
||||
map :map_string_int32, :string, :int32, 69
|
||||
map :map_string_bool, :string, :bool, 70
|
||||
optional :nested_message, :message, 80, "A.B.C.TestMessage.NestedMessage"
|
||||
oneof :my_oneof do
|
||||
optional :oneof_int32, :int32, 41
|
||||
optional :oneof_int64, :int64, 42
|
||||
optional :oneof_uint32, :uint32, 43
|
||||
optional :oneof_uint64, :uint64, 44
|
||||
optional :oneof_bool, :bool, 45
|
||||
optional :oneof_double, :double, 46
|
||||
optional :oneof_float, :float, 47
|
||||
optional :oneof_string, :string, 48
|
||||
optional :oneof_bytes, :string, 49
|
||||
optional :oneof_enum, :enum, 50, "A.B.C.TestEnum"
|
||||
optional :oneof_msg, :message, 51, "A.B.C.TestMessage"
|
||||
end
|
||||
end
|
||||
add_message "A.B.C.TestMessage.NestedMessage" do
|
||||
optional :foo, :int32, 1
|
||||
end
|
||||
add_enum "A.B.C.TestEnum" do
|
||||
value :Default, 0
|
||||
value :A, 1
|
||||
value :B, 2
|
||||
value :C, 3
|
||||
end
|
||||
end
|
||||
|
||||
module A
|
||||
module B
|
||||
module C
|
||||
TestMessage = Google::Protobuf::DescriptorPool.generated_pool.lookup("A.B.C.TestMessage").msgclass
|
||||
TestMessage::NestedMessage = Google::Protobuf::DescriptorPool.generated_pool.lookup("A.B.C.TestMessage.NestedMessage").msgclass
|
||||
TestEnum = Google::Protobuf::DescriptorPool.generated_pool.lookup("A.B.C.TestEnum").enummodule
|
||||
end
|
||||
end
|
||||
end
|
|
@ -48,7 +48,7 @@ namespace {
|
|||
string FindRubyTestDir() {
|
||||
// Inspired by TestSourceDir() in src/google/protobuf/testing/googletest.cc.
|
||||
string prefix = ".";
|
||||
while (!File::Exists(prefix + "/ruby/tests")) {
|
||||
while (!File::Exists(prefix + "/src/google/protobuf/compiler/ruby")) {
|
||||
if (!File::Exists(prefix)) {
|
||||
GOOGLE_LOG(FATAL)
|
||||
<< "Could not find Ruby test directory. Please run tests from "
|
||||
|
@ -56,7 +56,7 @@ string FindRubyTestDir() {
|
|||
}
|
||||
prefix += "/..";
|
||||
}
|
||||
return prefix + "/ruby/tests";
|
||||
return prefix + "/src/google/protobuf/compiler/ruby";
|
||||
}
|
||||
|
||||
// This test is a simple golden-file test over the output of the Ruby code
|
||||
|
@ -78,11 +78,11 @@ TEST(RubyGeneratorTest, GeneratorTest) {
|
|||
// Copy generated_code.proto to the temporary test directory.
|
||||
string test_input;
|
||||
GOOGLE_CHECK_OK(File::GetContents(
|
||||
ruby_tests + "/generated_code.proto",
|
||||
ruby_tests + "/ruby_generated_code.proto",
|
||||
&test_input,
|
||||
true));
|
||||
GOOGLE_CHECK_OK(File::SetContents(
|
||||
TestTempDir() + "/generated_code.proto",
|
||||
TestTempDir() + "/ruby_generated_code.proto",
|
||||
test_input,
|
||||
true));
|
||||
|
||||
|
@ -93,7 +93,7 @@ TEST(RubyGeneratorTest, GeneratorTest) {
|
|||
"protoc",
|
||||
ruby_out.c_str(),
|
||||
proto_path.c_str(),
|
||||
"generated_code.proto",
|
||||
"ruby_generated_code.proto",
|
||||
};
|
||||
|
||||
EXPECT_EQ(0, cli.Run(4, argv));
|
||||
|
@ -101,12 +101,12 @@ TEST(RubyGeneratorTest, GeneratorTest) {
|
|||
// Load the generated output and compare to the expected result.
|
||||
string output;
|
||||
GOOGLE_CHECK_OK(File::GetContents(
|
||||
TestTempDir() + "/generated_code.rb",
|
||||
TestTempDir() + "/ruby_generated_code.rb",
|
||||
&output,
|
||||
true));
|
||||
string expected_output;
|
||||
GOOGLE_CHECK_OK(File::GetContents(
|
||||
ruby_tests + "/generated_code.rb",
|
||||
ruby_tests + "/ruby_generated_code.rb",
|
||||
&expected_output,
|
||||
true));
|
||||
EXPECT_EQ(expected_output, output);
|
||||
|
|
Loading…
Add table
Reference in a new issue