2014-08-11 07:34:59 +00:00
|
|
|
/*
|
|
|
|
Copyright 2014 Google Inc. All rights reserved.
|
|
|
|
|
|
|
|
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 registrytest
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/api"
|
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/labels"
|
2014-08-11 19:58:19 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/watch"
|
2014-08-11 07:34:59 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type PodRegistry struct {
|
2014-08-14 21:14:31 +00:00
|
|
|
Err error
|
|
|
|
Machine string
|
|
|
|
Pod *api.Pod
|
|
|
|
Pods []api.Pod
|
2014-08-11 07:34:59 +00:00
|
|
|
sync.Mutex
|
2014-08-14 21:14:31 +00:00
|
|
|
|
|
|
|
mux *watch.Mux
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewPodRegistry(pods []api.Pod) *PodRegistry {
|
|
|
|
return &PodRegistry{
|
|
|
|
Pods: pods,
|
2014-08-14 21:14:31 +00:00
|
|
|
mux: watch.NewMux(0),
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *PodRegistry) ListPods(selector labels.Selector) ([]api.Pod, error) {
|
|
|
|
r.Lock()
|
|
|
|
defer r.Unlock()
|
|
|
|
if r.Err != nil {
|
|
|
|
return r.Pods, r.Err
|
|
|
|
}
|
|
|
|
var filtered []api.Pod
|
|
|
|
for _, pod := range r.Pods {
|
|
|
|
if selector.Matches(labels.Set(pod.Labels)) {
|
|
|
|
filtered = append(filtered, pod)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return filtered, nil
|
|
|
|
}
|
|
|
|
|
2014-08-14 21:14:31 +00:00
|
|
|
func (r *PodRegistry) WatchPods(resourceVersion uint64) (watch.Interface, error) {
|
|
|
|
return r.mux.Watch(), nil
|
2014-08-11 19:58:19 +00:00
|
|
|
}
|
|
|
|
|
2014-08-11 07:34:59 +00:00
|
|
|
func (r *PodRegistry) GetPod(podId string) (*api.Pod, error) {
|
|
|
|
r.Lock()
|
|
|
|
defer r.Unlock()
|
|
|
|
return r.Pod, r.Err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *PodRegistry) CreatePod(machine string, pod api.Pod) error {
|
|
|
|
r.Lock()
|
|
|
|
defer r.Unlock()
|
2014-08-14 21:14:31 +00:00
|
|
|
r.Machine = machine
|
|
|
|
r.Pod = &pod
|
|
|
|
r.mux.Action(watch.Added, &pod)
|
2014-08-11 07:34:59 +00:00
|
|
|
return r.Err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *PodRegistry) UpdatePod(pod api.Pod) error {
|
|
|
|
r.Lock()
|
|
|
|
defer r.Unlock()
|
|
|
|
r.Pod = &pod
|
2014-08-14 21:14:31 +00:00
|
|
|
r.mux.Action(watch.Modified, &pod)
|
2014-08-11 07:34:59 +00:00
|
|
|
return r.Err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (r *PodRegistry) DeletePod(podId string) error {
|
|
|
|
r.Lock()
|
|
|
|
defer r.Unlock()
|
2014-08-14 21:14:31 +00:00
|
|
|
r.mux.Action(watch.Deleted, r.Pod)
|
2014-08-11 07:34:59 +00:00
|
|
|
return r.Err
|
|
|
|
}
|