mirror of
https://github.com/TECHNOFAB11/zfs-localpv.git
synced 2025-12-11 22:10:11 +01:00
test(zfspv): minikube setup for travis
to run integration test cases Signed-off-by: Pawan <pawan@mayadata.io>
This commit is contained in:
parent
7ab6156b98
commit
d933b47c75
27 changed files with 4933 additions and 5 deletions
183
tests/pod/pod.go
Normal file
183
tests/pod/pod.go
Normal file
|
|
@ -0,0 +1,183 @@
|
|||
// Copyright 2019 The OpenEBS 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 pod
|
||||
|
||||
import (
|
||||
corev1 "k8s.io/api/core/v1"
|
||||
)
|
||||
|
||||
// Pod holds the api's pod objects
|
||||
type Pod struct {
|
||||
object *corev1.Pod
|
||||
}
|
||||
|
||||
// PodList holds the list of API pod instances
|
||||
type PodList struct {
|
||||
items []*Pod
|
||||
}
|
||||
|
||||
// PredicateList holds a list of predicate
|
||||
type predicateList []Predicate
|
||||
|
||||
// Predicate defines an abstraction
|
||||
// to determine conditional checks
|
||||
// against the provided pod instance
|
||||
type Predicate func(*Pod) bool
|
||||
|
||||
// ToAPIList converts PodList to API PodList
|
||||
func (pl *PodList) ToAPIList() *corev1.PodList {
|
||||
plist := &corev1.PodList{}
|
||||
for _, pod := range pl.items {
|
||||
plist.Items = append(plist.Items, *pod.object)
|
||||
}
|
||||
return plist
|
||||
}
|
||||
|
||||
type podBuildOption func(*Pod)
|
||||
|
||||
// NewForAPIObject returns a new instance of Pod
|
||||
func NewForAPIObject(obj *corev1.Pod, opts ...podBuildOption) *Pod {
|
||||
p := &Pod{object: obj}
|
||||
for _, o := range opts {
|
||||
o(p)
|
||||
}
|
||||
return p
|
||||
}
|
||||
|
||||
// Len returns the number of items present in the PodList
|
||||
func (pl *PodList) Len() int {
|
||||
return len(pl.items)
|
||||
}
|
||||
|
||||
// all returns true if all the predicates
|
||||
// succeed against the provided pod
|
||||
// instance
|
||||
func (l predicateList) all(p *Pod) bool {
|
||||
for _, pred := range l {
|
||||
if !pred(p) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
return true
|
||||
}
|
||||
|
||||
// IsRunning retuns true if the pod is in running
|
||||
// state
|
||||
func (p *Pod) IsRunning() bool {
|
||||
return p.object.Status.Phase == "Running"
|
||||
}
|
||||
|
||||
// IsRunning is a predicate to filter out pods
|
||||
// which in running state
|
||||
func IsRunning() Predicate {
|
||||
return func(p *Pod) bool {
|
||||
return p.IsRunning()
|
||||
}
|
||||
}
|
||||
|
||||
// IsCompleted retuns true if the pod is in completed
|
||||
// state
|
||||
func (p *Pod) IsCompleted() bool {
|
||||
return p.object.Status.Phase == "Succeeded"
|
||||
}
|
||||
|
||||
// IsCompleted is a predicate to filter out pods
|
||||
// which in completed state
|
||||
func IsCompleted() Predicate {
|
||||
return func(p *Pod) bool {
|
||||
return p.IsCompleted()
|
||||
}
|
||||
}
|
||||
|
||||
// HasLabels returns true if provided labels
|
||||
// map[key]value are present in the provided PodList
|
||||
// instance
|
||||
func HasLabels(keyValuePair map[string]string) Predicate {
|
||||
return func(p *Pod) bool {
|
||||
// objKeyValues := p.object.GetLabels()
|
||||
for key, value := range keyValuePair {
|
||||
if !p.HasLabel(key, value) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
return true
|
||||
}
|
||||
}
|
||||
|
||||
// HasLabel return true if provided lable
|
||||
// key and value are present in the the provided PodList
|
||||
// instance
|
||||
func (p *Pod) HasLabel(key, value string) bool {
|
||||
val, ok := p.object.GetLabels()[key]
|
||||
if ok {
|
||||
return val == value
|
||||
}
|
||||
return false
|
||||
}
|
||||
|
||||
// HasLabel is predicate to filter out labeled
|
||||
// pod instances
|
||||
func HasLabel(key, value string) Predicate {
|
||||
return func(p *Pod) bool {
|
||||
return p.HasLabel(key, value)
|
||||
}
|
||||
}
|
||||
|
||||
// IsNil returns true if the pod instance
|
||||
// is nil
|
||||
func (p *Pod) IsNil() bool {
|
||||
return p.object == nil
|
||||
}
|
||||
|
||||
// IsNil is predicate to filter out nil pod
|
||||
// instances
|
||||
func IsNil() Predicate {
|
||||
return func(p *Pod) bool {
|
||||
return p.IsNil()
|
||||
}
|
||||
}
|
||||
|
||||
// GetAPIObject returns a API's Pod
|
||||
func (p *Pod) GetAPIObject() *corev1.Pod {
|
||||
return p.object
|
||||
}
|
||||
|
||||
// FromList created a PodList with provided api podlist
|
||||
func FromList(pods *corev1.PodList) *PodList {
|
||||
pl := ListBuilderForAPIList(pods).
|
||||
List()
|
||||
return pl
|
||||
}
|
||||
|
||||
// GetScheduledNodes returns the nodes on which pods are scheduled
|
||||
func (pl *PodList) GetScheduledNodes() map[string]int {
|
||||
nodeNames := make(map[string]int)
|
||||
for _, p := range pl.items {
|
||||
p := p // pin it
|
||||
nodeNames[p.object.Spec.NodeName]++
|
||||
}
|
||||
return nodeNames
|
||||
}
|
||||
|
||||
// IsMatchNodeAny checks the PodList is running on the provided nodes
|
||||
func (pl *PodList) IsMatchNodeAny(nodes map[string]int) bool {
|
||||
for _, p := range pl.items {
|
||||
p := p // pin it
|
||||
if nodes[p.object.Spec.NodeName] == 0 {
|
||||
return false
|
||||
}
|
||||
}
|
||||
return true
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue