How to use Has method of got Package

Best Got code snippet using got.Has

immutable_test.go

Source:immutable_test.go Github

copy

Full Screen

...19 )20 }21 // Ensure there are no errors with requesting keys from an empty treap.22 key := serializeUint32(0)23 if gotVal := testTreap.Has(key); gotVal {24 t.Fatalf("Has: unexpected result - got %v, want false", gotVal)25 }26 if gotVal := testTreap.Get(key); gotVal != nil {27 t.Fatalf("Get: unexpected result - got %x, want nil", gotVal)28 }29 // Ensure there are no panics when deleting keys from an empty treap.30 testTreap.Delete(key)31 // Ensure the number of keys iterated by ForEach on an empty treap is32 // zero.33 var numIterated int34 testTreap.ForEach(func(k, v []byte) bool {35 numIterated++36 return true37 },38 )39 if numIterated != 0 {40 t.Fatalf("ForEach: unexpected iterate count - got %d, want 0",41 numIterated,42 )43 }44}45// TestImmutableSequential ensures that putting keys into an immutable treap in sequential order works as expected.46func TestImmutableSequential(t *testing.T) {47 t.Parallel()48 // Insert a bunch of sequential keys while checking several of the treap functions work as expected.49 expectedSize := uint64(0)50 numItems := 100051 testTreap := NewImmutable()52 for i := 0; i < numItems; i++ {53 key := serializeUint32(uint32(i))54 testTreap = testTreap.Put(key, key)55 // Ensure the treap length is the expected value.56 if gotLen := testTreap.Len(); gotLen != i+1 {57 t.Fatalf("Len #%d: unexpected length - got %d, want %d",58 i, gotLen, i+1,59 )60 }61 // Ensure the treap has the key.62 if !testTreap.Has(key) {63 t.Fatalf("Has #%d: key %q is not in treap", i, key)64 }65 // Get the key from the treap and ensure it is the expected value.66 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, key) {67 t.Fatalf("Get #%d: unexpected value - got %x, want %x",68 i, gotVal, key,69 )70 }71 // Ensure the expected size is reported.72 expectedSize += nodeFieldsSize + 873 if gotSize := testTreap.Size(); gotSize != expectedSize {74 t.Fatalf("Size #%d: unexpected byte size - got %d, "+75 "want %d", i, gotSize, expectedSize,76 )77 }78 }79 // Ensure the all keys are iterated by ForEach in order.80 var numIterated int81 testTreap.ForEach(func(k, v []byte) bool {82 wantKey := serializeUint32(uint32(numIterated))83 // Ensure the key is as expected.84 if !bytes.Equal(k, wantKey) {85 t.Fatalf("ForEach #%d: unexpected key - got %x, want %x",86 numIterated, k, wantKey,87 )88 }89 // Ensure the value is as expected.90 if !bytes.Equal(v, wantKey) {91 t.Fatalf("ForEach #%d: unexpected value - got %x, want %x",92 numIterated, v, wantKey,93 )94 }95 numIterated++96 return true97 },98 )99 // Ensure all items were iterated.100 if numIterated != numItems {101 t.Fatalf("ForEach: unexpected iterate count - got %d, want %d",102 numIterated, numItems,103 )104 }105 // Delete the keys one-by-one while checking several of the treap functions work as expected.106 for i := 0; i < numItems; i++ {107 key := serializeUint32(uint32(i))108 testTreap = testTreap.Delete(key)109 // Ensure the treap length is the expected value.110 if gotLen := testTreap.Len(); gotLen != numItems-i-1 {111 t.Fatalf("Len #%d: unexpected length - got %d, want %d",112 i, gotLen, numItems-i-1,113 )114 }115 // Ensure the treap no longer has the key.116 if testTreap.Has(key) {117 t.Fatalf("Has #%d: key %q is in treap", i, key)118 }119 // Get the key that no longer exists from the treap and ensure it is nil.120 if gotVal := testTreap.Get(key); gotVal != nil {121 t.Fatalf("Get #%d: unexpected value - got %x, want nil",122 i, gotVal,123 )124 }125 // Ensure the expected size is reported.126 expectedSize -= nodeFieldsSize + 8127 if gotSize := testTreap.Size(); gotSize != expectedSize {128 t.Fatalf("Size #%d: unexpected byte size - got %d, "+129 "want %d", i, gotSize, expectedSize,130 )131 }132 }133}134// TestImmutableReverseSequential ensures that putting keys into an immutable treap in reverse sequential order works as135// expected.136func TestImmutableReverseSequential(t *testing.T) {137 t.Parallel()138 // Insert a bunch of sequential keys while checking several of the treap functions work as expected.139 expectedSize := uint64(0)140 numItems := 1000141 testTreap := NewImmutable()142 for i := 0; i < numItems; i++ {143 key := serializeUint32(uint32(numItems - i - 1))144 testTreap = testTreap.Put(key, key)145 // Ensure the treap length is the expected value.146 if gotLen := testTreap.Len(); gotLen != i+1 {147 t.Fatalf("Len #%d: unexpected length - got %d, want %d",148 i, gotLen, i+1,149 )150 }151 // Ensure the treap has the key.152 if !testTreap.Has(key) {153 t.Fatalf("Has #%d: key %q is not in treap", i, key)154 }155 // Get the key from the treap and ensure it is the expected156 // value.157 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, key) {158 t.Fatalf("Get #%d: unexpected value - got %x, want %x",159 i, gotVal, key,160 )161 }162 // Ensure the expected size is reported.163 expectedSize += nodeFieldsSize + 8164 if gotSize := testTreap.Size(); gotSize != expectedSize {165 t.Fatalf("Size #%d: unexpected byte size - got %d, "+166 "want %d", i, gotSize, expectedSize,167 )168 }169 }170 // Ensure the all keys are iterated by ForEach in order.171 var numIterated int172 testTreap.ForEach(func(k, v []byte) bool {173 wantKey := serializeUint32(uint32(numIterated))174 // Ensure the key is as expected.175 if !bytes.Equal(k, wantKey) {176 t.Fatalf("ForEach #%d: unexpected key - got %x, want %x",177 numIterated, k, wantKey,178 )179 }180 // Ensure the value is as expected.181 if !bytes.Equal(v, wantKey) {182 t.Fatalf("ForEach #%d: unexpected value - got %x, want %x",183 numIterated, v, wantKey,184 )185 }186 numIterated++187 return true188 },189 )190 // Ensure all items were iterated.191 if numIterated != numItems {192 t.Fatalf("ForEach: unexpected iterate count - got %d, want %d",193 numIterated, numItems,194 )195 }196 // Delete the keys one-by-one while checking several of the treap functions work as expected.197 for i := 0; i < numItems; i++ {198 // Intentionally use the reverse order they were inserted here.199 key := serializeUint32(uint32(i))200 testTreap = testTreap.Delete(key)201 // Ensure the treap length is the expected value.202 if gotLen := testTreap.Len(); gotLen != numItems-i-1 {203 t.Fatalf("Len #%d: unexpected length - got %d, want %d",204 i, gotLen, numItems-i-1,205 )206 }207 // Ensure the treap no longer has the key.208 if testTreap.Has(key) {209 t.Fatalf("Has #%d: key %q is in treap", i, key)210 }211 // Get the key that no longer exists from the treap and ensure212 // it is nil.213 if gotVal := testTreap.Get(key); gotVal != nil {214 t.Fatalf("Get #%d: unexpected value - got %x, want nil",215 i, gotVal,216 )217 }218 // Ensure the expected size is reported.219 expectedSize -= nodeFieldsSize + 8220 if gotSize := testTreap.Size(); gotSize != expectedSize {221 t.Fatalf("Size #%d: unexpected byte size - got %d, "+222 "want %d", i, gotSize, expectedSize,223 )224 }225 }226}227// TestImmutableUnordered ensures that putting keys into an immutable treap in no particular order works as expected.228func TestImmutableUnordered(t *testing.T) {229 t.Parallel()230 // Insert a bunch of out-of-order keys while checking several of the treap functions work as expected.231 expectedSize := uint64(0)232 numItems := 1000233 testTreap := NewImmutable()234 for i := 0; i < numItems; i++ {235 // Hash the serialized int to generate out-of-order keys.236 hash := sha256.Sum256(serializeUint32(uint32(i)))237 key := hash[:]238 testTreap = testTreap.Put(key, key)239 // Ensure the treap length is the expected value.240 if gotLen := testTreap.Len(); gotLen != i+1 {241 t.Fatalf("Len #%d: unexpected length - got %d, want %d",242 i, gotLen, i+1,243 )244 }245 // Ensure the treap has the key.246 if !testTreap.Has(key) {247 t.Fatalf("Has #%d: key %q is not in treap", i, key)248 }249 // Get the key from the treap and ensure it is the expected value.250 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, key) {251 t.Fatalf("Get #%d: unexpected value - got %x, want %x",252 i, gotVal, key,253 )254 }255 // Ensure the expected size is reported.256 expectedSize += nodeFieldsSize + uint64(len(key)+len(key))257 if gotSize := testTreap.Size(); gotSize != expectedSize {258 t.Fatalf("Size #%d: unexpected byte size - got %d, "+259 "want %d", i, gotSize, expectedSize,260 )261 }262 }263 // Delete the keys one-by-one while checking several of the treap functions work as expected.264 for i := 0; i < numItems; i++ {265 // Hash the serialized int to generate out-of-order keys.266 hash := sha256.Sum256(serializeUint32(uint32(i)))267 key := hash[:]268 testTreap = testTreap.Delete(key)269 // Ensure the treap length is the expected value.270 if gotLen := testTreap.Len(); gotLen != numItems-i-1 {271 t.Fatalf("Len #%d: unexpected length - got %d, want %d",272 i, gotLen, numItems-i-1,273 )274 }275 // Ensure the treap no longer has the key.276 if testTreap.Has(key) {277 t.Fatalf("Has #%d: key %q is in treap", i, key)278 }279 // Get the key that no longer exists from the treap and ensure it is nil.280 if gotVal := testTreap.Get(key); gotVal != nil {281 t.Fatalf("Get #%d: unexpected value - got %x, want nil",282 i, gotVal,283 )284 }285 // Ensure the expected size is reported.286 expectedSize -= nodeFieldsSize + 64287 if gotSize := testTreap.Size(); gotSize != expectedSize {288 t.Fatalf("Size #%d: unexpected byte size - got %d, "+289 "want %d", i, gotSize, expectedSize,290 )291 }292 }293}294// TestImmutableDuplicatePut ensures that putting a duplicate key into an immutable treap works as expected.295func TestImmutableDuplicatePut(t *testing.T) {296 t.Parallel()297 expectedVal := []byte("testval")298 expectedSize := uint64(0)299 numItems := 1000300 testTreap := NewImmutable()301 for i := 0; i < numItems; i++ {302 key := serializeUint32(uint32(i))303 testTreap = testTreap.Put(key, key)304 expectedSize += nodeFieldsSize + uint64(len(key)+len(key))305 // Put a duplicate key with the the expected final value.306 testTreap = testTreap.Put(key, expectedVal)307 // Ensure the key still exists and is the new value.308 if gotVal := testTreap.Has(key); !gotVal {309 t.Fatalf("Has: unexpected result - got %v, want true",310 gotVal,311 )312 }313 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, expectedVal) {314 t.Fatalf("Get: unexpected result - got %x, want %x",315 gotVal, expectedVal,316 )317 }318 // Ensure the expected size is reported.319 expectedSize -= uint64(len(key))320 expectedSize += uint64(len(expectedVal))321 if gotSize := testTreap.Size(); gotSize != expectedSize {322 t.Fatalf("Size: unexpected byte size - got %d, want %d",323 gotSize, expectedSize,324 )325 }326 }327}328// TestImmutableNilValue ensures that putting a nil value into an immutable treap results in a key being added with an329// empty byte slice.330func TestImmutableNilValue(t *testing.T) {331 t.Parallel()332 key := serializeUint32(0)333 // Put the key with a nil value.334 testTreap := NewImmutable()335 testTreap = testTreap.Put(key, nil)336 // Ensure the key exists and is an empty byte slice.337 if gotVal := testTreap.Has(key); !gotVal {338 t.Fatalf("Has: unexpected result - got %v, want true", gotVal)339 }340 if gotVal := testTreap.Get(key); gotVal == nil {341 t.Fatalf("Get: unexpected result - got nil, want empty slice")342 }343 if gotVal := testTreap.Get(key); len(gotVal) != 0 {344 t.Fatalf("Get: unexpected result - got %x, want empty slice",345 gotVal,346 )347 }348}349// TestImmutableForEachStopIterator ensures that returning false from the ForEach callback on an immutable treap stops350// iteration early.351func TestImmutableForEachStopIterator(t *testing.T) {352 t.Parallel()353 // Insert a few keys.354 numItems := 10355 testTreap := NewImmutable()356 for i := 0; i < numItems; i++ {357 key := serializeUint32(uint32(i))358 testTreap = testTreap.Put(key, key)359 }360 // Ensure ForEach exits early on false return by caller.361 var numIterated int362 testTreap.ForEach(func(k, v []byte) bool {363 numIterated++364 return numIterated != numItems/2365 },366 )367 if numIterated != numItems/2 {368 t.Fatalf("ForEach: unexpected iterate count - got %d, want %d",369 numIterated, numItems/2,370 )371 }372}373// TestImmutableSnapshot ensures that immutable treaps are actually immutable by keeping a reference to the previous374// treap, performing a mutation, and then ensuring the referenced treap does not have the mutation applied.375func TestImmutableSnapshot(t *testing.T) {376 t.Parallel()377 // Insert a bunch of sequential keys while checking several of the treap functions work as expected.378 expectedSize := uint64(0)379 numItems := 1000380 testTreap := NewImmutable()381 for i := 0; i < numItems; i++ {382 treapSnap := testTreap383 key := serializeUint32(uint32(i))384 testTreap = testTreap.Put(key, key)385 // Ensure the length of the treap snapshot is the expected386 // value.387 if gotLen := treapSnap.Len(); gotLen != i {388 t.Fatalf("Len #%d: unexpected length - got %d, want %d",389 i, gotLen, i,390 )391 }392 // Ensure the treap snapshot does not have the key.393 if treapSnap.Has(key) {394 t.Fatalf("Has #%d: key %q is in treap", i, key)395 }396 // Get the key that doesn't exist in the treap snapshot and397 // ensure it is nil.398 if gotVal := treapSnap.Get(key); gotVal != nil {399 t.Fatalf("Get #%d: unexpected value - got %x, want nil",400 i, gotVal,401 )402 }403 // Ensure the expected size is reported.404 if gotSize := treapSnap.Size(); gotSize != expectedSize {405 t.Fatalf("Size #%d: unexpected byte size - got %d, "+406 "want %d", i, gotSize, expectedSize,407 )408 }409 expectedSize += nodeFieldsSize + 8410 }411 // Delete the keys one-by-one while checking several of the treap functions work as expected.412 for i := 0; i < numItems; i++ {413 treapSnap := testTreap414 key := serializeUint32(uint32(i))415 testTreap = testTreap.Delete(key)416 // Ensure the length of the treap snapshot is the expected value.417 if gotLen := treapSnap.Len(); gotLen != numItems-i {418 t.Fatalf("Len #%d: unexpected length - got %d, want %d",419 i, gotLen, numItems-i,420 )421 }422 // Ensure the treap snapshot still has the key.423 if !treapSnap.Has(key) {424 t.Fatalf("Has #%d: key %q is not in treap", i, key)425 }426 // Get the key from the treap snapshot and ensure it is still the expected value.427 if gotVal := treapSnap.Get(key); !bytes.Equal(gotVal, key) {428 t.Fatalf("Get #%d: unexpected value - got %x, want %x",429 i, gotVal, key,430 )431 }432 // Ensure the expected size is reported.433 if gotSize := treapSnap.Size(); gotSize != expectedSize {434 t.Fatalf("Size #%d: unexpected byte size - got %d, "+435 "want %d", i, gotSize, expectedSize,436 )437 }438 expectedSize -= nodeFieldsSize + 8...

Full Screen

Full Screen

mutable_test.go

Source:mutable_test.go Github

copy

Full Screen

...20 )21 }22 // Ensure there are no errors with requesting keys from an empty treap.23 key := serializeUint32(0)24 if gotVal := testTreap.Has(key); gotVal {25 t.Fatalf("Has: unexpected result - got %v, want false", gotVal)26 }27 if gotVal := testTreap.Get(key); gotVal != nil {28 t.Fatalf("Get: unexpected result - got %x, want nil", gotVal)29 }30 // Ensure there are no panics when deleting keys from an empty treap.31 testTreap.Delete(key)32 // Ensure the number of keys iterated by ForEach on an empty treap is33 // zero.34 var numIterated int35 testTreap.ForEach(func(k, v []byte) bool {36 numIterated++37 return true38 },39 )40 if numIterated != 0 {41 t.Fatalf("ForEach: unexpected iterate count - got %d, want 0",42 numIterated,43 )44 }45}46// TestMutableReset ensures that resetting an existing mutable treap works as expected.47func TestMutableReset(t *testing.T) {48 t.Parallel()49 // Insert a few keys.50 numItems := 1051 testTreap := NewMutable()52 for i := 0; i < numItems; i++ {53 key := serializeUint32(uint32(i))54 testTreap.Put(key, key)55 }56 // Reset it.57 testTreap.Reset()58 // Ensure the treap length is now 0.59 if gotLen := testTreap.Len(); gotLen != 0 {60 t.Fatalf("Len: unexpected length - got %d, want %d", gotLen, 0)61 }62 // Ensure the reported size is now 0.63 if gotSize := testTreap.Size(); gotSize != 0 {64 t.Fatalf("Size: unexpected byte size - got %d, want 0",65 gotSize,66 )67 }68 // Ensure the treap no longer has any of the keys.69 for i := 0; i < numItems; i++ {70 key := serializeUint32(uint32(i))71 // Ensure the treap no longer has the key.72 if testTreap.Has(key) {73 t.Fatalf("Has #%d: key %q is in treap", i, key)74 }75 // Get the key that no longer exists from the treap and ensure76 // it is nil.77 if gotVal := testTreap.Get(key); gotVal != nil {78 t.Fatalf("Get #%d: unexpected value - got %x, want nil",79 i, gotVal,80 )81 }82 }83 // Ensure the number of keys iterated by ForEach is zero.84 var numIterated int85 testTreap.ForEach(func(k, v []byte) bool {86 numIterated++87 return true88 },89 )90 if numIterated != 0 {91 t.Fatalf("ForEach: unexpected iterate count - got %d, want 0",92 numIterated,93 )94 }95}96// TestMutableSequential ensures that putting keys into a mutable treap in sequential order works as expected.97func TestMutableSequential(t *testing.T) {98 t.Parallel()99 // Insert a bunch of sequential keys while checking several of the treap functions work as expected.100 expectedSize := uint64(0)101 numItems := 1000102 testTreap := NewMutable()103 for i := 0; i < numItems; i++ {104 key := serializeUint32(uint32(i))105 testTreap.Put(key, key)106 // Ensure the treap length is the expected value.107 if gotLen := testTreap.Len(); gotLen != i+1 {108 t.Fatalf("Len #%d: unexpected length - got %d, want %d",109 i, gotLen, i+1,110 )111 }112 // Ensure the treap has the key.113 if !testTreap.Has(key) {114 t.Fatalf("Has #%d: key %q is not in treap", i, key)115 }116 // Get the key from the treap and ensure it is the expected value.117 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, key) {118 t.Fatalf("Get #%d: unexpected value - got %x, want %x",119 i, gotVal, key,120 )121 }122 // Ensure the expected size is reported.123 expectedSize += nodeFieldsSize + 8124 if gotSize := testTreap.Size(); gotSize != expectedSize {125 t.Fatalf("Size #%d: unexpected byte size - got %d, "+126 "want %d", i, gotSize, expectedSize,127 )128 }129 }130 // Ensure the all keys are iterated by ForEach in order.131 var numIterated int132 testTreap.ForEach(func(k, v []byte) bool {133 wantKey := serializeUint32(uint32(numIterated))134 // Ensure the key is as expected.135 if !bytes.Equal(k, wantKey) {136 t.Fatalf("ForEach #%d: unexpected key - got %x, want %x",137 numIterated, k, wantKey,138 )139 }140 // Ensure the value is as expected.141 if !bytes.Equal(v, wantKey) {142 t.Fatalf("ForEach #%d: unexpected value - got %x, want %x",143 numIterated, v, wantKey,144 )145 }146 numIterated++147 return true148 },149 )150 // Ensure all items were iterated.151 if numIterated != numItems {152 t.Fatalf("ForEach: unexpected iterate count - got %d, want %d",153 numIterated, numItems,154 )155 }156 // Delete the keys one-by-one while checking several of the treap functions work as expected.157 for i := 0; i < numItems; i++ {158 key := serializeUint32(uint32(i))159 testTreap.Delete(key)160 // Ensure the treap length is the expected value.161 if gotLen := testTreap.Len(); gotLen != numItems-i-1 {162 t.Fatalf("Len #%d: unexpected length - got %d, want %d",163 i, gotLen, numItems-i-1,164 )165 }166 // Ensure the treap no longer has the key.167 if testTreap.Has(key) {168 t.Fatalf("Has #%d: key %q is in treap", i, key)169 }170 // Get the key that no longer exists from the treap and ensure it is nil.171 if gotVal := testTreap.Get(key); gotVal != nil {172 t.Fatalf("Get #%d: unexpected value - got %x, want nil",173 i, gotVal,174 )175 }176 // Ensure the expected size is reported.177 expectedSize -= nodeFieldsSize + 8178 if gotSize := testTreap.Size(); gotSize != expectedSize {179 t.Fatalf("Size #%d: unexpected byte size - got %d, "+180 "want %d", i, gotSize, expectedSize,181 )182 }183 }184}185// TestMutableReverseSequential ensures that putting keys into a mutable treap in reverse sequential order works as186// expected.187func TestMutableReverseSequential(t *testing.T) {188 t.Parallel()189 // Insert a bunch of sequential keys while checking several of the treap functions work as expected.190 expectedSize := uint64(0)191 numItems := 1000192 testTreap := NewMutable()193 for i := 0; i < numItems; i++ {194 key := serializeUint32(uint32(numItems - i - 1))195 testTreap.Put(key, key)196 // Ensure the treap length is the expected value.197 if gotLen := testTreap.Len(); gotLen != i+1 {198 t.Fatalf("Len #%d: unexpected length - got %d, want %d",199 i, gotLen, i+1,200 )201 }202 // Ensure the treap has the key.203 if !testTreap.Has(key) {204 t.Fatalf("Has #%d: key %q is not in treap", i, key)205 }206 // Get the key from the treap and ensure it is the expected value.207 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, key) {208 t.Fatalf("Get #%d: unexpected value - got %x, want %x",209 i, gotVal, key,210 )211 }212 // Ensure the expected size is reported.213 expectedSize += nodeFieldsSize + 8214 if gotSize := testTreap.Size(); gotSize != expectedSize {215 t.Fatalf("Size #%d: unexpected byte size - got %d, "+216 "want %d", i, gotSize, expectedSize,217 )218 }219 }220 // Ensure the all keys are iterated by ForEach in order.221 var numIterated int222 testTreap.ForEach(func(k, v []byte) bool {223 wantKey := serializeUint32(uint32(numIterated))224 // Ensure the key is as expected.225 if !bytes.Equal(k, wantKey) {226 t.Fatalf("ForEach #%d: unexpected key - got %x, want %x",227 numIterated, k, wantKey,228 )229 }230 // Ensure the value is as expected.231 if !bytes.Equal(v, wantKey) {232 t.Fatalf("ForEach #%d: unexpected value - got %x, want %x",233 numIterated, v, wantKey,234 )235 }236 numIterated++237 return true238 },239 )240 // Ensure all items were iterated.241 if numIterated != numItems {242 t.Fatalf("ForEach: unexpected iterate count - got %d, want %d",243 numIterated, numItems,244 )245 }246 // Delete the keys one-by-one while checking several of the treap functions work as expected.247 for i := 0; i < numItems; i++ {248 // Intentionally use the reverse order they were inserted here.249 key := serializeUint32(uint32(i))250 testTreap.Delete(key)251 // Ensure the treap length is the expected value.252 if gotLen := testTreap.Len(); gotLen != numItems-i-1 {253 t.Fatalf("Len #%d: unexpected length - got %d, want %d",254 i, gotLen, numItems-i-1,255 )256 }257 // Ensure the treap no longer has the key.258 if testTreap.Has(key) {259 t.Fatalf("Has #%d: key %q is in treap", i, key)260 }261 // Get the key that no longer exists from the treap and ensure it is nil.262 if gotVal := testTreap.Get(key); gotVal != nil {263 t.Fatalf("Get #%d: unexpected value - got %x, want nil",264 i, gotVal,265 )266 }267 // Ensure the expected size is reported.268 expectedSize -= nodeFieldsSize + 8269 if gotSize := testTreap.Size(); gotSize != expectedSize {270 t.Fatalf("Size #%d: unexpected byte size - got %d, "+271 "want %d", i, gotSize, expectedSize,272 )273 }274 }275}276// TestMutableUnordered ensures that putting keys into a mutable treap in no particular order works as expected.277func TestMutableUnordered(t *testing.T) {278 t.Parallel()279 // Insert a bunch of out-of-order keys while checking several of the treap functions work as expected.280 expectedSize := uint64(0)281 numItems := 1000282 testTreap := NewMutable()283 for i := 0; i < numItems; i++ {284 // Hash the serialized int to generate out-of-order keys.285 hash := sha256.Sum256(serializeUint32(uint32(i)))286 key := hash[:]287 testTreap.Put(key, key)288 // Ensure the treap length is the expected value.289 if gotLen := testTreap.Len(); gotLen != i+1 {290 t.Fatalf("Len #%d: unexpected length - got %d, want %d",291 i, gotLen, i+1,292 )293 }294 // Ensure the treap has the key.295 if !testTreap.Has(key) {296 t.Fatalf("Has #%d: key %q is not in treap", i, key)297 }298 // Get the key from the treap and ensure it is the expected299 // value.300 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, key) {301 t.Fatalf("Get #%d: unexpected value - got %x, want %x",302 i, gotVal, key,303 )304 }305 // Ensure the expected size is reported.306 expectedSize += nodeFieldsSize + uint64(len(key)+len(key))307 if gotSize := testTreap.Size(); gotSize != expectedSize {308 t.Fatalf("Size #%d: unexpected byte size - got %d, "+309 "want %d", i, gotSize, expectedSize,310 )311 }312 }313 // Delete the keys one-by-one while checking several of the treap functions work as expected.314 for i := 0; i < numItems; i++ {315 // Hash the serialized int to generate out-of-order keys.316 hash := sha256.Sum256(serializeUint32(uint32(i)))317 key := hash[:]318 testTreap.Delete(key)319 // Ensure the treap length is the expected value.320 if gotLen := testTreap.Len(); gotLen != numItems-i-1 {321 t.Fatalf("Len #%d: unexpected length - got %d, want %d",322 i, gotLen, numItems-i-1,323 )324 }325 // Ensure the treap no longer has the key.326 if testTreap.Has(key) {327 t.Fatalf("Has #%d: key %q is in treap", i, key)328 }329 // Get the key that no longer exists from the treap and ensure it is nil.330 if gotVal := testTreap.Get(key); gotVal != nil {331 t.Fatalf("Get #%d: unexpected value - got %x, want nil",332 i, gotVal,333 )334 }335 // Ensure the expected size is reported.336 expectedSize -= nodeFieldsSize + 64337 if gotSize := testTreap.Size(); gotSize != expectedSize {338 t.Fatalf("Size #%d: unexpected byte size - got %d, "+339 "want %d", i, gotSize, expectedSize,340 )341 }342 }343}344// TestMutableDuplicatePut ensures that putting a duplicate key into a mutable treap updates the existing value.345func TestMutableDuplicatePut(t *testing.T) {346 t.Parallel()347 key := serializeUint32(0)348 val := []byte("testval")349 // Put the key twice with the second put being the expected final value.350 testTreap := NewMutable()351 testTreap.Put(key, key)352 testTreap.Put(key, val)353 // Ensure the key still exists and is the new value.354 if gotVal := testTreap.Has(key); !gotVal {355 t.Fatalf("Has: unexpected result - got %v, want true", gotVal)356 }357 if gotVal := testTreap.Get(key); !bytes.Equal(gotVal, val) {358 t.Fatalf("Get: unexpected result - got %x, want %x", gotVal, val)359 }360 // Ensure the expected size is reported.361 expectedSize := uint64(nodeFieldsSize + len(key) + len(val))362 if gotSize := testTreap.Size(); gotSize != expectedSize {363 t.Fatalf("Size: unexpected byte size - got %d, want %d",364 gotSize, expectedSize,365 )366 }367}368// TestMutableNilValue ensures that putting a nil value into a mutable treap results in a key being added with an empty369// byte slice.370func TestMutableNilValue(t *testing.T) {371 t.Parallel()372 key := serializeUint32(0)373 // Put the key with a nil value.374 testTreap := NewMutable()375 testTreap.Put(key, nil)376 // Ensure the key exists and is an empty byte slice.377 if gotVal := testTreap.Has(key); !gotVal {378 t.Fatalf("Has: unexpected result - got %v, want true", gotVal)379 }380 if gotVal := testTreap.Get(key); gotVal == nil {381 t.Fatalf("Get: unexpected result - got nil, want empty slice")382 }383 if gotVal := testTreap.Get(key); len(gotVal) != 0 {384 t.Fatalf("Get: unexpected result - got %x, want empty slice",385 gotVal,386 )387 }388}389// TestMutableForEachStopIterator ensures that returning false from the ForEach callback of a mutable treap stops390// iteration early.391func TestMutableForEachStopIterator(t *testing.T) {392 t.Parallel()...

Full Screen

Full Screen

cpu_test.go

Source:cpu_test.go Github

copy

Full Screen

...11 if runtime.GOARCH == "amd64" {12 if !cpu.Initialized {13 t.Fatal("Initialized expected true, got false")14 }15 if !cpu.X86.HasSSE2 {16 t.Fatal("HasSSE2 expected true, got false")17 }18 }19}20func TestAVX2hasAVX(t *testing.T) {21 if runtime.GOARCH == "amd64" {22 if cpu.X86.HasAVX2 && !cpu.X86.HasAVX {23 t.Fatal("HasAVX expected true, got false")24 }25 }26}27func TestAVX512HasAVX2AndAVX(t *testing.T) {28 if runtime.GOARCH == "amd64" {29 if cpu.X86.HasAVX512 && !cpu.X86.HasAVX {30 t.Fatal("HasAVX expected true, got false")31 }32 if cpu.X86.HasAVX512 && !cpu.X86.HasAVX2 {33 t.Fatal("HasAVX2 expected true, got false")34 }35 }36}37func TestARM64minimalFeatures(t *testing.T) {38 if runtime.GOARCH != "arm64" || (runtime.GOOS == "darwin" || runtime.GOOS == "ios") {39 return40 }41 if !cpu.ARM64.HasASIMD {42 t.Fatal("HasASIMD expected true, got false")43 }44 if !cpu.ARM64.HasFP {45 t.Fatal("HasFP expected true, got false")46 }47}48func TestMIPS64Initialized(t *testing.T) {49 if runtime.GOARCH == "mips64" || runtime.GOARCH == "mips64le" {50 if !cpu.Initialized {51 t.Fatal("Initialized expected true, got false")52 }53 }54}55// On ppc64x, the ISA bit for POWER8 should always be set on POWER8 and beyond.56func TestPPC64minimalFeatures(t *testing.T) {57 // Do not run this with gccgo on ppc64, as it doesn't have POWER8 as a minimum58 // requirement.59 if runtime.Compiler == "gccgo" && runtime.GOARCH == "ppc64" {60 t.Skip("gccgo does not require POWER8 on ppc64; skipping")61 }62 if runtime.GOARCH == "ppc64" || runtime.GOARCH == "ppc64le" {63 if !cpu.PPC64.IsPOWER8 {64 t.Fatal("IsPOWER8 expected true, got false")65 }66 }67}68func TestS390X(t *testing.T) {69 if runtime.GOARCH != "s390x" {70 return71 }72 if testing.Verbose() {73 t.Logf("%+v\n", cpu.S390X)74 }75 // z/Architecture is mandatory76 if !cpu.S390X.HasZARCH {77 t.Error("HasZARCH expected true, got false")78 }79 // vector-enhancements require vector facility to be enabled80 if cpu.S390X.HasVXE && !cpu.S390X.HasVX {81 t.Error("HasVX expected true, got false (VXE is true)")82 }83}...

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 m = make(map[string]int)4 fmt.Println(m)5 fmt.Println(m["one"])6 fmt.Println(m["two"])7 fmt.Println(m["three"])8 fmt.Println(m["four"])9 fmt.Println(m["five"])10 fmt.Println(m["six"])11}12import (13func main() {14 m = make(map[string]int)15 fmt.Println(m)16 fmt.Println(m["one"])17 fmt.Println(m["two"])18 fmt.Println(m["three"])19 fmt.Println(m["four"])20 fmt.Println(m["five"])21 fmt.Println(m["six"])22}

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 got := got.Got{}4 got.Add("Arya")5 got.Add("Sansa")6 got.Add("Bran")7 got.Add("Jon")8 fmt.Println(got.Has("Sansa"))9 fmt.Println(got.Has("John"))10}

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1func main() {2 var got = new(GoT)3 got.Add("Ned", "Robb", "Sansa", "Arya", "Bran", "Rickon")4 fmt.Println(got.Has("Sansa"))5 fmt.Println(got.Has("Jon"))6}

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 g := got.NewGot()4 g.Add("This is a test")5 g.Add("This is a second test")6 g.Add("This is a third test")7 g.Add("This is a fourth test")8 g.Add("This is a fifth test")9 g.Add("This is a sixth test")10 g.Add("This is a seventh test")11 g.Add("This is a eighth test")12 g.Add("This is a ninth test")13 g.Add("This is a tenth test")14 fmt.Println(g.Has("This is a test"))15 fmt.Println(g.Has("This is a second test"))16 fmt.Println(g.Has("This is a third test"))17 fmt.Println(g.Has("This is a fourth test"))18 fmt.Println(g.Has("This is a fifth test"))19 fmt.Println(g.Has("This is a sixth test"))20 fmt.Println(g.Has("This is a seventh test"))21 fmt.Println(g.Has("This is a eighth test"))22 fmt.Println(g.Has("This is a ninth test"))23 fmt.Println(g.Has("This is a tenth test"))24}25import (26func main() {27 g := got.NewGot()28 g.Add("This is a test")29 g.Add("This is a second test")30 g.Add("This is a third test")31 g.Add("This is a fourth test")32 g.Add("This is a fifth test")33 g.Add("This is a sixth test")34 g.Add("This is a seventh test")35 g.Add("This is a eighth test")36 g.Add("This is a ninth test")37 g.Add("This is a tenth test")38 fmt.Println(g.Has("This is a test"))39 fmt.Println(g.Has("This is a second test"))40 fmt.Println(g.Has("This is a third test"))41 fmt.Println(g.Has("This is a fourth test"))42 fmt.Println(g.Has("This is a fifth test"))43 fmt.Println(g.Has("This is a sixth test"))44 fmt.Println(g.Has("This is a seventh test"))45 fmt.Println(g.Has("This is a eighth test"))46 fmt.Println(g.Has("This is a ninth test"))47 fmt.Println(g.Has("This is a tenth test"))48}49import (50func main() {

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 contains := strings.Contains(str, "how")4 fmt.Println(contains)5}6The strings package in Go provides a lot of useful methods to work with strings. Here are some of the most important ones:7strings.Fields("Hello how

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 g := remotegit.NewGot()4 if g.Has() {5 fmt.Println("Git repository exist")6 } else {7 fmt.Println("Git repository does not exist")8 }9}

Full Screen

Full Screen

Has

Using AI Code Generation

copy

Full Screen

1import (2func main() {3 g.Has("Ned")4 g.Has("Robb")5 g.Has("Sansa")6 fmt.Println(g)7}8{map[Ned:1 Robb:1 Sansa:1]}

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful