mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-18 07:51:48 +08:00
122 lines
3.2 KiB
TypeScript
122 lines
3.2 KiB
TypeScript
|
|
import redis = require('redis');
|
|
|
|
var value: any;
|
|
var valueArr: any[];
|
|
var commandArr: any[][];
|
|
var num: number;
|
|
var str: string;
|
|
var bool: boolean;
|
|
var err: Error;
|
|
var args: any[];
|
|
var options: redis.ClientOpts;
|
|
var client: redis.RedisClient;
|
|
var info: redis.ServerInfo;
|
|
var resCallback: (err: Error, res: any) => void;
|
|
var numCallback: (err: Error, res: number) => void;
|
|
var strCallback: (err: Error, res: string) => void;
|
|
var messageHandler: (channel: string, message: any) => void;
|
|
|
|
// ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
|
|
|
|
bool = redis.debug_mode;
|
|
redis.print(err, value);
|
|
|
|
// ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
|
|
|
|
client = redis.createClient(num, str, options);
|
|
|
|
// Test the `retry_strategy` property
|
|
// ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
|
|
function retryStrategyNumber(options: redis.RetryStrategyOptions): number {
|
|
// Ensure that the properties of RetryStrategyOptions are resilient to breaking change.
|
|
// If the properties of the interface changes, the variables below will also need to be adapted.
|
|
var error: Error = options.error;
|
|
var total_retry_time: number = options.total_retry_time;
|
|
var times_connected: number = options.times_connected;
|
|
var attempt: number = options.attempt;
|
|
return 5000;
|
|
}
|
|
function retryStrategyError(options: redis.RetryStrategyOptions): Error {
|
|
return new Error('Foo');
|
|
}
|
|
client = redis.createClient({
|
|
retry_strategy: retryStrategyNumber
|
|
});
|
|
client = redis.createClient({
|
|
retry_strategy: retryStrategyError
|
|
});
|
|
// ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
|
|
|
|
bool = client.connected;
|
|
num = client.retry_delay;
|
|
num = client.retry_backoff;
|
|
valueArr = client.command_queue;
|
|
valueArr = client.offline_queue;
|
|
info = client.server_info;
|
|
|
|
// ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
|
|
|
|
client.end(true);
|
|
|
|
// Connection (http://redis.io/commands#connection)
|
|
client.auth(str, resCallback);
|
|
client.ping(strCallback);
|
|
client.unref();
|
|
|
|
// Strings (http://redis.io/commands#strings)
|
|
client.append(str, str, numCallback);
|
|
client.bitcount(str, numCallback);
|
|
client.bitcount(str, num, num, numCallback);
|
|
client.set(str, str, strCallback);
|
|
client.get(str, strCallback);
|
|
client.exists(str, numCallback);
|
|
|
|
// Event handlers
|
|
client.on(str, messageHandler);
|
|
client.once(str, messageHandler);
|
|
|
|
// ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
|
|
|
|
// some of the bulk methods
|
|
client.get('test');
|
|
client.get('test', resCallback);
|
|
client.set('test', 'test');
|
|
client.set('test', 'test', resCallback);
|
|
client.mset(args, resCallback);
|
|
|
|
client.incr(str, resCallback);
|
|
|
|
// Friendlier hash commands
|
|
client.hgetall(str, resCallback);
|
|
client.hmset(str, value, resCallback);
|
|
client.hmset(str, str, str, str, str, resCallback);
|
|
|
|
// Publish / Subscribe
|
|
client.publish(str, value);
|
|
client.subscribe(str);
|
|
|
|
// Multi
|
|
client.multi()
|
|
.scard(str)
|
|
.smembers(str)
|
|
.keys('*', resCallback)
|
|
.dbsize()
|
|
.exec(resCallback);
|
|
|
|
client.multi([['get', 'test']]).exec();
|
|
|
|
// Monitor mode
|
|
client.monitor(resCallback);
|
|
|
|
// Send command
|
|
client.send_command(str, args, resCallback);
|
|
// Duplicate
|
|
client.duplicate();
|
|
|
|
// Pipeline
|
|
client.cork();
|
|
client.set("abc", "fff", strCallback);
|
|
client.get("abc", resCallback);
|
|
client.uncork();
|