mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			157 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2014 The Kubernetes 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 cache
 | 
						|
 | 
						|
import (
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"k8s.io/kubernetes/pkg/util/sets"
 | 
						|
)
 | 
						|
 | 
						|
// Test public interface
 | 
						|
func doTestStore(t *testing.T, store Store) {
 | 
						|
	mkObj := func(id string, val string) testStoreObject {
 | 
						|
		return testStoreObject{id: id, val: val}
 | 
						|
	}
 | 
						|
 | 
						|
	store.Add(mkObj("foo", "bar"))
 | 
						|
	if item, ok, _ := store.Get(mkObj("foo", "")); !ok {
 | 
						|
		t.Errorf("didn't find inserted item")
 | 
						|
	} else {
 | 
						|
		if e, a := "bar", item.(testStoreObject).val; e != a {
 | 
						|
			t.Errorf("expected %v, got %v", e, a)
 | 
						|
		}
 | 
						|
	}
 | 
						|
	store.Update(mkObj("foo", "baz"))
 | 
						|
	if item, ok, _ := store.Get(mkObj("foo", "")); !ok {
 | 
						|
		t.Errorf("didn't find inserted item")
 | 
						|
	} else {
 | 
						|
		if e, a := "baz", item.(testStoreObject).val; e != a {
 | 
						|
			t.Errorf("expected %v, got %v", e, a)
 | 
						|
		}
 | 
						|
	}
 | 
						|
	store.Delete(mkObj("foo", ""))
 | 
						|
	if _, ok, _ := store.Get(mkObj("foo", "")); ok {
 | 
						|
		t.Errorf("found deleted item??")
 | 
						|
	}
 | 
						|
 | 
						|
	// Test List.
 | 
						|
	store.Add(mkObj("a", "b"))
 | 
						|
	store.Add(mkObj("c", "d"))
 | 
						|
	store.Add(mkObj("e", "e"))
 | 
						|
	{
 | 
						|
		found := sets.String{}
 | 
						|
		for _, item := range store.List() {
 | 
						|
			found.Insert(item.(testStoreObject).val)
 | 
						|
		}
 | 
						|
		if !found.HasAll("b", "d", "e") {
 | 
						|
			t.Errorf("missing items, found: %v", found)
 | 
						|
		}
 | 
						|
		if len(found) != 3 {
 | 
						|
			t.Errorf("extra items")
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	// Test Replace.
 | 
						|
	store.Replace([]interface{}{
 | 
						|
		mkObj("foo", "foo"),
 | 
						|
		mkObj("bar", "bar"),
 | 
						|
	}, "0")
 | 
						|
 | 
						|
	{
 | 
						|
		found := sets.String{}
 | 
						|
		for _, item := range store.List() {
 | 
						|
			found.Insert(item.(testStoreObject).val)
 | 
						|
		}
 | 
						|
		if !found.HasAll("foo", "bar") {
 | 
						|
			t.Errorf("missing items")
 | 
						|
		}
 | 
						|
		if len(found) != 2 {
 | 
						|
			t.Errorf("extra items")
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Test public interface
 | 
						|
func doTestIndex(t *testing.T, indexer Indexer) {
 | 
						|
	mkObj := func(id string, val string) testStoreObject {
 | 
						|
		return testStoreObject{id: id, val: val}
 | 
						|
	}
 | 
						|
 | 
						|
	// Test Index
 | 
						|
	expected := map[string]sets.String{}
 | 
						|
	expected["b"] = sets.NewString("a", "c")
 | 
						|
	expected["f"] = sets.NewString("e")
 | 
						|
	expected["h"] = sets.NewString("g")
 | 
						|
	indexer.Add(mkObj("a", "b"))
 | 
						|
	indexer.Add(mkObj("c", "b"))
 | 
						|
	indexer.Add(mkObj("e", "f"))
 | 
						|
	indexer.Add(mkObj("g", "h"))
 | 
						|
	{
 | 
						|
		for k, v := range expected {
 | 
						|
			found := sets.String{}
 | 
						|
			indexResults, err := indexer.Index("by_val", mkObj("", k))
 | 
						|
			if err != nil {
 | 
						|
				t.Errorf("Unexpected error %v", err)
 | 
						|
			}
 | 
						|
			for _, item := range indexResults {
 | 
						|
				found.Insert(item.(testStoreObject).id)
 | 
						|
			}
 | 
						|
			items := v.List()
 | 
						|
			if !found.HasAll(items...) {
 | 
						|
				t.Errorf("missing items, index %s, expected %v but found %v", k, items, found.List())
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func testStoreKeyFunc(obj interface{}) (string, error) {
 | 
						|
	return obj.(testStoreObject).id, nil
 | 
						|
}
 | 
						|
 | 
						|
func testStoreIndexFunc(obj interface{}) ([]string, error) {
 | 
						|
	return []string{obj.(testStoreObject).val}, nil
 | 
						|
}
 | 
						|
 | 
						|
func testStoreIndexers() Indexers {
 | 
						|
	indexers := Indexers{}
 | 
						|
	indexers["by_val"] = testStoreIndexFunc
 | 
						|
	return indexers
 | 
						|
}
 | 
						|
 | 
						|
type testStoreObject struct {
 | 
						|
	id  string
 | 
						|
	val string
 | 
						|
}
 | 
						|
 | 
						|
func TestCache(t *testing.T) {
 | 
						|
	doTestStore(t, NewStore(testStoreKeyFunc))
 | 
						|
}
 | 
						|
 | 
						|
func TestFIFOCache(t *testing.T) {
 | 
						|
	doTestStore(t, NewFIFO(testStoreKeyFunc))
 | 
						|
}
 | 
						|
 | 
						|
func TestUndeltaStore(t *testing.T) {
 | 
						|
	nop := func([]interface{}) {}
 | 
						|
	doTestStore(t, NewUndeltaStore(nop, testStoreKeyFunc))
 | 
						|
}
 | 
						|
 | 
						|
func TestIndex(t *testing.T) {
 | 
						|
	doTestIndex(t, NewIndexer(testStoreKeyFunc, testStoreIndexers()))
 | 
						|
}
 |