From a25d90906137f85ea9853018f7c3fbe0cfd67df1 Mon Sep 17 00:00:00 2001 From: Alex Donesky Date: Wed, 11 May 2022 13:27:54 -0500 Subject: [PATCH] Revert "[Token Detection V2] 1 of 7 - Throw on failure for fetchTokenMetadata in token service (#812)" (#824) This reverts commit d4030cff97344d6a919bfc0cf1dc786e771e27b5. --- src/apis/token-service.test.ts | 86 ++++++++++++++-------------------- src/apis/token-service.ts | 10 ++-- 2 files changed, 39 insertions(+), 57 deletions(-) diff --git a/src/apis/token-service.test.ts b/src/apis/token-service.test.ts index f69656ab14..758229f52b 100644 --- a/src/apis/token-service.test.ts +++ b/src/apis/token-service.test.ts @@ -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'; @@ -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}`) @@ -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}`) @@ -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(); + }); }); }); diff --git a/src/apis/token-service.ts b/src/apis/token-service.ts index 4028c9721a..139a1738b1 100644 --- a/src/apis/token-service.ts +++ b/src/apis/token-service.ts @@ -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. @@ -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( +export async function fetchTokenMetadata( chainId: string, tokenAddress: string, abortSignal: AbortSignal, { timeout = defaultTimeout } = {}, -): Promise { +): Promise { const tokenMetadataURL = getTokenMetadataURL(chainId, tokenAddress); const response = await queryApi(tokenMetadataURL, abortSignal, timeout); if (response) { - return parseJsonResponse(response) as Promise; + return parseJsonResponse(response); } - throw new Error(FETCH_TOKEN_METADATA_ERROR); + return undefined; } /**