-
Notifications
You must be signed in to change notification settings - Fork 60
/
Copy pathcontext_test.go
91 lines (75 loc) · 2.6 KB
/
context_test.go
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// Copyright 2018 Palantir Technologies, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package githubapp
import (
"bytes"
"context"
"encoding/json"
"testing"
"github.com/google/go-github/v71/github"
"github.com/rs/zerolog"
)
func TestPrepareRepoContext(t *testing.T) {
var out bytes.Buffer
logger := zerolog.New(&out)
ctx := logger.WithContext(context.Background())
_, logger = PrepareRepoContext(ctx, 42, &github.Repository{
Name: github.String("test"),
Owner: &github.User{
Login: github.String("mhaypenny"),
},
})
logger.Info().Msg("")
var entry struct {
ID int64 `json:"github_installation_id"`
Owner string `json:"github_repository_owner"`
Name string `json:"github_repository_name"`
}
if err := json.Unmarshal(out.Bytes(), &entry); err != nil {
t.Fatalf("invalid log entry: %s: %v", out.String(), err)
}
assertField(t, "installation ID", int64(42), entry.ID)
assertField(t, "repository owner", "mhaypenny", entry.Owner)
assertField(t, "repository name", "test", entry.Name)
}
func TestPreparePRContext(t *testing.T) {
var out bytes.Buffer
logger := zerolog.New(&out)
ctx := logger.WithContext(context.Background())
_, logger = PreparePRContext(ctx, 42, &github.Repository{
Name: github.String("test"),
Owner: &github.User{
Login: github.String("mhaypenny"),
},
}, 128)
logger.Info().Msg("")
var entry struct {
ID int64 `json:"github_installation_id"`
Owner string `json:"github_repository_owner"`
Name string `json:"github_repository_name"`
Number int `json:"github_pr_num"`
}
if err := json.Unmarshal(out.Bytes(), &entry); err != nil {
t.Fatalf("invalid log entry: %s: %v", out.String(), err)
}
assertField(t, "installation ID", int64(42), entry.ID)
assertField(t, "repository owner", "mhaypenny", entry.Owner)
assertField(t, "repository name", "test", entry.Name)
assertField(t, "pull request number", 128, entry.Number)
}
func assertField(t *testing.T, name string, expected, actual interface{}) {
if expected != actual {
t.Errorf("incorrect %s: expected %#v (%T), but was %#v (%T)", name, expected, expected, actual, actual)
}
}