From db6b2dda07b1ad7c875f47219de65d40242d112d Mon Sep 17 00:00:00 2001 From: Anita Ruangrotsakun <138700973+anitarua@users.noreply.github.com> Date: Fri, 6 Sep 2024 09:15:15 -0700 Subject: [PATCH] chore: make sure storage tests use unique stores (#1433) * chore: make sure storage tests use unique stores * some storage test reorganization --- .../test/integration/integration-setup.ts | 20 +- .../test/integration/integration-setup.ts | 16 +- .../src/storage/storage.ts | 294 ++++++++---------- 3 files changed, 158 insertions(+), 172 deletions(-) diff --git a/packages/client-sdk-nodejs/test/integration/integration-setup.ts b/packages/client-sdk-nodejs/test/integration/integration-setup.ts index 28d3db7a7..b018aaccf 100644 --- a/packages/client-sdk-nodejs/test/integration/integration-setup.ts +++ b/packages/client-sdk-nodejs/test/integration/integration-setup.ts @@ -1,4 +1,9 @@ -import {testCacheName} from '@gomomento/common-integration-tests'; +import { + createStoreIfNotExists, + deleteStoreIfExists, + testCacheName, + testStoreName, +} from '@gomomento/common-integration-tests'; import { AuthClient, CreateCache, @@ -249,11 +254,20 @@ export function SetupStorageIntegrationTest(): { storageClient: PreviewStorageClient; integrationTestStoreName: string; } { - const {integrationTestCacheName} = SetupIntegrationTest(); + const integrationTestStoreName = testStoreName(); const storageClient = momentoStorageClientForTesting(); + + beforeAll(async () => { + await createStoreIfNotExists(storageClient, integrationTestStoreName); + }); + + afterAll(async () => { + await deleteStoreIfExists(storageClient, integrationTestStoreName); + }); + return { storageClient, - integrationTestStoreName: integrationTestCacheName, + integrationTestStoreName, }; } diff --git a/packages/client-sdk-web/test/integration/integration-setup.ts b/packages/client-sdk-web/test/integration/integration-setup.ts index 170fbdcb4..27cda6b1d 100644 --- a/packages/client-sdk-web/test/integration/integration-setup.ts +++ b/packages/client-sdk-web/test/integration/integration-setup.ts @@ -3,6 +3,9 @@ import { testCacheName, isLocalhostDevelopmentMode, createCacheIfNotExists, + testStoreName, + deleteStoreIfExists, + createStoreIfNotExists, } from '@gomomento/common-integration-tests'; import { CreateCache, @@ -237,11 +240,20 @@ export function SetupStorageIntegrationTest(): { storageClient: IStorageClient; integrationTestStoreName: string; } { - const {integrationTestCacheName} = SetupIntegrationTest(); + const integrationTestStoreName = testStoreName(); const storageClient = momentoStorageClientForTesting(); + + beforeAll(async () => { + await createStoreIfNotExists(storageClient, integrationTestStoreName); + }); + + afterAll(async () => { + await deleteStoreIfExists(storageClient, integrationTestStoreName); + }); + return { storageClient, - integrationTestStoreName: integrationTestCacheName, + integrationTestStoreName, }; } diff --git a/packages/common-integration-tests/src/storage/storage.ts b/packages/common-integration-tests/src/storage/storage.ts index 34d14b8e2..aa3d460c5 100644 --- a/packages/common-integration-tests/src/storage/storage.ts +++ b/packages/common-integration-tests/src/storage/storage.ts @@ -14,12 +14,11 @@ import { WithStore, } from '../common-int-test-utils'; import {v4} from 'uuid'; -import {sleep} from '@gomomento/sdk-core/dist/src/internal/utils'; export function runStorageServiceTests( storageClient: IStorageClient, testingStoreName: string -) { +): void { describe('#create list and delete stores', () => { it('creates a store, lists it and makes sure it exists, and then deletes it', async () => { const storeName = testStoreName(); @@ -71,169 +70,26 @@ export function runStorageServiceTests( }); it('should return AlreadyExists response if trying to create a store that already exists', async () => { const storeName = testStoreName(); - const createResponse = await storageClient.createStore(storeName); - switch (createResponse.type) { - // this is the expected response - case CreateStoreResponse.Success: { - break; - } - case CreateStoreResponse.AlreadyExists: { - break; - } - case CreateStoreResponse.Error: { - throw new Error( - `failed to create store, expected store to be able to happen, error: ${createResponse.message()} exception: ${createResponse.toString()}` - ); - } - } - const alreadyExistResponse = await storageClient.createStore(storeName); - switch (alreadyExistResponse.type) { - case CreateStoreResponse.AlreadyExists: { - break; - } - case CreateStoreResponse.Error: { - throw new Error( - `failed to create store, expected AlreadyExists response, error: ${alreadyExistResponse.message()} exception: ${alreadyExistResponse.toString()}` - ); - } - case CreateStoreResponse.Success: { - throw new Error( - 'store already exists, we should not be able to create it again' - ); - } - } - await storageClient.deleteStore(storeName); - }); - }); - describe('#store get put and delete', () => { - it('put get and delete key in a store', async () => { - await WithStore(storageClient, testingStoreName, async () => { - const key = v4(); - - // put/get an int value - const intValue = 42; - const putIntResponse = await storageClient.putInt( - testingStoreName, - key, - intValue - ); - switch (putIntResponse.type) { - case StoragePutResponse.Success: { - break; - } - case StoragePutResponse.Error: { - throw new Error( - `failed to put key: ${putIntResponse.message()} ${putIntResponse.toString()}` - ); - } - } - const getIntResponse = await storageClient.get(testingStoreName, key); - expectWithMessage(() => { - expect(getIntResponse.type).toEqual(StorageGetResponse.Found); - }, `expected Found, received ${getIntResponse.toString()}`); - expect(getIntResponse.value()?.int()).toEqual(intValue); - - // put/get a double value - const doubleValue = 42.42; - const putDoubleResponse = await storageClient.putDouble( - testingStoreName, - key, - doubleValue - ); - switch (putDoubleResponse.type) { - case StoragePutResponse.Success: { - break; - } - case StoragePutResponse.Error: { - throw new Error( - `failed to put key: ${putDoubleResponse.message()} ${putDoubleResponse.toString()}` - ); - } - } - const getDoubleResponse = await storageClient.get( - testingStoreName, - key - ); - expectWithMessage(() => { - expect(getDoubleResponse.type).toEqual(StorageGetResponse.Found); - }, `expected Found, received ${getDoubleResponse.toString()}`); - expect(getDoubleResponse.value()?.double()).toEqual(doubleValue); - - // put/get a string value - const stringValue = v4(); - const putStringResponse = await storageClient.putString( - testingStoreName, - key, - stringValue - ); - switch (putStringResponse.type) { - case StoragePutResponse.Success: { - break; - } - case StoragePutResponse.Error: { - throw new Error( - `failed to put key: ${putStringResponse.message()} ${putStringResponse.toString()}` - ); - } - } - const getStringResponse = await storageClient.get( - testingStoreName, - key - ); - expectWithMessage(() => { - expect(getStringResponse.type).toEqual(StorageGetResponse.Found); - }, `expected Found, received ${getStringResponse.toString()}`); - expect(getStringResponse.value()?.string()).toEqual(stringValue); - - // put/get a bytes value - const bytesValue = new Uint8Array([1, 2, 3, 4]); - const putBytesResponse = await storageClient.putBytes( - testingStoreName, - key, - bytesValue - ); - switch (putBytesResponse.type) { - case StoragePutResponse.Success: { + // WithStore creates a store then deletes it + await WithStore(storageClient, storeName, async () => { + const alreadyExistResponse = await storageClient.createStore(storeName); + switch (alreadyExistResponse.type) { + case CreateStoreResponse.AlreadyExists: { break; } - case StoragePutResponse.Error: { + case CreateStoreResponse.Error: { throw new Error( - `failed to put key: ${putBytesResponse.message()} ${putBytesResponse.toString()}` + `failed to create store, expected AlreadyExists response, error: ${alreadyExistResponse.message()} exception: ${alreadyExistResponse.toString()}` ); } - } - const getBytesResponse = await storageClient.get(testingStoreName, key); - expectWithMessage(() => { - expect(getBytesResponse.type).toEqual(StorageGetResponse.Found); - }, `expected Found, received ${getBytesResponse.toString()}`); - expect(getBytesResponse.value()?.bytes()).toEqual(bytesValue); - - const deleteResponse = await storageClient.delete( - testingStoreName, - key - ); - switch (deleteResponse.type) { - case StorageDeleteResponse.Success: { - break; - } - case StorageDeleteResponse.Error: { + case CreateStoreResponse.Success: { throw new Error( - `failed to delete key in store: ${deleteResponse.message()} ${deleteResponse.toString()}` + 'store already exists, we should not be able to create it again' ); } } }); }); - it('should return an undefined value for a key that doesnt exist', async () => { - await WithStore(storageClient, testingStoreName, async () => { - const key = v4(); - const getResponse = await storageClient.get(testingStoreName, key); - expectWithMessage(() => { - expect(getResponse.type).toEqual(StorageGetResponse.NotFound); - }, `expected NotFound, received ${getResponse.toString()}`); - expect(getResponse.value()).toBeUndefined(); - }); - }); it('should return store not found error for deleting a store that doesnt exist', async () => { const storeName = testStoreName(); const deleteResponse = await storageClient.deleteStore(storeName); @@ -253,21 +109,125 @@ export function runStorageServiceTests( } } }); - it('should successfully make two of the same requests after 5s retry timeout', async () => { - await WithStore(storageClient, testingStoreName, async () => { - const key = v4(); - const getResponse1 = await storageClient.get(testingStoreName, key); - expectWithMessage(() => { - expect(getResponse1.type).toEqual(StorageGetResponse.NotFound); - }, `expected NotFound, received ${getResponse1.toString()}`); + }); - await sleep(5000); + // Data plane tests should use the shared integration test store + // with the BeforeAll setup and AfterAll teardown + describe('#store get put and delete', () => { + it('put get and delete key in a store', async () => { + const key = v4(); - const getResponse2 = await storageClient.get(testingStoreName, key); - expectWithMessage(() => { - expect(getResponse2.type).toEqual(StorageGetResponse.NotFound); - }, `expected NotFound, received ${getResponse2.toString()}`); - }); + // put/get an int value + const intValue = 42; + const putIntResponse = await storageClient.putInt( + testingStoreName, + key, + intValue + ); + switch (putIntResponse.type) { + case StoragePutResponse.Success: { + break; + } + case StoragePutResponse.Error: { + throw new Error( + `failed to put key: ${putIntResponse.message()} ${putIntResponse.toString()}` + ); + } + } + const getIntResponse = await storageClient.get(testingStoreName, key); + expectWithMessage(() => { + expect(getIntResponse.type).toEqual(StorageGetResponse.Found); + }, `expected Found, received ${getIntResponse.toString()}`); + expect(getIntResponse.value()?.int()).toEqual(intValue); + + // put/get a double value + const doubleValue = 42.42; + const putDoubleResponse = await storageClient.putDouble( + testingStoreName, + key, + doubleValue + ); + switch (putDoubleResponse.type) { + case StoragePutResponse.Success: { + break; + } + case StoragePutResponse.Error: { + throw new Error( + `failed to put key: ${putDoubleResponse.message()} ${putDoubleResponse.toString()}` + ); + } + } + const getDoubleResponse = await storageClient.get(testingStoreName, key); + expectWithMessage(() => { + expect(getDoubleResponse.type).toEqual(StorageGetResponse.Found); + }, `expected Found, received ${getDoubleResponse.toString()}`); + expect(getDoubleResponse.value()?.double()).toEqual(doubleValue); + + // put/get a string value + const stringValue = v4(); + const putStringResponse = await storageClient.putString( + testingStoreName, + key, + stringValue + ); + switch (putStringResponse.type) { + case StoragePutResponse.Success: { + break; + } + case StoragePutResponse.Error: { + throw new Error( + `failed to put key: ${putStringResponse.message()} ${putStringResponse.toString()}` + ); + } + } + const getStringResponse = await storageClient.get(testingStoreName, key); + expectWithMessage(() => { + expect(getStringResponse.type).toEqual(StorageGetResponse.Found); + }, `expected Found, received ${getStringResponse.toString()}`); + expect(getStringResponse.value()?.string()).toEqual(stringValue); + + // put/get a bytes value + const bytesValue = new Uint8Array([1, 2, 3, 4]); + const putBytesResponse = await storageClient.putBytes( + testingStoreName, + key, + bytesValue + ); + switch (putBytesResponse.type) { + case StoragePutResponse.Success: { + break; + } + case StoragePutResponse.Error: { + throw new Error( + `failed to put key: ${putBytesResponse.message()} ${putBytesResponse.toString()}` + ); + } + } + const getBytesResponse = await storageClient.get(testingStoreName, key); + expectWithMessage(() => { + expect(getBytesResponse.type).toEqual(StorageGetResponse.Found); + }, `expected Found, received ${getBytesResponse.toString()}`); + expect(getBytesResponse.value()?.bytes()).toEqual(bytesValue); + + const deleteResponse = await storageClient.delete(testingStoreName, key); + switch (deleteResponse.type) { + case StorageDeleteResponse.Success: { + break; + } + case StorageDeleteResponse.Error: { + throw new Error( + `failed to delete key in store: ${deleteResponse.message()} ${deleteResponse.toString()}` + ); + } + } + }); + it('should return an undefined value for a key that doesnt exist', async () => { + const key = v4(); + const getResponse = await storageClient.get(testingStoreName, key); + expectWithMessage(() => { + expect(getResponse.type).toEqual(StorageGetResponse.NotFound); + }, `expected NotFound, received ${getResponse.toString()}`); + expect(getResponse.value()).toBeUndefined(); }); }); }