本文整理匯總了Golang中github.com/cockroachdb/cockroach/storage/engine.Key函數的典型用法代碼示例。如果您正苦於以下問題:Golang Key函數的具體用法?Golang Key怎麽用?Golang Key使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Key函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: TestCoordinatorGC
// TestCoordinatorGC verifies that the coordinator cleans up extant
// transactions after the lastUpdateTS exceeds the timeout.
func TestCoordinatorGC(t *testing.T) {
db, _, manual := createTestDB(t)
defer db.Close()
// Set heartbeat interval to 1ms for testing.
db.coordinator.heartbeatInterval = 1 * time.Millisecond
txnID := engine.Key("txn")
<-db.Put(createPutRequest(engine.Key("a"), []byte("value"), txnID))
// Now, advance clock past the default client timeout.
// Locking the coordinator to prevent a data race.
db.coordinator.Lock()
*manual = hlc.ManualClock(defaultClientTimeout.Nanoseconds() + 1)
db.coordinator.Unlock()
if err := util.IsTrueWithin(func() bool {
// Locking the coordinator to prevent a data race.
db.coordinator.Lock()
_, ok := db.coordinator.txns[string(txnID)]
db.coordinator.Unlock()
return !ok
}, 50*time.Millisecond); err != nil {
t.Error("expected garbage collection")
}
}
示例2: TestRangeGossipConfigUpdates
// TestRangeGossipConfigUpdates verifies that writes to the
// permissions cause the updated configs to be re-gossipped.
func TestRangeGossipConfigUpdates(t *testing.T) {
r, g := createTestRange(createTestEngine(t), t)
defer r.Stop()
// Add a permission for a new key prefix.
db1Perm := proto.PermConfig{
Read: []string{"spencer"},
Write: []string{"spencer"},
}
key := engine.MakeKey(engine.KeyConfigPermissionPrefix, engine.Key("/db1"))
reply := &proto.PutResponse{}
data, err := gogoproto.Marshal(&db1Perm)
if err != nil {
t.Fatal(err)
}
r.Put(&proto.PutRequest{RequestHeader: proto.RequestHeader{Key: key}, Value: proto.Value{Bytes: data}}, reply)
if reply.Error != nil {
t.Fatal(reply.GoError())
}
info, err := g.GetInfo(gossip.KeyConfigPermission)
if err != nil {
t.Fatal(err)
}
configMap := info.(PrefixConfigMap)
expConfigs := []*PrefixConfig{
&PrefixConfig{engine.KeyMin, nil, &testDefaultPermConfig},
&PrefixConfig{engine.Key("/db1"), nil, &db1Perm},
&PrefixConfig{engine.Key("/db2"), engine.KeyMin, &testDefaultPermConfig},
}
if !reflect.DeepEqual([]*PrefixConfig(configMap), expConfigs) {
t.Errorf("expected gossiped configs to be equal %s vs %s", configMap, expConfigs)
}
}
示例3: TestReadQueueMultipleReads
func TestReadQueueMultipleReads(t *testing.T) {
rq := NewReadQueue()
wg1 := sync.WaitGroup{}
wg2 := sync.WaitGroup{}
wg3 := sync.WaitGroup{}
// Add a write which will overlap all reads.
wk := rq.AddWrite(engine.Key("a"), engine.Key("d"))
rq.AddRead(engine.Key("a"), nil, &wg1)
rq.AddRead(engine.Key("b"), nil, &wg2)
rq.AddRead(engine.Key("c"), nil, &wg3)
rd1 := waitForReader(&wg1)
rd2 := waitForReader(&wg2)
rd3 := waitForReader(&wg3)
if testReadDone(rd1, 1*time.Millisecond) ||
testReadDone(rd2, 1*time.Millisecond) ||
testReadDone(rd3, 1*time.Millisecond) {
t.Fatal("no reads should finish with write outstanding")
}
rq.RemoveWrite(wk)
if !testReadDone(rd1, 5*time.Millisecond) ||
!testReadDone(rd2, 5*time.Millisecond) ||
!testReadDone(rd3, 5*time.Millisecond) {
t.Fatal("reads should finish with no writes outstanding")
}
}
示例4: TestGetFirstRangeDescriptor
func TestGetFirstRangeDescriptor(t *testing.T) {
n := gossip.NewSimulationNetwork(3, "unix", gossip.DefaultTestGossipInterval)
kv := NewDistKV(n.Nodes[0].Gossip)
if _, err := kv.getFirstRangeDescriptor(); err == nil {
t.Errorf("expected not to find first range descriptor")
}
expectedDesc := &proto.RangeDescriptor{}
expectedDesc.StartKey = engine.Key("a")
expectedDesc.EndKey = engine.Key("c")
// Add first RangeDescriptor to a node different from the node for this kv
// and ensure that this kv has the information within a given time.
n.Nodes[1].Gossip.AddInfo(
gossip.KeyFirstRangeMetadata, *expectedDesc, time.Hour)
maxCycles := 10
n.SimulateNetwork(func(cycle int, network *gossip.SimulationNetwork) bool {
desc, err := kv.getFirstRangeDescriptor()
if err != nil {
if cycle >= maxCycles {
t.Errorf("could not get range descriptor after %d cycles", cycle)
return false
}
return true
}
if !bytes.Equal(desc.StartKey, expectedDesc.StartKey) ||
!bytes.Equal(desc.EndKey, expectedDesc.EndKey) {
t.Errorf("expected first range descriptor %v, instead was %v",
expectedDesc, desc)
}
return false
})
n.Stop()
}
示例5: TestRangeGossipConfigWithMultipleKeyPrefixes
// TestRangeGossipConfigWithMultipleKeyPrefixes verifies that multiple
// key prefixes for a config are gossipped.
func TestRangeGossipConfigWithMultipleKeyPrefixes(t *testing.T) {
e := createTestEngine(t)
// Add a permission for a new key prefix.
db1Perm := proto.PermConfig{
Read: []string{"spencer", "foo", "bar", "baz"},
Write: []string{"spencer"},
}
key := engine.MakeKey(engine.KeyConfigPermissionPrefix, engine.Key("/db1"))
if err := engine.PutProto(e, key, &db1Perm); err != nil {
t.Fatal(err)
}
r, g := createTestRange(e, t)
defer r.Stop()
info, err := g.GetInfo(gossip.KeyConfigPermission)
if err != nil {
t.Fatal(err)
}
configMap := info.(PrefixConfigMap)
expConfigs := []*PrefixConfig{
&PrefixConfig{engine.KeyMin, nil, &testDefaultPermConfig},
&PrefixConfig{engine.Key("/db1"), nil, &db1Perm},
&PrefixConfig{engine.Key("/db2"), engine.KeyMin, &testDefaultPermConfig},
}
if !reflect.DeepEqual([]*PrefixConfig(configMap), expConfigs) {
t.Errorf("expected gossiped configs to be equal %s vs %s", configMap, expConfigs)
}
}
示例6: TestCoordinatorAddRequest
// TestCoordinatorAddRequest verifies adding a request creates a
// transaction metadata and adding multiple requests with same
// transaction ID updates the last update timestamp.
func TestCoordinatorAddRequest(t *testing.T) {
db, clock, manual := createTestDB(t)
defer db.Close()
txnID := engine.Key("txn")
putReq := createPutRequest(engine.Key("a"), []byte("value"), txnID)
// Put request will create a new transaction.
<-db.Put(putReq)
txnMeta, ok := db.coordinator.txns[string(txnID)]
if !ok {
t.Fatal("expected a transaction to be created on coordinator")
}
ts := txnMeta.lastUpdateTS
if !ts.Less(clock.Now()) {
t.Errorf("expected earlier last update timestamp; got: %+v", ts)
}
// Advance time and send another put request.
// Locking the coordinator to prevent a data race.
db.coordinator.Lock()
*manual = hlc.ManualClock(1)
db.coordinator.Unlock()
<-db.Put(putReq)
if len(db.coordinator.txns) != 1 {
t.Errorf("expected length of transactions map to be 1; got %d", len(db.coordinator.txns))
}
txnMeta = db.coordinator.txns[string(txnID)]
if !ts.Less(txnMeta.lastUpdateTS) || txnMeta.lastUpdateTS.WallTime != int64(*manual) {
t.Errorf("expected last update time to advance; got %+v", txnMeta.lastUpdateTS)
}
}
示例7: TestPrefixConfigSort
// TestPrefixConfigSort verifies sorting of keys.
func TestPrefixConfigSort(t *testing.T) {
keys := []engine.Key{
engine.KeyMax,
engine.Key("c"),
engine.Key("a"),
engine.Key("b"),
engine.Key("aa"),
engine.Key("\xfe"),
engine.KeyMin,
}
expKeys := []engine.Key{
engine.KeyMin,
engine.Key("a"),
engine.Key("aa"),
engine.Key("b"),
engine.Key("c"),
engine.Key("\xfe"),
engine.KeyMax,
}
pcc := PrefixConfigMap{}
for _, key := range keys {
pcc = append(pcc, &PrefixConfig{key, nil, nil})
}
sort.Sort(pcc)
for i, pc := range pcc {
if bytes.Compare(pc.Prefix, expKeys[i]) != 0 {
t.Errorf("order for index %d incorrect; expected %q, got %q", i, expKeys[i], pc.Prefix)
}
}
}
示例8: TestCoordinatorHeartbeat
// TestCoordinatorHeartbeat verifies periodic heartbeat of the
// transaction record.
func TestCoordinatorHeartbeat(t *testing.T) {
db, _, manual := createTestDB(t)
defer db.Close()
// Set heartbeat interval to 1ms for testing.
db.coordinator.heartbeatInterval = 1 * time.Millisecond
txnID := engine.Key("txn")
<-db.Put(createPutRequest(engine.Key("a"), []byte("value"), txnID))
// Verify 3 heartbeats.
var heartbeatTS proto.Timestamp
for i := 0; i < 3; i++ {
if err := util.IsTrueWithin(func() bool {
ok, txn, err := getTxn(db, engine.MakeKey(engine.KeyLocalTransactionPrefix, txnID))
if !ok || err != nil {
return false
}
// Advance clock by 1ns.
// Locking the coordinator to prevent a data race.
db.coordinator.Lock()
*manual = hlc.ManualClock(*manual + 1)
db.coordinator.Unlock()
if heartbeatTS.Less(*txn.LastHeartbeat) {
heartbeatTS = *txn.LastHeartbeat
return true
}
return false
}, 50*time.Millisecond); err != nil {
t.Error("expected initial heartbeat within 50ms")
}
}
}
示例9: doLookup
func doLookup(t *testing.T, rc *RangeMetadataCache, key string) {
r, err := rc.LookupRangeMetadata(engine.Key(key))
if err != nil {
t.Fatalf("Unexpected error from LookupRangeMetadata: %s", err.Error())
}
if !r.ContainsKey(engine.Key(key)) {
t.Fatalf("Returned range did not contain key: %s-%s, %s", r.StartKey, r.EndKey, key)
}
}
示例10: createTestStore
// createTestStore creates a test store using an in-memory
// engine. Returns the store clock's manual unix nanos time and the
// store. A single range from key "a" to key "z" is setup in the store
// with a default replica descriptor (i.e. StoreID = 0, RangeID = 1,
// etc.). The caller is responsible for closing the store on exit.
func createTestStore(t *testing.T) (*Store, *hlc.ManualClock) {
manual := hlc.ManualClock(0)
clock := hlc.NewClock(manual.UnixNano)
eng := engine.NewInMem(proto.Attributes{}, 1<<20)
store := NewStore(clock, eng, nil)
replica := proto.Replica{RangeID: 1}
_, err := store.CreateRange(engine.Key("a"), engine.Key("z"), []proto.Replica{replica})
if err != nil {
t.Fatal(err)
}
return store, &manual
}
示例11: ExampleLsZones
// ExampleLsZones creates a series of zone configs and verifies
// zone-ls works. First, no regexp lists all zone configs. Second,
// regexp properly matches results.
func ExampleLsZones() {
httpServer := startAdminServer()
defer httpServer.Close()
testConfigFn := createTestConfigFile()
defer os.Remove(testConfigFn)
keys := []engine.Key{
engine.KeyMin,
engine.Key("db1"),
engine.Key("db2"),
engine.Key("db3"),
engine.Key("user"),
}
regexps := []string{
"",
"db*",
"db[12]",
}
for _, key := range keys {
prefix := url.QueryEscape(string(key))
runSetZone(CmdSetZone, []string{prefix, testConfigFn})
}
for i, regexp := range regexps {
fmt.Fprintf(os.Stdout, "test case %d: %q\n", i, regexp)
if regexp == "" {
runLsZones(CmdLsZones, []string{})
} else {
runLsZones(CmdLsZones, []string{regexp})
}
}
// Output:
// set zone config for key prefix ""
// set zone config for key prefix "db1"
// set zone config for key prefix "db2"
// set zone config for key prefix "db3"
// set zone config for key prefix "user"
// test case 0: ""
// [default]
// db1
// db2
// db3
// user
// test case 1: "db*"
// db1
// db2
// db3
// test case 2: "db[12]"
// db1
// db2
}
示例12: TestCoordinatorMultipleTxns
// TestCoordinatorMultipleTxns verifies correct operation with
// multiple outstanding transactions.
func TestCoordinatorMultipleTxns(t *testing.T) {
db, _, _ := createTestDB(t)
defer db.Close()
txn1ID := engine.Key("txn1")
txn2ID := engine.Key("txn2")
<-db.Put(createPutRequest(engine.Key("a"), []byte("value"), txn1ID))
<-db.Put(createPutRequest(engine.Key("b"), []byte("value"), txn2ID))
if len(db.coordinator.txns) != 2 {
t.Errorf("expected length of transactions map to be 2; got %d", len(db.coordinator.txns))
}
}
示例13: buildTestPrefixConfigMap
func buildTestPrefixConfigMap() PrefixConfigMap {
configs := []*PrefixConfig{
{engine.KeyMin, nil, config1},
{engine.Key("/db1"), nil, config2},
{engine.Key("/db1/table"), nil, config3},
{engine.Key("/db3"), nil, config4},
}
pcc, err := NewPrefixConfigMap(configs)
if err != nil {
log.Fatalf("unexpected error building config map: %v", err)
}
return pcc
}
示例14: TestRangeCache
// TestRangeCache is a simple test which verifies that metadata ranges
// are being cached and retrieved properly. It sets up a fake backing
// store for the cache, and measures how often that backing store is
// accessed when looking up metadata keys through the cache.
func TestRangeCache(t *testing.T) {
db := newTestMetadataDB()
for i, char := range "abcdefghijklmnopqrstuvwx" {
db.splitRange(t, engine.Key(string(char)))
if i > 0 && i%6 == 0 {
db.splitRange(t, engine.RangeMetaKey(engine.Key(string(char))))
}
}
rangeCache := NewRangeMetadataCache(db)
db.cache = rangeCache
doLookup(t, rangeCache, "aa")
db.assertHitCount(t, 2)
// Metadata for the following ranges should be cached
doLookup(t, rangeCache, "ab")
db.assertHitCount(t, 0)
doLookup(t, rangeCache, "ba")
db.assertHitCount(t, 0)
doLookup(t, rangeCache, "cz")
db.assertHitCount(t, 0)
// Metadata two ranges weren't cached, same metadata 1 range
doLookup(t, rangeCache, "d")
db.assertHitCount(t, 1)
doLookup(t, rangeCache, "fa")
db.assertHitCount(t, 0)
// Metadata two ranges weren't cached, metadata 1 was aggressively cached
doLookup(t, rangeCache, "ij")
db.assertHitCount(t, 1)
doLookup(t, rangeCache, "jk")
db.assertHitCount(t, 0)
doLookup(t, rangeCache, "pn")
db.assertHitCount(t, 1)
// Totally uncached ranges
doLookup(t, rangeCache, "vu")
db.assertHitCount(t, 2)
doLookup(t, rangeCache, "xx")
db.assertHitCount(t, 0)
// Evict clears one level 1 and one level 2 cache
rangeCache.EvictCachedRangeMetadata(engine.Key("da"))
doLookup(t, rangeCache, "fa")
db.assertHitCount(t, 0)
doLookup(t, rangeCache, "da")
db.assertHitCount(t, 2)
}
示例15: TestCoordinatorEndTxn
// TestCoordinatorEndTxn verifies that ending a transaction
// sends resolve write intent requests and removes the transaction
// from the txns map.
func TestCoordinatorEndTxn(t *testing.T) {
db, _, _ := createTestDB(t)
defer db.Close()
txnID := engine.Key("txn")
<-db.Put(createPutRequest(engine.Key("a"), []byte("value"), txnID))
db.coordinator.EndTxn(txnID, true)
if len(db.coordinator.txns) != 0 {
t.Errorf("expected empty transactions map; got %d", len(db.coordinator.txns))
}
// TODO(spencer): need to test that write intents were sent to key "a".
}