Implement lazy watcher mode in erc20-watcher (#275)

This commit is contained in:
nikugogoi 2021-10-18 13:03:55 +05:30 committed by GitHub
parent 3b27177389
commit f00ea0c1f0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 20 additions and 11 deletions

View File

@ -2,6 +2,7 @@
host = "127.0.0.1" host = "127.0.0.1"
port = 3001 port = 3001
mode = "eth_call" mode = "eth_call"
kind = "lazy"
[database] [database]
type = "postgres" type = "postgres"

View File

@ -15,7 +15,7 @@ import { getDefaultProvider } from 'ethers';
import { getCache } from '@vulcanize/cache'; import { getCache } from '@vulcanize/cache';
import { EthClient } from '@vulcanize/ipld-eth-client'; import { EthClient } from '@vulcanize/ipld-eth-client';
import { DEFAULT_CONFIG_PATH, getConfig, JobQueue } from '@vulcanize/util'; import { DEFAULT_CONFIG_PATH, getConfig, JobQueue, KIND_ACTIVE } from '@vulcanize/util';
import typeDefs from './schema'; import typeDefs from './schema';
@ -42,7 +42,7 @@ export const main = async (): Promise<any> => {
assert(config.server, 'Missing server config'); assert(config.server, 'Missing server config');
const { host, port, mode } = config.server; const { host, port, mode, kind: watcherKind } = config.server;
const { upstream, database: dbConfig, jobQueue: jobQueueConfig } = config; const { upstream, database: dbConfig, jobQueue: jobQueueConfig } = config;
@ -76,10 +76,12 @@ export const main = async (): Promise<any> => {
assert(dbConnectionString, 'Missing job queue db connection string'); assert(dbConnectionString, 'Missing job queue db connection string');
const jobQueue = new JobQueue({ dbConnectionString, maxCompletionLag: maxCompletionLagInSecs }); const jobQueue = new JobQueue({ dbConnectionString, maxCompletionLag: maxCompletionLagInSecs });
await jobQueue.start();
const eventWatcher = new EventWatcher(ethClient, indexer, pubsub, jobQueue); const eventWatcher = new EventWatcher(ethClient, indexer, pubsub, jobQueue);
if (watcherKind === KIND_ACTIVE) {
await jobQueue.start();
await eventWatcher.start(); await eventWatcher.start();
}
const resolvers = process.env.MOCK ? await createMockResolvers() : await createResolvers(indexer, eventWatcher); const resolvers = process.env.MOCK ? await createMockResolvers() : await createResolvers(indexer, eventWatcher);

View File

@ -61,6 +61,7 @@ describe('uni-info-watcher', () => {
let config: Config; let config: Config;
let uniClient: UniClient; let uniClient: UniClient;
let client: Client; let client: Client;
let deadline: number;
before(async () => { before(async () => {
config = await getConfig(CONFIG_FILE); config = await getConfig(CONFIG_FILE);
@ -84,6 +85,11 @@ describe('uni-info-watcher', () => {
const provider = new ethers.providers.JsonRpcProvider(rpcProviderEndpoint); const provider = new ethers.providers.JsonRpcProvider(rpcProviderEndpoint);
signer = provider.getSigner(); signer = provider.getSigner();
recipient = await signer.getAddress(); recipient = await signer.getAddress();
// Deadline set to 2 days from current date.
const deadlineDate = new Date();
deadlineDate.setDate(deadlineDate.getDate() + 2);
deadline = Math.floor(deadlineDate.getTime() / 1000);
}); });
it('should have a Factory entity', async () => { it('should have a Factory entity', async () => {
@ -702,7 +708,6 @@ describe('uni-info-watcher', () => {
const amount1Desired = 15; const amount1Desired = 15;
const amount0Min = 0; const amount0Min = 0;
const amount1Min = 0; const amount1Min = 0;
const deadline = 1634367993;
before(async () => { before(async () => {
// Get the NFPM contract address. // Get the NFPM contract address.
@ -833,7 +838,6 @@ describe('uni-info-watcher', () => {
const amount1Desired = 15; const amount1Desired = 15;
const amount0Min = 0; const amount0Min = 0;
const amount1Min = 0; const amount1Min = 0;
const deadline = 1634367993;
before(async () => { before(async () => {
// Get initial entity values. // Get initial entity values.
@ -908,7 +912,6 @@ describe('uni-info-watcher', () => {
const liquidity = 5; const liquidity = 5;
const amount0Min = 0; const amount0Min = 0;
const amount1Min = 0; const amount1Min = 0;
const deadline = 1634367993;
before(async () => { before(async () => {
// Get initial entity values. // Get initial entity values.

View File

@ -66,6 +66,7 @@ describe('uni-watcher', () => {
let postgraphileClient: EthClient; let postgraphileClient: EthClient;
let signer: Signer; let signer: Signer;
let recipient: string; let recipient: string;
let deadline: number;
before(async () => { before(async () => {
config = await getConfig(CONFIG_FILE); config = await getConfig(CONFIG_FILE);
@ -108,6 +109,11 @@ describe('uni-watcher', () => {
const provider = new ethers.providers.JsonRpcProvider(rpcProviderEndpoint); const provider = new ethers.providers.JsonRpcProvider(rpcProviderEndpoint);
signer = provider.getSigner(); signer = provider.getSigner();
recipient = await signer.getAddress(); recipient = await signer.getAddress();
// Deadline set to 2 days from current date.
const deadlineDate = new Date();
deadlineDate.setDate(deadlineDate.getDate() + 2);
deadline = Math.floor(deadlineDate.getTime() / 1000);
}); });
after(async () => { after(async () => {
@ -279,7 +285,6 @@ describe('uni-watcher', () => {
const amount1Desired = 15; const amount1Desired = 15;
const amount0Min = 0; const amount0Min = 0;
const amount1Min = 0; const amount1Min = 0;
const deadline = 1634367993;
// Approving tokens for NonfungiblePositionManager contract. // Approving tokens for NonfungiblePositionManager contract.
// https://github.com/Uniswap/uniswap-v3-periphery/blob/main/test/NonfungiblePositionManager.spec.ts#L44 // https://github.com/Uniswap/uniswap-v3-periphery/blob/main/test/NonfungiblePositionManager.spec.ts#L44
@ -344,7 +349,6 @@ describe('uni-watcher', () => {
const amount1Desired = 15; const amount1Desired = 15;
const amount0Min = 0; const amount0Min = 0;
const amount1Min = 0; const amount1Min = 0;
const deadline = 1634367993;
// Subscribe using UniClient. // Subscribe using UniClient.
const subscription = await uniClient.watchEvents((value: any) => { const subscription = await uniClient.watchEvents((value: any) => {
@ -388,7 +392,6 @@ describe('uni-watcher', () => {
const liquidity = 5; const liquidity = 5;
const amount0Min = 0; const amount0Min = 0;
const amount1Min = 0; const amount1Min = 0;
const deadline = 1634367993;
// Subscribe using UniClient. // Subscribe using UniClient.
const subscription = await uniClient.watchEvents((value: any) => { const subscription = await uniClient.watchEvents((value: any) => {