Skip to content

Commit

Permalink
Revert "[Token Detection V2] 1 of 7 - Throw on failure for fetchToken…
Browse files Browse the repository at this point in the history
…Metadata in token service (#812)" (#824)

This reverts commit d4030cf.
  • Loading branch information
adonesky1 authored May 11, 2022
1 parent 9c3483a commit a25d909
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 57 deletions.
86 changes: 35 additions & 51 deletions src/apis/token-service.test.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,6 @@
import nock from 'nock';
import { NetworksChainId } from '../network/NetworkController';
import {
fetchTokenList,
fetchTokenMetadata,
FETCH_TOKEN_METADATA_ERROR,
} from './token-service';
import { fetchTokenList, fetchTokenMetadata } from './token-service';

const TOKEN_END_POINT_API = 'https://token-api.metaswap.codefi.network';

Expand Down Expand Up @@ -237,7 +233,7 @@ describe('Token service', () => {
expect(token).toStrictEqual(sampleToken);
});

it('should throw error if the fetch is aborted', async () => {
it('should return undefined if the fetch is aborted', async () => {
const abortController = new AbortController();
nock(TOKEN_END_POINT_API)
.get(`/tokens/${NetworksChainId.mainnet}`)
Expand All @@ -246,49 +242,49 @@ describe('Token service', () => {
.reply(200, sampleTokenList)
.persist();

await expect(async () => {
await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
abortController.signal,
);
abortController.abort();
}).rejects.toThrow(FETCH_TOKEN_METADATA_ERROR);
const fetchPromise = fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
abortController.signal,
);
abortController.abort();

expect(await fetchPromise).toBeUndefined();
});

it('should throw error if the fetch fails with a network error', async () => {
it('should return undefined if the fetch fails with a network error', async () => {
const { signal } = new AbortController();
nock(TOKEN_END_POINT_API)
.get(`/tokens/${NetworksChainId.mainnet}`)
.replyWithError('Example network error')
.persist();

await expect(async () => {
await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
signal,
);
}).rejects.toThrow(FETCH_TOKEN_METADATA_ERROR);
const result = await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
signal,
);

expect(result).toBeUndefined();
});

it('should throw error if the fetch fails with an unsuccessful status code', async () => {
it('should return undefined if the fetch fails with an unsuccessful status code', async () => {
const { signal } = new AbortController();
nock(TOKEN_END_POINT_API)
.get(`/tokens/${NetworksChainId.mainnet}`)
.reply(500)
.persist();

await expect(async () => {
await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
signal,
);
}).rejects.toThrow(FETCH_TOKEN_METADATA_ERROR);
const result = await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
signal,
);

expect(result).toBeUndefined();
});

it('should throw error if the fetch fails with a timeout', async () => {
it('should return undefined if the fetch fails with a timeout', async () => {
const { signal } = new AbortController();
nock(TOKEN_END_POINT_API)
.get(`/tokens/${NetworksChainId.mainnet}`)
Expand All @@ -297,26 +293,14 @@ describe('Token service', () => {
.reply(200, sampleTokenList)
.persist();

await expect(async () => {
await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
signal,
{ timeout: ONE_MILLISECOND },
);
}).rejects.toThrow(FETCH_TOKEN_METADATA_ERROR);
});
});

it('should call the tokens api and return undefined', async () => {
const { signal } = new AbortController();
nock(TOKEN_END_POINT_API)
.get(`/tokens/${NetworksChainId.mainnet}`)
.reply(404, undefined)
.persist();

const tokens = await fetchTokenList(NetworksChainId.mainnet, signal);
const result = await fetchTokenMetadata(
NetworksChainId.mainnet,
'0x514910771af9ca656af840dff83e8264ecf986ca',
signal,
{ timeout: ONE_MILLISECOND },
);

expect(tokens).toBeUndefined();
expect(result).toBeUndefined();
});
});
});
10 changes: 4 additions & 6 deletions src/apis/token-service.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
import { timeoutFetch } from '../util';

const END_POINT = 'https://token-api.metaswap.codefi.network';
export const FETCH_TOKEN_METADATA_ERROR =
'TokenService Error: No response from fetchTokenMetadata';

/**
* Get the tokens URL for a specific network.
Expand Down Expand Up @@ -65,18 +63,18 @@ export async function fetchTokenList(
* @param options.timeout - The fetch timeout.
* @returns The token metadata, or `undefined` if the request was cancelled.
*/
export async function fetchTokenMetadata<T>(
export async function fetchTokenMetadata(
chainId: string,
tokenAddress: string,
abortSignal: AbortSignal,
{ timeout = defaultTimeout } = {},
): Promise<T> {
): Promise<unknown> {
const tokenMetadataURL = getTokenMetadataURL(chainId, tokenAddress);
const response = await queryApi(tokenMetadataURL, abortSignal, timeout);
if (response) {
return parseJsonResponse(response) as Promise<T>;
return parseJsonResponse(response);
}
throw new Error(FETCH_TOKEN_METADATA_ERROR);
return undefined;
}

/**
Expand Down

0 comments on commit a25d909

Please sign in to comment.