1
0
mirror of https://github.com/woodpecker-ci/woodpecker.git synced 2025-01-17 17:45:03 +02:00
woodpecker/cmd/agent/core/health_test.go

52 lines
1.5 KiB
Go
Raw Normal View History

2018-02-19 14:24:10 -08:00
// Copyright 2018 Drone.IO Inc.
2018-03-21 14:02:17 +01:00
//
2018-02-19 14:24:10 -08:00
// 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
2018-03-21 14:02:17 +01:00
//
2018-02-19 14:24:10 -08:00
// http://www.apache.org/licenses/LICENSE-2.0
2018-03-21 14:02:17 +01:00
//
2018-02-19 14:24:10 -08:00
// 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 core
2017-09-12 13:40:24 -07:00
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
"go.woodpecker-ci.org/woodpecker/v2/agent"
2017-09-12 13:40:24 -07:00
)
func TestHealthy(t *testing.T) {
s := agent.State{}
s.Metadata = map[string]agent.Info{}
2017-09-12 13:40:24 -07:00
s.Add("1", time.Hour, "octocat/hello-world", "42")
assert.Equal(t, "1", s.Metadata["1"].ID)
assert.Equal(t, time.Hour, s.Metadata["1"].Timeout)
assert.Equal(t, "octocat/hello-world", s.Metadata["1"].Repo)
2017-09-12 13:40:24 -07:00
s.Metadata["1"] = agent.Info{
2017-09-12 13:40:24 -07:00
Timeout: time.Hour,
Started: time.Now().UTC(),
}
assert.True(t, s.Healthy(), "want healthy status when timeout not exceeded, got false")
2017-09-12 13:40:24 -07:00
s.Metadata["1"] = agent.Info{
2017-09-12 13:40:24 -07:00
Started: time.Now().UTC().Add(-(time.Minute * 30)),
}
assert.True(t, s.Healthy(), "want healthy status when timeout+buffer not exceeded, got false")
2017-09-12 13:40:24 -07:00
s.Metadata["1"] = agent.Info{
2017-09-12 13:40:24 -07:00
Started: time.Now().UTC().Add(-(time.Hour + time.Minute)),
}
assert.False(t, s.Healthy(), "want unhealthy status when timeout+buffer not exceeded, got true")
2017-09-12 13:40:24 -07:00
}