Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add event logger type and function to set event context for writer #5937

Merged
merged 2 commits into from
Jun 4, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
29 changes: 29 additions & 0 deletions pkg/skaffold/event/v2/config.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
/*
Copyright 2021 The Skaffold Authors

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 v2

import (
latestV1 "github.com/GoogleContainerTools/skaffold/pkg/skaffold/schema/latest/v1"
)

type Config interface {
GetKubeContext() string
AutoBuild() bool
AutoDeploy() bool
AutoSync() bool
GetPipelines() []latestV1.Pipeline
}
9 changes: 4 additions & 5 deletions pkg/skaffold/event/v2/event.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,6 @@ import (

"github.com/GoogleContainerTools/skaffold/pkg/skaffold/constants"
sErrors "github.com/GoogleContainerTools/skaffold/pkg/skaffold/errors"
"github.com/GoogleContainerTools/skaffold/pkg/skaffold/event"
proto "github.com/GoogleContainerTools/skaffold/proto/v2"
)

Expand Down Expand Up @@ -69,7 +68,7 @@ type eventHandler struct {
logLock sync.Mutex
applicationLogs []proto.Event
applicationLogsLock sync.Mutex
cfg event.Config
cfg Config

iteration int
state proto.State
Expand Down Expand Up @@ -179,7 +178,7 @@ func (ev *eventHandler) forEachApplicationLog(callback func(*proto.Event) error)
return ev.forEach(&ev.applicationLogListeners, &ev.applicationLogs, &ev.applicationLogsLock, callback)
}

func emptyState(cfg event.Config) proto.State {
func emptyState(cfg Config) proto.State {
builds := map[string]string{}
for _, p := range cfg.GetPipelines() {
for _, a := range p.Build.Artifacts {
Expand Down Expand Up @@ -272,7 +271,7 @@ func emptyStatusCheckState() *proto.StatusCheckState {
}

// InitializeState instantiates the global state of the skaffold runner, as well as the event log.
func InitializeState(cfg event.Config) {
func InitializeState(cfg Config) {
handler.cfg = cfg
handler.setState(emptyState(cfg))
}
Expand All @@ -286,7 +285,7 @@ func AutoTriggerDiff(phase constants.Phase, val bool) (bool, error) {
case constants.Deploy:
return val != handler.getState().DeployState.AutoTrigger, nil
default:
return false, fmt.Errorf("unknown phase %v not found in handler state", phase)
return false, fmt.Errorf("unknown Phase %v not found in handler state", phase)
}
}

Expand Down
59 changes: 59 additions & 0 deletions pkg/skaffold/event/v2/logger.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
/*
Copyright 2021 The Skaffold Authors

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 v2

import (
"fmt"
"io"

"github.com/GoogleContainerTools/skaffold/pkg/skaffold/constants"
proto "github.com/GoogleContainerTools/skaffold/proto/v2"
)

type logger struct {
Phase constants.Phase
SubtaskID string
Origin string
}

func NewLogger(phase constants.Phase, subtaskID, origin string) io.Writer {
return logger{
Phase: phase,
SubtaskID: subtaskID,
Origin: origin,
}
}

func (l logger) Write(p []byte) (int, error) {
handler.handleSkaffoldLogEvent(&proto.SkaffoldLogEvent{
TaskId: fmt.Sprintf("%s-%d", l.Phase, handler.iteration),
SubtaskId: l.SubtaskID,
Origin: l.Origin,
Level: 0,
Message: string(p),
})

return len(p), nil
}

func (ev *eventHandler) handleSkaffoldLogEvent(e *proto.SkaffoldLogEvent) {
ev.handle(&proto.Event{
EventType: &proto.Event_SkaffoldLogEvent{
SkaffoldLogEvent: e,
},
})
}
54 changes: 54 additions & 0 deletions pkg/skaffold/event/v2/logger_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
/*
Copyright 2021 The Skaffold Authors

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 v2

import (
"testing"

latestV1 "github.com/GoogleContainerTools/skaffold/pkg/skaffold/schema/latest/v1"
"github.com/GoogleContainerTools/skaffold/proto/enums"
proto "github.com/GoogleContainerTools/skaffold/proto/v2"
)

func TestHandleSkaffoldLogEvent(t *testing.T) {
testHandler := newHandler()
testHandler.state = emptyState(mockCfg([]latestV1.Pipeline{{}}, "test"))

messages := []string{
"hi!",
"how's it going",
"hope you're well",
"this is a skaffold test",
}

// ensure that messages sent through the SkaffoldLog function are populating the event log
for _, message := range messages {
testHandler.handleSkaffoldLogEvent(&proto.SkaffoldLogEvent{
TaskId: "Test-0",
SubtaskId: "1",
Origin: "skaffold-test",
Level: enums.LogLevel_INFO,
Message: message,
})
}
wait(t, func() bool {
testHandler.logLock.Lock()
logLen := len(testHandler.eventLog)
testHandler.logLock.Unlock()
return logLen == len(messages)
})
}
16 changes: 16 additions & 0 deletions pkg/skaffold/output/output.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,9 @@ import (
"io"
"io/ioutil"
"os"

"github.com/GoogleContainerTools/skaffold/pkg/skaffold/constants"
eventV2 "github.com/GoogleContainerTools/skaffold/pkg/skaffold/event/v2"
)

type skaffoldWriter struct {
Expand Down Expand Up @@ -77,3 +80,16 @@ func GetUnderlyingWriter(out io.Writer) io.Writer {
}
return out
}

// WithEventContext will return a new skaffoldWriter with the given parameters to be used for the event writer.
// If the passed io.Writer is not a skaffoldWriter, then it is simply returned.
func WithEventContext(out io.Writer, phase constants.Phase, subtaskID, origin string) io.Writer {
if sw, isSW := out.(skaffoldWriter); isSW {
return skaffoldWriter{
MainWriter: sw.MainWriter,
EventWriter: eventV2.NewLogger(phase, subtaskID, origin),
}
}

return out
}
41 changes: 41 additions & 0 deletions pkg/skaffold/output/output_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,8 @@ import (
"os"
"testing"

"github.com/GoogleContainerTools/skaffold/pkg/skaffold/constants"
eventV2 "github.com/GoogleContainerTools/skaffold/pkg/skaffold/event/v2"
"github.com/GoogleContainerTools/skaffold/testutil"
)

Expand Down Expand Up @@ -116,3 +118,42 @@ func TestGetUnderlyingWriter(t *testing.T) {
})
}
}

func TestWithEventContext(t *testing.T) {
tests := []struct {
name string
writer io.Writer
phase constants.Phase
subtaskID string
origin string

expected io.Writer
}{
{
name: "skaffoldWriter update info",
writer: skaffoldWriter{
MainWriter: ioutil.Discard,
EventWriter: eventV2.NewLogger(constants.Build, "1", "skaffold-test"),
},
phase: constants.Test,
subtaskID: "2",
origin: "skaffold-test-change",
expected: skaffoldWriter{
MainWriter: ioutil.Discard,
EventWriter: eventV2.NewLogger(constants.Test, "2", "skaffold-test-change"),
},
},
{
name: "non skaffoldWriter returns same",
writer: ioutil.Discard,
expected: ioutil.Discard,
},
}

for _, test := range tests {
testutil.Run(t, test.name, func(t *testutil.T) {
got := WithEventContext(test.writer, test.phase, test.subtaskID, test.origin)
t.CheckDeepEqual(test.expected, got)
})
}
}