Commit 47d33e75 authored by Jon Skeet's avatar Jon Skeet Committed by Jon Skeet

Test locations, and add comment to clarify testing

parent 6e39eaad
...@@ -45,6 +45,14 @@ namespace Google.Protobuf.Test.Reflection ...@@ -45,6 +45,14 @@ namespace Google.Protobuf.Test.Reflection
// Note: we don't expose a declaration for FileDescriptor as it doesn't have comments // Note: we don't expose a declaration for FileDescriptor as it doesn't have comments
// at the moment and the locations aren't terribly useful. // at the moment and the locations aren't terribly useful.
// The tests for most elements are quite basic: we don't test every aspect of every element.
// The code within the library falls into two categories:
// - Exposing the properties for *any* declaration
// - Finding the right declaration for an element from the descriptor data
// We have a per-element check to make sure we *are* finding the right declaration, and we
// check every property of declarations in at least one test, but we don't have a cross-product.
// That would effectively be testing protoc, which seems redundant here.
[Test] [Test]
public void ServiceComments() public void ServiceComments()
{ {
...@@ -72,6 +80,19 @@ namespace Google.Protobuf.Test.Reflection ...@@ -72,6 +80,19 @@ namespace Google.Protobuf.Test.Reflection
message.Declaration.LeadingDetachedComments); message.Declaration.LeadingDetachedComments);
} }
// Note: this test is somewhat brittle; a change earlier in the proto will break it.
[Test]
public void MessageLocations()
{
var message = unitTestProto3Descriptor.FindTypeByName<MessageDescriptor>("CommentMessage");
Assert.NotNull(message.Declaration);
Assert.AreEqual(389, message.Declaration.StartLine);
Assert.AreEqual(1, message.Declaration.StartColumn);
Assert.AreEqual(404, message.Declaration.EndLine);
Assert.AreEqual(2, message.Declaration.EndColumn);
}
[Test] [Test]
public void EnumComments() public void EnumComments()
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment