...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29 package face
30
31 import (
32 "github.com/gogo/protobuf/gogoproto"
33 "github.com/gogo/protobuf/plugin/testgen"
34 "github.com/gogo/protobuf/protoc-gen-gogo/generator"
35 )
36
37 type test struct {
38 *generator.Generator
39 }
40
41 func NewTest(g *generator.Generator) testgen.TestPlugin {
42 return &test{g}
43 }
44
45 func (p *test) Generate(imports generator.PluginImports, file *generator.FileDescriptor) bool {
46 used := false
47 randPkg := imports.NewImport("math/rand")
48 timePkg := imports.NewImport("time")
49 testingPkg := imports.NewImport("testing")
50 for _, message := range file.Messages() {
51 ccTypeName := generator.CamelCaseSlice(message.TypeName())
52 if !gogoproto.IsFace(file.FileDescriptorProto, message.DescriptorProto) {
53 continue
54 }
55 if message.DescriptorProto.GetOptions().GetMapEntry() {
56 continue
57 }
58
59 if gogoproto.HasTestGen(file.FileDescriptorProto, message.DescriptorProto) {
60 used = true
61
62 p.P(`func Test`, ccTypeName, `Face(t *`, testingPkg.Use(), `.T) {`)
63 p.In()
64 p.P(`popr := `, randPkg.Use(), `.New(`, randPkg.Use(), `.NewSource(`, timePkg.Use(), `.Now().UnixNano()))`)
65 p.P(`p := NewPopulated`, ccTypeName, `(popr, true)`)
66 p.P(`msg := p.TestProto()`)
67 p.P(`if !p.Equal(msg) {`)
68 p.In()
69 p.P(`t.Fatalf("%#v !Face Equal %#v", msg, p)`)
70 p.Out()
71 p.P(`}`)
72 p.Out()
73 p.P(`}`)
74 }
75
76 }
77 return used
78 }
79
80 func init() {
81 testgen.RegisterTestPlugin(NewTest)
82 }
83
View as plain text