Java tutorial
/* * Copyright (c) 2014-2015 Spotify AB * * 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 com.spotify.folsom; import com.google.common.base.Function; import com.google.common.collect.Lists; import com.google.common.util.concurrent.AsyncFunction; import com.google.common.util.concurrent.Futures; import com.google.common.util.concurrent.ListenableFuture; import com.spotify.folsom.client.Utils; import com.spotify.folsom.transcoder.StringTranscoder; import java.util.List; public class LoadTestRunner { public static void main(final String[] args) throws Throwable { final BinaryMemcacheClient<String> client = new MemcacheClientBuilder<>(StringTranscoder.UTF8_INSTANCE) .withAddress("127.0.0.1").withMaxOutstandingRequests(100000).connectBinary(); final String[] keys = new String[10]; for (int i = 0; i < 10; i++) { keys[i] = "key" + i; } final List<ListenableFuture<Boolean>> futures = Lists.newArrayList(); for (int r = 0; r < 100; r++) { for (final String keyProto : keys) { final String key = keyProto + ":" + r; final ListenableFuture<MemcacheStatus> setFuture = client.set(key, "value" + key, 100000); final ListenableFuture<String> getFuture = Utils.transform(setFuture, new AsyncFunction<MemcacheStatus, String>() { @Override public ListenableFuture<String> apply(final MemcacheStatus input) throws Exception { return client.get(key); } }); final ListenableFuture<String> deleteFuture = Utils.transform(getFuture, new AsyncFunction<String, String>() { @Override public ListenableFuture<String> apply(final String value) throws Exception { return Utils.transform(client.delete(key), new Function<MemcacheStatus, String>() { @Override public String apply(final MemcacheStatus input) { return value; } }); } }); final ListenableFuture<Boolean> assertFuture = Utils.transform(deleteFuture, new Function<String, Boolean>() { @Override public Boolean apply(final String input) { return ("value" + key).equals(input); } }); futures.add(assertFuture); } } final List<Boolean> asserts = Futures.allAsList(futures).get(); int failed = 0; for (final boolean b : asserts) { if (!b) { failed++; } } System.out.println(failed + " failed of " + asserts.size()); client.shutdown(); } }